Heim > Web-Frontend > js-Tutorial > Warum kann AJAX kein domänenübergreifendes HTML laden, wenn JSONP nicht verwendet wird, und wie kann das Problem gelöst werden?

Warum kann AJAX kein domänenübergreifendes HTML laden, wenn JSONP nicht verwendet wird, und wie kann das Problem gelöst werden?

Barbara Streisand
Freigeben: 2024-12-29 19:32:12
Original
749 Leute haben es durchsucht

Why Does AJAX Fail to Load Cross-Domain HTML Unless JSONP is Used, and How Can This Be Solved?

Laden eines domänenübergreifenden Endpunkts mit AJAX

Problem:

Sie stoßen auf Schwierigkeiten beim Laden einer domänenübergreifenden HTML-Seite mit AJAX, es sei denn, der dataType ist auf „jsonp“ gesetzt. Selbst bei Verwendung von JSONP erwartet der Browser einen Skript-MIME-Typ, empfängt aber stattdessen „text/html“.

Lösung 1: Verwendung von Drittanbieter-Proxys

Aus Sicherheitsgründen Da wir Bedenken haben, dass Drittanbieter-Proxys Benutzerdaten verfolgen, wird von deren Verwendung mit privaten Informationen abgeraten. Sie können jedoch für öffentliche Datenszenarien geeignet sein.

Berücksichtigen Sie die folgenden Proxy-Optionen:

  • CORS Anywhere: Fügt automatisch CORS-Header zu Proxy-Anfragen hinzu.
$.ajaxPrefilter(function (options) {
  if (options.crossDomain && jQuery.support.cors) {
    var http = (window.location.protocol === 'http:' ? 'http:' : 'https:');
    options.url = http + '//cors-anywhere.herokuapp.com/' + options.url;
  }
});
Nach dem Login kopieren
  • Was auch immer Herkunft: Erleichtert den domänenübergreifenden JSONP-Zugriff.
$.ajaxSetup({
  scriptCharset: "utf-8",
  contentType: "application/json; charset=utf-8"
});

$.getJSON('http://whateverorigin.org/get?url=' +
  encodeURIComponent('http://google.com') + '&callback=?',
  function (data) {
    console.log("> ", data);
    $("#viewer").html(data.contents);
  }
);
Nach dem Login kopieren
  • CORS-Proxy: Vereinfacht CORS-Anfragen für jede Website.
$.get(
  'http://www.corsproxy.com/' +
  'en.wikipedia.org/wiki/Cross-origin_resource_sharing',
  function (response) {
    console.log("> ", response);
    $("#viewer").html(response);
  }
);
Nach dem Login kopieren

Lösung 2: Einrichten Ihres Backends Proxy

Der sicherste Ansatz besteht darin, einen Proxy im Back-End zu erstellen, um das domänenübergreifende Problem zu lösen.

Das obige ist der detaillierte Inhalt vonWarum kann AJAX kein domänenübergreifendes HTML laden, wenn JSONP nicht verwendet wird, und wie kann das Problem gelöst werden?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage