C and C++ Binaries


BADFUNC.BO.SYSLOG : syslogの使用

要旨

実装によってはセキュリティに問題のある syslog() が使用されています。

プロパティ

クラス名 Use of syslog
日本語クラス名 syslogの使用
クラス分類 セキュリティ (security)
ニーモニック BADFUNC.BO.SYSLOG
カテゴリー
AUTOSARC++14 AUTOSARC++14:A5-2-5 An array or container shall not be accessed beyond its range.
CWE CWE:120 Buffer Copy without Checking Size of Input ('Classic Buffer Overflow')
  CWE:676 Use of Potentially 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.
BSI BSI:SYSLOG-1 Use of syslog
対応言語 C および C++ で利用可能です。
有効/無効設定 このワーニングクラスのチェックはデフォルトで無効になっています。チェックを有効にするにはプロジェクト設定ファイル (configuration file)に以下の WARNING_FILTER ルールを追加してください。
WARNING_FILTER += allow class="Use of syslog"
全ての BSI 固有の BADFUNC クラスを含む BSI 関連クラスを有効にするには、 bsi 設定プリセットを使用してください。

解決法

使用しているライブラリの syslog() 実装は、その内部でバッファオーバーフローの可能性があるものか確認してください。

ある場合
  • ログメッセージサイズの上限チェックが行われているか否か確認してください。
    問題がないことを確認できた場合は、ワーニングの stateSuppressed (抑制)に変更して除外することができます。
  • もしくはライブラリを脆弱性のないバージョンにアップグレードしてください。
ない場合 このワーニングクラスを有効にする必要はありません。

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

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

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