Heim >Web-Frontend >js-Tutorial >Zusammenfassung von drei Methoden zum Erreichen eines domänenübergreifenden Zugriffs mit Ajax
Dieses Mal werde ich Ihnen eine Zusammenfassung der drei Methoden von Ajax geben, um einen domänenübergreifenden Zugriff zu erreichen. Was sind die Vorsichtsmaßnahmen für Ajax, um einen domänenübergreifenden Zugriff zu implementieren? ein Blick.
1. Was ist domänenübergreifend?
Lassen Sie uns zunächst die Zusammensetzung der Domainnamenadresse überprüfen: http:// www . 8080 / script🎜> 8080 (Portnummer)script/jquery.js (angefragte Adresse)
* Wenn eines der Protokolle, Subdomainnamen, Hauptdomainnamen usw Portnummern sind unterschiedlich, alle zählen unterschiedliche „Domänen“. * Wenn verschiedene Domänen voneinander Ressourcen anfordern, spricht man von „domänenübergreifend“. Zum Beispiel: http://www.abc.com/index.html fordert http://www.def.com/sever.php an2. Cross-Verarbeitung Domain-Methode 1 – Agent
(Diese Methode ist relativ „dumm“, daher werde ich sie nicht im Detail vorstellen) Zum Beispiel in Peking (www.beijing.com/sever.php) und Shanghai (www.shanghai.com/sever.php) Jeder hat einen Server (www.beijing.com/sever.php) greift direkt auf den Dienst in Shanghai zu und gibt den erhaltenen Antwortwert dann an das Frontend zurück. Das heißt, der Dienst in Peking fungiert im Hintergrund als Proxy, und das Frontend muss nur auf den Server in Peking zugreifen, was dem Zugriff auf den Server in Shanghai entspricht. Diese Art von Agent gehört zur Hintergrundtechnologie, daher werde ich nicht näher darauf eingehen.3. Methode 2 für den Umgang mit domänenübergreifendem JSONP
Angenommen, dass auf der Seite http://www.aaa.com/index.php http : //www.bbb.com/getinfo.php sendet eine GET-Anfrage, dann fügen wir den folgenden Code zur Seite www.aaa.com hinzu:var eleScript= document.createElement("script"); //创建一个script元素 eleScript.type = "text/javascript"; //声明类型、 eleScript.src = "http://www.bbb.com/getinfo.php"; //添加src属性 引入跨域访问的url document.getElementsByTagName("HEAD")[0].appendChild(eleScript); //在页面中添加新创建的script元素Wenn die GET-Anfrage von http://www .bbb.com/ Wenn getinfo.php zurückkehrt, kann es einen Teil des JavaScript-Codes zurückgeben, der automatisch ausgeführt wird und zum Aufrufen einer Rückruffunktion auf der Seite http://www.aaa.com/index.php verwendet werden kann . Schauen Sie sich das folgende Beispiel an: auf der Seite www.aaa.com:
<script> function jsonp( json ){ document.write( json.name ); //输出周星驰 } <script> <script src="http://www.bbb.com/getinfo.php"></script>auf der Seite www.bbb.com:
jsonp({ "name": „ Stephen Chow“, „age“:45 });
Das heißt, es wird auf der Seite www.aaa.com deklariert und auf der Seite www.bbb.com aufgerufen. JSONP unterstützt jedoch nur „GET“-Anfragen, nicht jedoch „POST“-Anfragen.3. Methode 2 zur domänenübergreifenden Handhabung – XHR2 (empfohlene Methode)
„XHR2“ vollständiger Name „XMLHttpRequest Level2“ ist eine von HTML5 bereitgestellte Methode Für die domänenübergreifende Verarbeitung bietet Access großartige Unterstützung und es gibt einige neue Funktionen. * Versionen unter IE10 unterstützen nicht * Fügen Sie einfach die folgenden zwei Codezeilen zum serverseitigen Header hinzu: header( "Access-Control-Allow- Origin:*" );header( "Access-Control-Allow-Methods:POST,GET" );
Weitere Informationen zu „XHR2“ finden Sie in der offiziellen Dokumentation unter Ich werde hier nicht auf Details eingehen, aber dies ist eine sehr nützliche Methode. Ich glaube, dass Sie die Methode beherrschen, nachdem Sie den Fall in diesem Artikel gelesen haben. Weitere spannende Informationen finden Sie in anderen verwandten Artikeln auf der chinesischen PHP-Website! Empfohlene Lektüre:Das obige ist der detaillierte Inhalt vonZusammenfassung von drei Methoden zum Erreichen eines domänenübergreifenden Zugriffs mit Ajax. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!