セキュリティ Silverlight ドメイン間ポリシーファイル clientaccesspolicy.xml
スポンサーリンク
このドキュメントの内容は、以下の通りです。
FlashのSWFにクロスドメインのアクセスを許可するときは、crossdomain.xmlにアクセス許可を定義します。マイクロソフトのSilverlightでもクロスドメインでのアクセスを許可するためにドメイン間ポリシーファイルで定義する必要があります。HTTPのサポート
Silverlightは、HTTP/HTTPSの通信を行うことができます。
- 同一ドメインの呼び出しは常に可能
- GET/POSTのみがサポート
- 標準要求ヘッダーとカスタム要求ヘッダーをサポート
- ステータスコードは、200 OK と 404 Not Found のみが使用可能
HTTP通信
HTTP通信を行うためのクラス
- WebClient
- HttpWebRequest/HttpWebResponse
ヘッダ
リクエストのヘッダは、カスタマイズ可能だが、制限付きヘッダー(cookieとか)は設定することはできません。
同一ドメイン通信
Silverlightの通信は、同じドメイン、同じ発信元サイトにあるWebサービスの呼び出しがデフォルトでサポートされています。
同じドメインの場合、下記の制限があります。
- 同じプロトコル
- 同じサブドメイン
- 同じポート
- 異なるプロトコル
- 異なるホスト
- 異なるポート
ドメイン間通信とドメイン間ポリシーファイル
Silverlightから別のドメインのWebサービスを呼び出すためには、ドメインのルートにドメイン間ポリシーファイルを設置する必要があります。
Silverlightは、2種類のドメイン間ポリシーファイルがサポートされます。
Flashドメイン間ポリシーファイル | crossdomain.xml |
Silverlightドメイン間ポリシーファイル | clientaccesspolicy.xml |
通信の手順
1. ドメイン間通信の場合、Webサービスのルートの Silverlight ドメイン間ポリシーファイル(clientaccesspolicy.xml) を探します。
2. 404 Not Found等が返された場合、ルートにあるFlashドメイン間ポリシーファイル(crossdomain.xml)を探します。
ドメイン間ポリシーファイルは下記の制限を受けます。
- ドメイン間ポリシーファイルへのリダイレクトはできません。
- ドメイン間ポリシーファイルはアプリケーションのセッション間のみ有効です。
要求URI http://foo.com/services/data の場合
http://foo.com/clientaccesspolicy.xml を探します。
要求URI http://news.foo.com/services/data の場合
http://news.foo.com/clientaccesspolicy.xml を探します。
要求URI http://foo.com:8080/services/data の場合
http://foo.com:8080/clientaccesspolicy.xml を探します。
ドメイン間通信とセキュリティ
Silverlightの通信では、 Cookie が送信されます。
ほかのドメイン(foo.com)に設置されたSilverlightがbar.comへのアクセスを許可される場合、foo.comのSilverlightがbar.comへアクセスするときにbar.comのCookieも送信されます。bar.comのセッション管理がCookieで行われる場合、注意が必要になります。
ドメイン間ポリシーファイルでほかのドメインにアクセスを許可する場合には、ほかのドメインへ提供してもかまわない情報しか返してはいけません。
clientaccesspolicy.xml
すべてのドメインからアクセスを許す例です。
/api へのアクセスが許可されます。
サブパスは含まれません。
<?xml version="1.0" encoding="utf-8"?> <access-policy> <cross-domain-access> <policy> <allow-from> <domain uri="*"/> </allow-from> <grant-to> <resource path="/api" include-subpaths="false"/> </grant-to> </policy> </cross-domain-access> </access-policy>
domainの指定の例
- http://www.foo.net/
- http://*.foo.net/ サブドメインすべてが対象になります。
- http://*
- https://*
/api で サブディレクトリが無効( include-subpaths="false" の場合
- /api
- /api?a=100 にはアクセスすることが可能。
- /api/
- /api.txt
- /api/test
- /api/test?a=100
- /api/
- /api/test
- /api/test?a=100 にもアクセスすることができます。
スポンサーリンク
スポンサーリンク
いつもシェア、ありがとうございます!
もっと情報を探しませんか?
関連記事
最近の記事
- パナソニック ジェットウォッシャードルツ EW-DJ61-Wのホースの修理
- LinuxセキュリティモジュールIntegrity Policy Enforcement
- アマゾンのEcho Show 5を買ったのでレビューします
- アマゾンのサイバーマンデーはAlexa Echo Show 5が安い
- Android スマートフォン OnePlus 7T と OnePlus 7の違い
- Android スマートフォン OnePlus 7 をAndroid10にアップデートしてみた
- クレジットカードのバーチャルカードの比較のまとめ
- 活動量計 Xiaomi Mi Band 4を買ってみたのでレビュー
- Android スマートフォン OnePlus 7 のレビュー
- AliExpressでスマートフォンを買い物してみた
- パソコンのホコリ対策 レンジフードフィルターと養生テープ
- 80PLUS GOLDのPC電源ユニットAntec NeoEco 750 Goldのレビュー
- イギリスの付加価値税 VAT は払い戻しを受けられる
- イギリスのロンドンでスーツケースなど荷物を預けられる場所は
- イギリスのロンドンで地下鉄やバスに乗るならオイスターカードを使おう
- イギリスのヒースロー空港からロンドン市内への行き方
- 航空便でほかの航空会社に乗り継ぎがある場合のオンラインチェックイン
- SFC会員がANA便ではなくベトナム航空のコードシェアを試して解ったこと
- ベトナムの入国審査でeチケットの掲示が必要だった話
- シアトルの交通ICカードはオルカカード(Orca)です
人気のページ
- Windows7 IME 辞書ツールで単語の登録に失敗しました
- C言語 popen()でコマンドを実行して出力を読み込む
- Windows7で休止状態にする方法
- CentOS MySQLの起動、停止、再起動
- loggerコマンドでsyslogにエラーを出力する方法
- パソコンパーツの買取をしてくれる店のまとめ
- Java Mapの使い方 get(),put(),remove(),size(),clear()
- 楽天のRポイントカードを作ってみた
- iPhone 5 から iPhone 6 に乗り換えたのでレビュー
- netstatコマンドのステータスの意味
スポンサーリンク
過去ログ
2020 : 01 02 03 04 05 06 07 08 09 10 11 122019 : 01 02 03 04 05 06 07 08 09 10 11 12
2018 : 01 02 03 04 05 06 07 08 09 10 11 12
2017 : 01 02 03 04 05 06 07 08 09 10 11 12
2016 : 01 02 03 04 05 06 07 08 09 10 11 12
2015 : 01 02 03 04 05 06 07 08 09 10 11 12
2014 : 01 02 03 04 05 06 07 08 09 10 11 12
2013 : 01 02 03 04 05 06 07 08 09 10 11 12
2012 : 01 02 03 04 05 06 07 08 09 10 11 12
2011 : 01 02 03 04 05 06 07 08 09 10 11 12
2010 : 01 02 03 04 05 06 07 08 09 10 11 12
2009 : 01 02 03 04 05 06 07 08 09 10 11 12
2008 : 01 02 03 04 05 06 07 08 09 10 11 12
2007 : 01 02 03 04 05 06 07 08 09 10 11 12
2006 : 01 02 03 04 05 06 07 08 09 10 11 12
2005 : 01 02 03 04 05 06 07 08 09 10 11 12
2004 : 01 02 03 04 05 06 07 08 09 10 11 12
2003 : 01 02 03 04 05 06 07 08 09 10 11 12