PHP におけるクロスドメイン実装のいくつかの形式
##1. JSONP (パディング付き JSON) 原則
HTML の script タグを使用して他のドメインの js を読み込み、script src を使用して他のドメインのデータを取得しますが、タグを通じて導入されているため、つまり、要求された JSON 形式のデータは js として実行および処理されますが、明らかに、この操作は機能しません。
したがって、返されたデータを事前にパッケージ化し、処理を実行するための関数にカプセル化する必要があります。関数名は、インターフェイスのパラメータ転送メソッドを通じてバックグラウンドに渡されます。バックグラウンドで解析した後、関数名。元の関数で使用されます。 この関数名をデータにラップしてフロントエンドに送信します。 (JSONP を実現するには、対応するインターフェイスのバックエンドの協力が必要です)
例:
<script>function showData(ret){ console.log(ret); }</script><script src="http://api.jirengu.com/weather.php?callback=showData"></script>
2. CORS
CORS の正式名は、クロスオリジン リソース共有 (Cross-Origin Resource Sharing) です。 )、これは最新のブラウザをサポートする ajax クロスドメイン リソース リクエスト メソッドであり、IE は 10 以降をサポートします。
実装方法:
XMLHttpRequest を使用してリクエストを送信すると、ブラウザはリクエストが同一オリジン ポリシーに準拠していないことを検出します。 Aリクエストヘッダ:
Originを追加し、一連の処理がバックグラウンドで行われ、リクエストが受け付けられたと判断された場合、戻り結果にレスポンスヘッダ:
Access-が追加されます。 Control-Allow-Origin; ブラウザは、対応するヘッダーに Origin の値が含まれているかどうかを判断します。そうである場合、ブラウザは応答を処理し、応答データを取得できます。そうでない場合、ブラウザは直接拒否します。今回は応答データを取得できません。
server.js
var http = require('http') var fs = require('fs') var path = require('path') var url = require('url')http.createServer(function(req, res){ var pathObj = url.parse(req.url, true) switch (pathObj.pathname) { case '/getNews': var news = [ "第11日前瞻:中国冲击4金 博尔特再战200米羽球", "正直播柴飚/洪炜出战 男双力争会师决赛", "女排将死磕巴西!郎平安排男陪练模仿对方核心" ] res.setHeader('Access-Control-Allow-Origin','http://localhost:8080') //res.setHeader('Access-Control-Allow-Origin','*') res.end(JSON.stringify(news)) break; default: fs.readFile(path.join(__dirname, pathObj.pathname), function(e, data){ if(e){ res.writeHead(404, 'not found') res.end('<h1>404 Not Found</h1>') }else{ res.end(data) } }) }}).listen(8080)
index.html
<!DOCTYPE html><html><body> <div class="container"> <ul class="news"></ul> <button class="show">show news</button> </div><script> $('.show').addEventListener('click', function(){ var xhr = new XMLHttpRequest() xhr.open('GET', 'http://127.0.0.1:8080/getNews', true) xhr.send() xhr.onload = function(){ appendHtml(JSON.parse(xhr.responseText)) } }) function appendHtml(news){ var html = '' for( var i=0; i<news.length; i++){ html += '<li>' + news[i] + '</li>' } $('.news').innerHTML = html } function $(selector){ return document.querySelector(selector) } </script> </html>
3 , postMessage
2 つのドメイン名があり (メイン ドメインのドメイン名が一致していない)、iframe ページが呼び出しへのアクセスを許可されていると仮定すると、次のようになります。 postMessageで実装されています。原則: a ドメイン名は postMessage のリクエストを送信し、b ドメイン名はメッセージ イベントを受信し、データを処理して返します
//b域名<script>window.frames[0].postMessage(this.value, '*'); //*号表示在任何域下都可以接收message window.addEventListener('message', function(e){ console.log(e.data); });</script>
以上がクロスドメイン PHP のいくつかの方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。