Heim > Web-Frontend > js-Tutorial > Domänenübergreifende JavaScript-Methoden, Prinzipien und Problemlösungen (ausführliche Erklärung)_Javascript-Kenntnisse

Domänenübergreifende JavaScript-Methoden, Prinzipien und Problemlösungen (ausführliche Erklärung)_Javascript-Kenntnisse

WBOY
Freigeben: 2016-05-16 15:46:57
Original
1299 Leute haben es durchsucht

Der domänenübergreifende JavaScript-Zugriff ist ein Problem, auf das Webentwickler häufig stoßen. Was ist domänenübergreifend? Ein auf einer Domäne geladenes Skript erhält oder betreibt Dokumentattribute auf einer anderen Domäne. :
1. Domainübergreifende Implementierung auf Basis von iframe

Die domänenübergreifende Implementierung basierend auf IFrame erfordert, dass die beiden Domänen die Merkmale aa.xx.com und bb.xx.com aufweisen, dh die beiden Seiten müssen zu einer Basisdomäne gehören (z. B. beide xxx. com oder xxx .com.cn) verwenden dasselbe Protokoll (z. B. sind beide http) und denselben Port (z. B. sind beide 80). Auf diese Weise wird document.domain gleichzeitig zu beiden Seiten hinzugefügt kann die Funktion der übergeordneten Seite realisieren, die die untergeordnete Seite aufruft. Der Code lautet wie folgt:
Seite 1:
HTML-Code

<html> 
<head> 
 <script> 
 document.domain = "xx.com"; 
 function aa(){ 
  alert("p"); 
 } 
 </script> 
</head> 
<body> 
 <iframe src="http://localhost:8080/CmsUI/2.html" id="i"> 
 </iframe> 
 <script> 
 document.getElementById('i').onload = function(){ 
  var d = document.getElementById('i').contentWindow; 
  d.a(); 
 }; 
 </script> 
 </body> 
</html> 
Nach dem Login kopieren

Seite 2:

Html-Code

<html> 
 <head> 
 <script> 
 document.domain = "xx.com"; 
 function a(){ 
 alert("c"); 
  } 
 </script> 
 </head> 
 <body> 
 </body> 
</html> 
Nach dem Login kopieren

Zu diesem Zeitpunkt kann die übergeordnete Seite die A-Funktion der untergeordneten Seite aufrufen, um einen domänenübergreifenden js-Zugriff zu erreichen

2. Domänenübergreifende Implementierung basierend auf Skript-Tags

Das Skript-Tag selbst kann auf Ressourcen in anderen Domänen zugreifen und ist nicht durch die Same-Origin-Richtlinie des Browsers eingeschränkt. Sie können dynamisch ein Skript-Tag auf der Seite erstellen:

Java-Code

var script = document.createElement('script'); 
script.src = "http://aa.xx.com/js/*.js"; 
document.body.appendChild(script); 
Nach dem Login kopieren

Auf diese Weise können JS-Dateien aus anderen Domänen geladen werden, indem Skript-Tags dynamisch erstellt werden. Anschließend kann die Funktion der geladenen JS-Datei über diese Seite aufgerufen werden. Der Nachteil besteht darin, dass Dokumente aus anderen Domänen nicht geladen werden können Auf diese Weise werden nur JS-Dateien implementiert. JSONP übergibt einen Rückrufparameter an andere Domänen und verpackt den Rückrufparameterwert und die JSON-Zeichenfolge über den Hintergrund anderer Domänen Das Skript-Tag, der Browser Die zurückgegebene Zeichenfolge wird gemäß JavaScript analysiert und ausgeführt, wodurch die Datenübertragung zwischen Domänen realisiert wird.
Auch die Unterstützung von JSONP in JQuery basiert auf dieser Lösung.

3.Backend-Proxy-Methode

Diese Methode kann alle domänenübergreifenden Probleme lösen, das heißt, das Backend wird als Proxy verwendet und jede Anfrage für andere Domänen wird an das Backend dieser Domäne weitergeleitet. Das Backend dieser Domäne greift auf andere Domänen zu, indem es http simuliert Anfragen und dann Rückgabe Das Ergebnis wird an die Rezeption zurückgegeben. Der Vorteil davon besteht darin, dass der Zugriff domänenübergreifend erfolgen kann, unabhängig davon, ob es sich um ein Dokument oder eine JS-Datei handelt.

