CS.NRE.FUNC.MUST
null を返す可能性がある関数の呼び出しによってオブジェクト参照値は、明示的に、またはそれを null についてチェックせずに逆参照する可能性がある関数を呼び出すことによって、逆参照されます。
脆弱性とリスク
null オブジェクト参照の逆参照は、一部のオペレーティングシステムでアプリケーションのクラッシュや実行時例外のスローを引き起こす実行時の重大な問題です。
例 1
コピー
public class A {
public A foo() {
if (flag)
return null;
return new A();
}
public void var() {
A a = foo();
a.foo();
}
private bool flag;
}
変数 'a' では、Klocwork は 10 行目で指摘レポート (CS.NRE.FUNC.MUST) を生成します。変数 'a' は 9 行目で null になる可能性がある値、および関数 'foo' の呼び出しによって返される値に割り当てられ、10 行目で逆参照されます。
外部参考資料
セキュリティトレーニング
Secure Code Warrior が提供しているアプリケーションセキュリティトレーニング教材。