次の方法で共有


CA2106: アサートをセキュリティで保護します

TypeName

SecureAsserts

CheckId

CA2106

[カテゴリ]

Microsoft.Security

互換性に影響する変更点

あり

原因

メソッドによってアクセス許可がアサートされますが、呼び出し元に対してセキュリティ チェックが実行されていません。

規則の説明

セキュリティ チェックを実行せずにセキュリティ アクセス許可をアサートすると、悪用される可能性があるセキュリティの弱点がコード内に残る場合があります。セキュリティ アクセス許可がアサートされると、セキュリティ スタック ウォークが停止します。呼び出し元にセキュリティ チェックを実行せずにアクセス許可をアサートすると、呼び出し元から作成者のアクセス許可を使用して間接的にコードを実行できる場合があります。セキュリティ チェックを実行せずにアサートすることは、アサートが有害な方法で利用できない場合に限り許されます。呼び出すコードが無害であるか、呼び出すコードにユーザーが任意の情報を渡すことができない場合、アサートは無害です。

違反の修正方法

この規則違反を修正するには、メソッドまたは宣言されている型にセキュリティ確認要求を追加します。

警告を抑制する状況

セキュリティの確認を慎重に行った後でのみ、この規則による警告を抑制してください。

参照

関連項目

CodeAccessPermission.Assert

その他の技術情報

安全なコーディングのガイドライン