Die folgende Tabelle gibt die relative http://store.company.com/dir/page.htmlErgebnisse der Homologieerkennung:

Domänenübergreifende JavaScript-Methoden, Prinzipien und Problemlösungen (ausführliche Erklärung)_Javascript-Kenntnisse

Um domänenübergreifende Probleme zu lösen, können wir die folgenden Methoden verwenden:

1. Domänenübergreifend über jsonp

In js ist es nicht möglich, XMLHttpRequest direkt zum Anfordern von Daten in verschiedenen Domänen zu verwenden. Es ist jedoch möglich, js-Skriptdateien aus verschiedenen Domänen auf der Seite einzuführen. JSONP verwendet diese Funktion, um dies zu erreichen.

Zum Beispiel gibt es eine a.html-Seite, deren Code Ajax verwenden muss, um JSON-Daten auf einer anderen Domäne abzurufen. Angenommen, die JSON-Datenadresse ist

http://example.com/data .php, dann kann der Code in einer.html so aussehen:

Domänenübergreifende JavaScript-Methoden, Prinzipien und Problemlösungen (ausführliche Erklärung)_Javascript-Kenntnisse

Wir sehen, dass es nach der Adresse einen Rückrufparameter gibt, um die Daten zu erhalten. Konventionell wird dieser Parametername verwendet, Sie können jedoch auch andere Parameter verwenden. Wenn die JSONP-Adressseite zum Abrufen von Daten nicht unter Ihrer Kontrolle steht, müssen Sie natürlich gemäß dem von der Partei, die die Daten bereitstellt, angegebenen Format vorgehen.

Da es als JS-Datei eingeführt wird, muss

http://example.com/data.php eine ausführbare JS-Datei zurückgeben, sodass der PHP-Code dieser Seite möglicherweise so lautet:

Domänenübergreifende JavaScript-Methoden, Prinzipien und Problemlösungen (ausführliche Erklärung)_Javascript-Kenntnisse

Das endgültige Ausgabeergebnis dieser Seite ist:

Domänenübergreifende JavaScript-Methoden, Prinzipien und Problemlösungen (ausführliche Erklärung)_Javascript-Kenntnisse

Die über

http://example.com/data.php?callback=dosomething erhaltene js-Datei ist die Dosomething-Funktion, die wir zuvor definiert haben, und ihre Parameter sind die JSON-Daten, die wir hier benötigen So erhalten wir domänenübergreifend die Daten, die wir benötigen.

Auf diese Weise ist das Prinzip von jsonp sehr klar. Nachdem die js-Datei erfolgreich geladen wurde, führt sie die im URL-Parameter angegebene Funktion aus und übergibt die json-Daten wir brauchen als Parameter . Daher erfordert JSONP eine entsprechende Zusammenarbeit von der serverseitigen Seite.

Nachdem wir das Prinzip des domänenübergreifenden JSONP kennen, können wir js verwenden, um Skript-Tags für domänenübergreifende Vorgänge dynamisch zu generieren, ohne diese Skript-Tags manuell schreiben zu müssen. Wenn Ihre Seite JQuery verwendet, können Sie JSONP-Vorgänge problemlos über die gekapselte Methode ausführen.

Domänenübergreifende JavaScript-Methoden, Prinzipien und Problemlösungen (ausführliche Erklärung)_Javascript-Kenntnisse

Das Prinzip ist dasselbe, außer dass wir keine Skript-Tags manuell einfügen und Rückruffunktionen definieren müssen. jQuery generiert automatisch eine globale Funktion, um das Fragezeichen in callback=? zu ersetzen, und zerstört es dann automatisch, nachdem die Daten abgerufen wurden. Tatsächlich fungiert es als temporäre Proxy-Funktion. Die $.getJSON-Methode ermittelt automatisch, ob es sich um eine domänenübergreifende Methode handelt. Wenn nicht, ruft sie die gewöhnliche Ajax-Methode auf. Wenn sie domänenübergreifend ist, ruft sie die JSONP-Rückruffunktion in Form eines asynchronen Ladens der JS-Datei auf.

