次の方法で共有


コンテンツ セキュリティ ポリシー (CSP) の管理

この記事では、Microsoft Dynamics 365 Commerce のコンテンツ セキュリティ ポリシー (CSP) を管理する方法について説明します。

CSP は、特定タイプの Web 攻撃の検出と軽減に役立つ追加のセキュリティ レベルです。 これらの攻撃の目的は、データの盗用からサイトの変造やマルウェアの配布まで多岐に指定できます。 CSP は、サイトページに読み込むことができるリソースを制御するのに役立つ、広範なポリシー ディレクティブのセットを提供します。 各ディレクティブは、特定のタイプのリソースに対する制限を定義します。

電子商取引サイトの CSP を有効にすると、接続、スクリプト、フォント、および未知または悪意のあるソースから発生したその他の種類のリソースをブロックすることによって、セキュリティを強化できます。 Dynamics 365 Commerce では、CSP が既定で有効になります。 ただし、ほとんどのサイトでは、追加のコンフィギュレーションが必要となる場合があります。 Dynamics 365 Commerce オンライン ソフトウェア開発キット (SDK) では、スタイル、スクリプト、およびアプリケーション プログラミング インターフェイス (API) の呼び出し元で許可されたソースの URLs における既定リストを提供します。 サイトビルダー ツールの拡張タブで、このリストを編集できます。

CSP の詳細については、Content Security Policy Reference を参照してください。

CSP 設定

サイトの CSP を無効

CSP がサイトにポリシーが適用しないようにするには、サイト ビルダーのそのサイトに対してポリシーを無効にできます。

サイトの CSP を無効にするには、次の手順に従います。

  1. サイト ビルダーで、作業しているサイトを選択します。

  2. サイト設定を選択し、拡張タブを選択します。

  3. コンテンツ セキュリティ ポリシー タブで、コンテンツ セキュリティ ポリシーを無効にするチェック ボックスを選択します。

    Content Security Policy タブで、コンテンツ セキュリティ ポリシーを無効にします。

  4. 保存と公開を選択します。

レポートのみモードの有効化

CSP が有効になっている場合、コンテンツ セキュリティ ポリシーは適用されませんが、すべての違反がレポート URI ディレクティブで指定された URI に報告されます。

レポートのみのモードを有効化するには、次の手順に従います。

  1. サイト ビルダーで、作業しているサイトを選択します。
  2. サイト設定を選択し、拡張タブを選択します。
  3. コンテンツ セキュリティ ポリシー タブで、レポートのみのモードの有効化チェック ボックスを選択します。

Nonce を有効にする

Nonce (1 回だけ使用する番号) を有効にすると、インライン スクリプト モジュール 内で特定されたものを除き、すべてのインライン スクリプトの実行がブロックされます。 一意の暗号 Nonce が生成され、CSP ヘッダーで特定された各スクリプトに追加されます。

Nonce を有効にするには、次の手順に従います。

  1. サイト ビルダーで、作業しているサイトを選択します。
  2. サイト設定を選択し、拡張タブを選択します。
  3. コンテンツ セキュリティ ポリシー タブで、Nonce の有効化チェック ボックスを選択します。

コマースの CSP ディレクティブ

次の CSP ディレクティブは、コマース サイトで使用できます。

ディレクティブ 説明
child-src このディレクティブは、<frame> および <iframe> などの要素を使用して読み込まれる、Web ワーカーと入れ子になったブラウジング コンテキストの有効なソースを定義します。
connect-src このディレクティブは、AJAX 要求を作成できる URLs を定義します。
font-src このディレクティブは、フォントの有効なソースを定義します。
frame-ancestors このディレクティブは、<frame><iframe><object><embed>、または <applet> 要素を使用してページに埋め込むことができる有効な親を指定します。 このディレクティブを「なし」に設定することは、"X-Frame-Options: DENY" ディレクティブ (旧バージョンのブラウザーでもサポートされています) を指定することと似ています。
frame-src このディレクティブは、<frame> および <iframe> などの要素を使用して読み込まれる、入れ子になったブラウジング コンテキストの有効なソースを定義します。
img-src このディレクティブは、画像の有効なソースを定義します。
media-src このディレクティブは、HTML5 <audio> および <video> 要素などのオーディオおよびビデオの有効なソースを定義します。
object-src このディレクティブは、<object><embed>、および <applet> 要素などのプラグインの有効なソースを定義します。
report-uri このディレクティブは、ブラウザーが CSP 違反レポートを転記する URI を定義します。 これらの違反レポートは、指定された URI に HTTP POST 要求を通じて送信される JSON ドキュメントで構成されます。
script-src このディレクティブは、JavaScript の有効なソースを定義します。
style-src このディレクティブは、stylesheets の有効なソースを定義します。

例: CSP ディレクティブのコンフィギュレーション

次の例の手順は、サイトから外部スクリプトを呼び出すことができるように、CSP ディレクティブを設定する方法を示しています。

  1. サイト ビルダーで、作業しているサイトを選択します。

  2. サイト設定を選択し、拡張タブを選択します。

  3. コンテンツ セキュリティ ポリシー タブの、script-src追加を選択し、呼び出す外部スクリプトの完全な URL を入力します。

    Content Security Policy タブの外部スクリプト用 URL。

  4. 保存と公開を選択します。

CSP エラーの解釈と修正

最初にサイトの CSP をコンフィギュレーションすると、一部のページがまったく読み込まれないか、意図したとおりに機能しない可能性があります。それは、CSP が外部接続、スクリプト、フォント、およびその他の種類のリソースの読み込みをブロックしているからです。 ただし、CSP は不要な要求または不要な要求を修正、調整、およびクリーン アップするために使用できるいくつかの有用なエラーをログに記録します。

次の図では、Web ブラウザーの開発ツールにおける CSP エラーの例を示しています。

Web ブラウザーの開発者ツールにおける CSP エラー。

この例では、次の 2 つの CSP エラーがあります。

  • Eval 関数は、任意の JavaScript を実行する可能性があるため、既定ではブロックされています。 この関数を使用するには、'危険 -eval' をサイトのスクリプト -src ディレクティブに追加します。 単一の引用符が必要です。
  • 外部スタイルシートがブロックされています。 スタイルシートを外部ドメインから読み込むには、URL をサイトのスタイル -src ディレクティブに追加します。

次のスクリーンショットでは、コマースにて Content Security Policy タブの固定設定がどのように表示されるか示します。

Content Security Policy タブの固定設定。

CSP を使用するページ モックの更新

開発環境でオンライン SDK を使用してモジュールをテストする場合、ページ モックを使用して CSP を追加することもできます。 ページ モックでは、トップ レベルの "appContext" プロパティを追加するか、または既存のトップレベルの "appContext" プロパティに移動して、"contentSecurityPolicy" という名前のプロパティを作成する必要があります。 ここでは、次の例に示すように、ディレクティブのキー / 値ペアをポリシーに追加できます。

"appContext": {
	"contentSecurityPolicy": {
		"script-src": ["https://www.w3schools.com/js/myScript.js"],
		"font-src": ["https://*.commerce.dynamics.com"]
	}
}

メモ

ページ モックに CSP ポリシーを追加する場合、ページ モックには、プラットフォームによって提供される既定の CSP ポリシーは含まれません。

ページ モックで CSP を無効にするには、次のコードを使用します。

"appContext": {
	"contentSecurityPolicy": {
		"disableContentSecurityPolicy": true
	}
}

追加リソース

電子コマースのユーザーとロールの管理

サイト ページにスクリプト コードを追加して機能の変更をサポート

サイトに関する検索エンジンの最適化 (何を考慮)