C and C++ Binaries


BADFUNC.PATH.SHELLEXECUTE : ShellExecuteの使用

要旨

ファイル名の引数が安全に定義されていない時、パスのなりすましに対して脆弱な ShellExecute() もしくは ShellExecuteEx() を使用しています。

プロパティ

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

解決法

HINSTANCE ShellExecute(
  • HWND hwnd,
  • LPCTSTR lpOperation,
  • LPCTSTR lpFile,
  • LPCTSTR lpParameters,
  • LPCTSTR lpDirectory,
  • INT nShowCmd)
BOOL ShellExecuteEx(LPSHELLEXECUTEINFO lpExecInfo)

ShellExecute() の場合、 lpFile, lpDirectory 引数が信頼されるソースからの絶対パス名である事を確認し、 lpFile 値がファイル拡張子を含むことを確認してください。 また lpParameters が空白を含む場合、それが正しくダブルクオートで囲まれていることを確認してください。

ShellExecuteEx() の場合、 lpExecInfo にて lpFile, lpParameters, lpDirectory がカプセル化されていますが、それらの引数に ShellExecute() と同じ確認をしてください。

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

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

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

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