2. Übergreifen Sie Subdomains, indem Sie document.domain ändern

Alle Browser haben eine Same-Origin-Richtlinie, und eine ihrer Einschränkungen besteht darin, dass wir bei der ersten Methode gesagt haben, dass Sie Ajax nicht verwenden können, um Dokumente aus verschiedenen Quellen anzufordern. Die zweite Einschränkung besteht darin, dass js nicht zwischen Frames in verschiedenen Domänen im Browser interagieren kann. Eine Sache, die erklärt werden muss, ist, dass verschiedene Frameworks (Vater und Sohn oder Peers) die Fensterobjekte des anderen abrufen können. Das Ärgerliche ist jedoch, dass Sie die Eigenschaften und Methoden der erhaltenen Fensterobjekte nicht verwenden können (die postMessage-Methode in HTML5). eine Ausnahme, und einige Browser wie ie6 können auch einige Attribute wie top und parent verwenden). Zum Beispiel gibt es eine Seite, deren Adresse http://www.example.com/a.html ist, und auf dieser Seite gibt es einen Iframe, dessen Quelle http:// ist Beispiel .com/b.html, offensichtlich befinden sich diese Seite und der darin enthaltene Iframe in unterschiedlichen Domänen, sodass wir den Inhalt im Iframe nicht erhalten können, indem wir JS-Code in die Seite schreiben:

Domänenübergreifende JavaScript-Methoden, Prinzipien und Problemlösungen (ausführliche Erklärung)_Javascript-Kenntnisse

Zu diesem Zeitpunkt kann sich document.domain als nützlich erweisen. Wir müssen nur http://www.example.com/a.html und http://example.com hinzufügen / b.htmlSetzen Sie einfach die document.domain dieser beiden Seiten auf denselben Domainnamen. Es ist jedoch zu beachten, dass die Einstellung von document.domain begrenzt ist. Wir können document.domain nur auf sich selbst oder eine übergeordnete Domäne einer höheren Ebene festlegen und die Hauptdomäne muss dieselbe sein. Beispiel: Die document.domain eines Dokuments in a.b.example.com kann auf a.b.example.com, b.example.com oder example.com festgelegt werden, aus diesem Grund kann sie jedoch nicht auf c.a.b.example.com festgelegt werden ist die aktuelle Unterdomäne der Domäne kann nicht auf baidu.com festgelegt werden, da die Hauptdomäne nicht mehr dieselbe ist.

Legen Sie document.domain: auf der Seite http://www.example.com/a.html

fest

Domänenübergreifende JavaScript-Methoden, Prinzipien und Problemlösungen (ausführliche Erklärung)_Javascript-Kenntnisse

Legen Sie auch document.domain auf der Seite http://example.com/b.html fest, und dies ist auch notwendig. Obwohl die Domain dieses Dokuments example.com ist, muss sie es trotzdem sein angezeigt. Legen Sie den Wert von document.domain fest:

Domänenübergreifende JavaScript-Methoden, Prinzipien und Problemlösungen (ausführliche Erklärung)_Javascript-Kenntnisse

Auf diese Weise können wir über js auf verschiedene Attribute und Objekte im Iframe zugreifen.

Aber wenn Sie http://example.com/b.html direkt über Ajax im http://www.example.com/a.html anfordern möchten page Seite, selbst wenn Sie dieselbe document.domain festlegen, funktioniert dies immer noch nicht. Daher ist die Methode zum Ändern von document.domain nur auf die Interaktion zwischen Frames in verschiedenen Subdomains anwendbar. Wenn Sie über die Ajax-Methode mit Seiten in verschiedenen Subdomains interagieren möchten, können Sie zusätzlich zur JSONP-Methode auch einen versteckten Iframe als Proxy verwenden. Das Prinzip besteht darin, diesen Iframe eine Seite in derselben Domäne laden zu lassen wie die Zielseite, auf der Sie Daten über Ajax abrufen möchten, sodass die Seite in diesem Iframe Ajax verwenden kann, um die gewünschten Daten normal abzurufen, und dann über uns Die Methode von Durch das gerade erwähnte Ändern von document.domain können wir diesen Iframe vollständig über js steuern, sodass wir den Iframe eine Ajax-Anfrage senden lassen und dann auch die empfangenen Daten erhalten können.

