[Sitecore][Error]method through reflection is not allowed
data:image/s3,"s3://crabby-images/43c0d/43c0df8f1a9d6d3dfc4e358fe3c23b7cf1873dab" alt=""
検証環境:Sitecore 10.2.0
概要:
従来動作していたSPEでスクリプトをがエラーが発生しているというタスクが渡されました。これはその設定のメモ書きです。
エラーメッセージ:
Method through reflection is not allowed
data:image/s3,"s3://crabby-images/8b938/8b938db1d0b7d8c1308b8bfd1c7e579026142c5a" alt=""
発生場所:
スクリプトを完了後、ウィンドウをクローズする際にポップアップされます:
data:image/s3,"s3://crabby-images/c4e3b/c4e3b03b8822b6cbc8dd66410eccf024d12b0a8b" alt=""
クイック解決策:
ローカールでとりあえずこのエアーを解決するなら、下記の設定を有効にすればよい。
ファイルパス:”\App_Config\Sitecore\CMS.Core\Sitecore.Reflection.Filtering.config”
設定:Sitecore.Reflection.Filtering.Disabled
ホワイトリストフィルタリングを無効にします。有効の場合メソッドはホワイトリストに登録されていない場合でも許可されます。このようなメソッドに対してワーニングがログにて記録されます。この設定が true か false かにかかわらず、forbiddenMethods のメソッドは許可されません。
初期値は無効です。
data:image/s3,"s3://crabby-images/699ce/699ce8b5eeb28b07e22483bd7530576a82123b3d" alt=""
勧められた解決策:
Sitecore.Reflection.Filtering.Disabledの設定を変更せず、allowedMethodsにて許可するメソッドを追加。
data:image/s3,"s3://crabby-images/38b34/38b3467a6e5ca629677fe126a415721f2a0e3bb7" alt=""
許可するメソッドを追加:
まず、Okclickメソッドの情報を取集。
SPEをディコンパイルします:
data:image/s3,"s3://crabby-images/db6d8/db6d8ffed58b275eb4b7a1c92c143c8517eb25a0" alt=""
OkClickメソッドを特定:
data:image/s3,"s3://crabby-images/3aab6/3aab67e01044e66828ef3868285de3afc6b15c3f" alt=""
許可するメソッドへ追加:
data:image/s3,"s3://crabby-images/5bc7c/5bc7ccc56e989a129002789d0d2cb0bf04b037aa" alt=""
結論:
このように、Method through reflection is not allowedのエラーに対して、必要なメソッドを追加していけばよい。ネットでこれに関して検索するところ、Sitecore セキュリティ情報 SC2023-003-587441 にて、sitecore.shell.Applications.Dialogs.Publish.PublishForm.StartPublisherも同じようなエラーがあり、同じ方法で許可するメソッドを追加すればよい。