C and C++ Binaries


BADFUNC.BO.STRSPN : strspnの使用

要旨

stdlib.h (C) / <cstring> (C++)で宣言される関数strspn()を使用しています。

この関数は、引数のいずれか(または両方)でバッファの終端を超えた読み取りが可能です。ただし、そのバッファにヌル終端ではない文字列が含まれる場合に限ります。

プロパティ

クラス名 Use of strspn
日本語クラス名 strspnの使用
クラス分類 セキュリティ (security)
ニーモニック BADFUNC.BO.STRSPN
カテゴリー
MisraC2023 MisraC2023:21.17 Use of the string handling functions from <string.h> shall not result in accesses beyond the bounds of the objects referenced by their pointer parameters
Misra2012 Misra2012:21.17 Use of the string handling functions from <string.h> shall not result in accesses beyond the bounds of the objects referenced by their pointer parameters
AUTOSARC++14 AUTOSARC++14:A5-2-5 An array or container shall not be accessed beyond its range.
  AUTOSARC++14:M18-0-5 The unbounded functions of library <cstring> shall not be used.
MisraC++2008 MisraC++2008:18-0-5 The unbounded functions of library <cstring> shall not be used.
MisraC++2023 MisraC++2023:21.2.2 The string handling functions from <cstring>, <cstdlib>, <cwchar> and <cinttypes> shall not be used
CWE CWE:120 Buffer Copy without Checking Size of Input ('Classic Buffer Overflow')
  CWE:676 Use of Potentially Dangerous Function
CERT-C CERT-C:STR07-C Use the bounds-checking interfaces for string manipulation
CERT-CPP CERT-CPP:CTR52-CPP Guarantee that library functions do not overflow
DISA-6r1 DISA-6r1:V-222612 The application must not be vulnerable to overflow attacks.
DISA-5r3 DISA-5r3:V-70277 The application must not be vulnerable to overflow attacks.
DISA-4r3 DISA-4r3:V-70277 The application must not be vulnerable to overflow attacks.
DISA-3r10 DISA-3r10:V-6165 The designer will ensure the application does not have buffer overflows, use functions known to be vulnerable to buffer overflows, and does not use signed values for memory allocation where permitted by the programming language.
対応言語 C および C++ で利用可能です。
有効/無効設定 このワーニングクラスのチェックはデフォルトで無効になっています。チェックを有効にするにはプロジェクト設定ファイル (configuration file)に以下の WARNING_FILTER ルールを追加してください。
WARNING_FILTER += allow class="Use of strspn"

#include "cstring"

int use_strspn(const char* instr, size_t target){
    if (strspn(instr, "ABC") >= target){  // "Use of strspn" warning issued here.
        return 1;
    }
    return 0;
}

関連のある設定ファイルパラメータ

このクラスは一般テンプレート設定ファイルで BAD_FUNCTION_* ルールセットによって実装されています。

設定ファイルの以下のパラメータがこのワーニングクラスのチェックに影響します。