So lösen Sie das Problem, dass domänenübergreifende Bilder in thinkphp nicht angezeigt werden

WBOY
Freigeben: 2023-05-31 22:01:37
nach vorne
975 Leute haben es durchsucht

Lassen Sie uns zunächst verstehen, was domänenübergreifend ist. Cross-Domain tritt zwischen zwei Websites mit unterschiedlichen Domainnamen auf. Wenn die Ressourcen einer Website, wie z. B. JS, CSS, Ajax oder Bilder, den Zugriff auf die Ressourcen einer anderen Website anfordern, werden sie aufgrund der Einschränkungen derselben blockiert. Herkunftspolitik. Eine Website darauf zu beschränken, nur auf Ressourcen mit demselben Domänennamen, demselben Protokoll und demselben Port wie sie selbst zuzugreifen, ist ein wichtiges Sicherheitsmerkmal der Same-Origin-Richtlinie.

Wir verwenden eine Bibliothek eines Drittanbieters zum Laden von Bildern in das Projekt, die Adressen mit unterschiedlichen Domänennamen zum Speichern von Bildern verwendet. Daher kann das Bild im Browser nicht ordnungsgemäß angezeigt werden, wenn es domänenübergreifend ist.

Um dieses Problem zu lösen, müssen wir einige Einstellungen auf der Serverseite vornehmen. Die gebräuchlichste Lösung besteht darin, CORS (Cross-Origin Resource Sharing) serverseitig einzurichten. CORS ermöglicht es dem Server, den Zugriff auf die Ressource bei der Beantwortung von Clientanfragen nur auf bestimmte Domänennamen zu beschränken.

Im ThinkPHP-Framework können wir CORS implementieren, indem wir den folgenden Code in die Datei index.php einfügen:

header('Access-Control-Allow-Origin:*'); //允许所有来源访问
header('Access-Control-Allow-Method:POST,GET'); //允许访问的方式
Nach dem Login kopieren

Dieser Code ermöglicht allen Quellen den Zugriff auf Ressourcen und ermöglicht den POST- und GET-Zugriff.

Wichtig ist hier zu beachten, dass dieser Code oben in index.php platziert werden sollte, damit alle Anfragen diese Einstellung verwenden können.

Neben der Einrichtung von CORS können wir auch andere Methoden zur Lösung domänenübergreifender Probleme nutzen. Beispielsweise ist JSONP (JSON mit Padding) eine praktikable Methode zur Lösung domänenübergreifender Probleme. Durch das Hinzufügen eines Skript-Tags zur Seite werden die Daten, auf die zugegriffen werden muss, in eine Funktion gepackt und die zurückgegebenen Ergebnisse werden dann empfangen eine andere Website.

Im ThinkPHP-Framework können wir den folgenden Code verwenden, um die JSONP-Methode zu generieren:

$callback = isset($_GET['callback']) ? $_GET['callback'] : 'callback';
$data = array('name' => 'test', 'age' => 18);
echo $callback . '(' . json_encode($data) . ')';
Nach dem Login kopieren

Wir prüfen zunächst, ob der GET-Parameter einen Callback-Parameter hat, und wenn ja, verwenden wir diesen Parameter als Funktionsnamen. Konvertieren Sie als Nächstes die zurückzugebenden Daten in das JSON-Format und fügen Sie sie der Rückruffunktion hinzu. Wenn wir schließlich Daten zurückgeben, geben wir die Funktion zusammen mit den Daten an den Browser zurück.

Das obige ist der detaillierte Inhalt vonSo lösen Sie das Problem, dass domänenübergreifende Bilder in thinkphp nicht angezeigt werden. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:yisu.com
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
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!