C and C++ Binaries


BADFUNC.BO.GETS : getsの使用

要旨

実装によってはバッファオーバーフローに脆弱な gets(), _getts(), _getws() を使用しています。

プロパティ

クラス名 Use of gets
日本語クラス名 getsの使用
クラス分類 スタイル (style)
ニーモニック BADFUNC.BO.GETS
カテゴリー
MisraC2023 MisraC2023:1.5 Obsolescent language features shall not be used
Misra2012 Misra2012:1.5 Obsolescent language features shall not be used
AUTOSARC++14 AUTOSARC++14:A1-1-1 All code shall conform to ISO/IEC 14882:2014 - Programming Language C++ and shall not use deprecated features.
  AUTOSARC++14:A5-2-5 An array or container shall not be accessed beyond its range.
MisraC++2023 MisraC++2023:30.0.1 The C Library input/output functions shall not be used
CWE CWE:120 Buffer Copy without Checking Size of Input ('Classic Buffer Overflow')
  CWE:242 Use of Inherently Dangerous Function
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.
OWASP-2017 OWASP-2017:A9 Using components with known vulnerabilities
OWASP-2021 OWASP-2021:A6 Vulnerable and outdated components
対応言語 C および C++ で利用可能です。
有効/無効設定 このワーニングクラスのチェックはデフォルトで有効になっています。チェックを無効にするにはプロジェクト設定ファイル (configuration file)に以下の WARNING_FILTER ルールを追加してください。
WARNING_FILTER += discard class="Use of gets"

解決法

fgets() もしくは C++ ストリームオブジェクトを使用してください。

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

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

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