C and C++ Binaries


BADFUNC.PATH.POPEN : popenの使用

要旨

パスの引数が安全に定義されていない場合、パスのなりすましに対して脆弱な popen() を使用しています。

プロパティ

クラス名 Use of popen
日本語クラス名 popenの使用
クラス分類 セキュリティ (security)
ニーモニック BADFUNC.PATH.POPEN
カテゴリー
CWE CWE:676 Use of Potentially Dangerous Function
DISA-6r1 DISA-6r1:V-222604 The application must protect from command injection.
DISA-5r3 DISA-5r3:V-70261 The application must protect from command injection.
DISA-4r3 DISA-4r3:V-70261 The application must protect from command injection.
DISA-3r10 DISA-3r10:V-6157 The designer will ensure the application does not contain invalid URL or path references.
  DISA-3r10:V-16810 The designer will ensure the application does not allow command injection.
BSI BSI:Exec-SearchPath-01  
対応言語 C および C++ で利用可能です。
有効/無効設定 このワーニングクラスのチェックはデフォルトで無効になっています。チェックを有効にするにはプロジェクト設定ファイル (configuration file)に以下の WARNING_FILTER ルールを追加してください。
WARNING_FILTER += allow class="Use of popen"
全ての BSI 固有の BADFUNC クラスを含む BSI 関連クラスを有効にするには、 bsi 設定プリセットを使用してください。

解決法

FILE * popen(const char *command, const char *mode)

command 引数が信頼されるソースからの絶対パス名である事を確認してください。

問題がないことを確認できた場合は、ワーニングの stateSuppressed (抑制)に変更して除外することができます。

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

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

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