3. Verwenden Sie window.name für domänenübergreifend

Das Fensterobjekt verfügt über ein Namensattribut, das eine Eigenschaft aufweist: Das heißt, innerhalb des Lebenszyklus eines Fensters (Fensters) teilen alle vom Fenster geladenen Seiten einen window.name und jede Seite hat eine eindeutige Beziehung zu Der Fenstername verfügt über Lese- und Schreibberechtigungen, die in allen in einem Fenster geladenen Seiten bestehen bleiben und beim Laden einer neuen Seite nicht zurückgesetzt werden.

Zum Beispiel: Es gibt eine Seite a.html, die diesen Code hat:

Domänenübergreifende JavaScript-Methoden, Prinzipien und Problemlösungen (ausführliche Erklärung)_Javascript-Kenntnisse

Schauen Sie sich noch einmal den Code der b.html-Seite an:

Domänenübergreifende JavaScript-Methoden, Prinzipien und Problemlösungen (ausführliche Erklärung)_Javascript-Kenntnisse

3 Sekunden nachdem die a.html-Seite geladen wurde, sprang sie zur b.html-Seite und das Ergebnis war:

Domänenübergreifende JavaScript-Methoden, Prinzipien und Problemlösungen (ausführliche Erklärung)_Javascript-Kenntnisse

Wir sehen, dass der von der vorherigen Seite a.html für window.name festgelegte Wert erfolgreich auf der Seite b.html abgerufen wurde. Wenn window.name auf allen nachfolgenden geladenen Seiten nicht geändert wird, ist der von allen diesen Seiten erhaltene Wert von window.name der von der a.html-Seite festgelegte Wert. Natürlich kann bei Bedarf jede der Seiten den Wert von window.name ändern. Beachten Sie, dass der Wert von window.name nur in Form einer Zeichenfolge vorliegen kann. Die maximale Größe dieser Zeichenfolge kann je nach Browser eine Kapazität von etwa 2 MB oder mehr ermöglichen, ist jedoch im Allgemeinen ausreichend.

Im obigen Beispiel befinden sich die von uns verwendeten Seiten a.html und b.html in derselben Domäne, aber selbst wenn sich a.html und b.html in unterschiedlichen Domänen befinden, gilt die obige Schlussfolgerung auch auch das Prinzip der domänenübergreifenden Verwendung von window.name.

Sehen wir uns an, wie man über window.name domänenübergreifende Daten erhält. Oder geben Sie ein Beispiel.

Wenn es beispielsweise eine Seite www.example.com/a.html gibt, müssen Sie die js in der Seite a.html verwenden, um eine weitere Seite www.cnblogs zu erhalten. com befindet sich in einer anderen Domäne. Die Daten in /data.html.

Der Code auf der Seite data.html ist sehr einfach. Er legt den Datenwert fest, den die Seite a.html für den aktuellen window.name erhalten möchte. Code in data.html:

Domänenübergreifende JavaScript-Methoden, Prinzipien und Problemlösungen (ausführliche Erklärung)_Javascript-Kenntnisse

Wie laden wir also auf der a.html-Seite die data.html-Seite? Offensichtlich können wir die Seite data.html nicht direkt laden, indem wir die window.location auf der Seite a.html ändern, da wir die Daten in data.html erhalten möchten, auch wenn die Seite a.html nicht springt. Die Antwort besteht darin, einen versteckten Iframe auf der a.html-Seite zu verwenden, der als Vermittler fungiert. Der iframe ruft die Daten von data.html ab, und a.html ruft dann die Daten vom iframe ab.

Wenn der als Mittelsmann fungierende Iframe den von window.name in data.html festgelegten Datensatz erhalten möchte, muss er nur die Quelle dieses Iframes auf www.cnblogs.com/data.html. Wenn a.html dann die vom Iframe erhaltenen Daten abrufen möchte, das heißt, wenn es den Wert von window.name des Iframes abrufen möchte, muss es auch den src des Iframes auf dieselbe Domäne wie a setzen Andernfalls kann a.html gemäß der Same-Origin-Richtlinie nicht auf das Attribut window.name im iframe zugreifen. Dies ist der gesamte domänenübergreifende Prozess.

