web-dev-qa-db-ja.com

クロスサブドメインのiframeとJavaScript

次のドメインのCMSサイトで作業しています。

http://www.acmssite.com

彼らはフォームシステムを保存するサブドメインを持っています:

http://www.forms.acmssite.com

最初のiframeを使用して、後者のフォームを確認します。

前者から後者を操作するためにスクリプトを実行する必要がありますが、これは可能ですか?

27
RyanP13

これが同じOriginポリシーによって制限されないようにするには、おそらく両方のページでこれを行う必要があります。

document.domain = "acmssite.com";
62
Dark Falcon

はい、そうです。

var iframe = document.getElementById("your-iframes-id").contentWindow.document;
2
Cobra_Fast

受信ウィンドウのヘッダー部分にアクセスできない場合でも、YQLを使用してこの問題を回避できます。 Postmessageメソッドでも、受信者ウィンドウスクリプトを編集する必要があります。ただし、この方法を使用すると、スクリプトに触れずにiframeを読み込むことができます。これをチェック! jsfiddle-link

<html>
<iframe src="https://google.com/" width="500" height="300"></iframe>

<script>
var iframe = document.getElementsByTagName('iframe')[0];
var url = iframe.src;
var getData = function (data) {
    if (data && data.query && data.query.results && data.query.results.resources && data.query.results.resources.content && data.query.results.resources.status == 200) loadHTML(data.query.results.resources.content);
    else if (data && data.error && data.error.description) loadHTML(data.error.description);
    else loadHTML('Error: Cannot load ' + url);
};
var loadURL = function (src) {
    url = src;
    var script = document.createElement('script');
    script.src = 'https://query.yahooapis.com/v1/public/yql?q=select%20*%20from%20data.headers%20where%20url%3D%22' + encodeURIComponent(url) + '%22&format=json&diagnostics=true&env=store%3A%2F%2Fdatatables.org%2Falltableswithkeys&callback=getData';
    document.body.appendChild(script);
};
var loadHTML = function (html) {
    iframe.src = 'about:blank';
    iframe.contentWindow.document.open();
    iframe.contentWindow.document.write(html.replace(/<head>/i, '<head><base href="' + url + '"><scr' + 'ipt>document.addEventListener("click", function(e) { if(e.target && e.target.nodeName == "A") { e.preventDefault(); parent.loadURL(e.target.href); } });</scr' + 'ipt>'));
    iframe.contentWindow.document.close();
}

loadURL(iframe.src);
</script>
</html>
0
Gihan Gamage