Sehen Sie sich den Code der a.html-Seite an:

Domänenübergreifende JavaScript-Methoden, Prinzipien und Problemlösungen (ausführliche Erklärung)_Javascript-Kenntnisse

Der obige Code ist nur der einfachste Demonstrationscode. Sie können js verwenden, um den oben genannten Prozess zu kapseln, z. B. das dynamische Erstellen von Iframes, das dynamische Registrieren verschiedener Ereignisse usw. Natürlich aus Sicherheitsgründen nach dem Abrufen der Daten , können Sie den als Proxy fungierenden Iframe zerstören. Es gibt viele ähnliche vorgefertigte Codes im Internet. Wenn Sie interessiert sind, können Sie danach suchen.

Domainübergreifend erfolgt über window.name, so funktioniert es.

4. Verwenden Sie die in HTML5 neu eingeführte Methode window.postMessage, um Daten domänenübergreifend zu übertragen

Die

window.postMessage(message,targetOrigin)-Methode ist eine neu eingeführte Funktion von HTML5. Sie können sie verwenden, um Nachrichten an andere Fensterobjekte zu senden, unabhängig davon, ob das Fensterobjekt zum gleichen Ursprung oder zu einem anderen Ursprung gehört , Firefox, Chrome, Browser wie Opera unterstützen bereits die Methode window.postMessage.

Das Fensterobjekt, das die PostMessage-Methode aufruft, bezieht sich auf das Fensterobjekt, das die Nachricht empfangen möchte. Der erste Parameter dieser Methode ist die zu sendende Nachricht, und der Typ kann nur eine Zeichenfolge sein wird verwendet, um den Empfang einzuschränken. Wenn Sie die Domäne nicht einschränken möchten, können Sie den Platzhalter * verwenden.

Das Fensterobjekt, das Nachrichten empfangen muss, kann die eingehende Nachricht erhalten, indem es sein eigenes Nachrichtenereignis überwacht. Der Nachrichteninhalt wird im Datenattribut des Ereignisobjekts gespeichert.

Das Senden von Nachrichten an andere oben erwähnte Fensterobjekte bezieht sich tatsächlich auf die Situation, in der eine Seite mehrere Frames hat, da jeder Frame ein Fensterobjekt hat. Bei der Erörterung der zweiten Methode haben wir gesagt, dass Frameworks in verschiedenen Domänen die Fensterobjekte des anderen abrufen und auch die Methode window.postMessage verwenden können. Schauen wir uns ein einfaches Beispiel mit zwei Seiten an

Domänenübergreifende JavaScript-Methoden, Prinzipien und Problemlösungen (ausführliche Erklärung)_Javascript-Kenntnisse

Domänenübergreifende JavaScript-Methoden, Prinzipien und Problemlösungen (ausführliche Erklärung)_Javascript-Kenntnisse

Das Ergebnis, das wir nach dem Ausführen von Seite a erhalten haben:

Domänenübergreifende JavaScript-Methoden, Prinzipien und Problemlösungen (ausführliche Erklärung)_Javascript-Kenntnisse

Wir sehen, dass Seite b die Nachricht erfolgreich empfangen hat.

Die Verwendung von postMessage zum Übertragen von Daten über Domänen hinweg ist relativ intuitiv und bequem. Der Nachteil besteht jedoch darin, dass IE6 und IE7 dies nicht unterstützen. Daher hängt die Verwendung von postMessage von den tatsächlichen Anforderungen ab.

Fazit:

Zusätzlich zu den oben genannten Methoden gibt es auch domänenübergreifende Methoden wie Flash und das Einrichten von Proxy-Seiten auf dem Server, die hier nicht vorgestellt werden.

Die oben genannten vier Methoden können entsprechend der tatsächlichen Situation des Projekts ausgewählt und angewendet werden. Ich persönlich denke, dass die Methode window.name nicht kompliziert ist und mit fast allen Browsern kompatibel ist .

Das Obige ist der gesamte Inhalt dieses Artikels, in dem die domänenübergreifenden Methoden, Prinzipien und Lösungen von JavaScript vorgestellt werden. Ich hoffe, dass er für alle hilfreich sein wird.

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage