Heim > Web-Frontend > js-Tutorial > Hauptteil

Warum löst canvas.toDataURL() beim Laden von Bildern von verschiedenen Servern eine Sicherheitsausnahme aus?

Linda Hamilton
Freigeben: 2024-10-31 10:07:02
Original
929 Leute haben es durchsucht

Why Does canvas.toDataURL() Throw a Security Exception When Loading Images From Different Servers?

Cross-Origin-Problem in Canvas toDataURL()

Obwohl für ausreichend Ruhe gesorgt ist, können Benutzer bei der Verwendung von canvas.toDataURL() auf Sicherheitsausnahmen stoßen . Betrachten Sie den folgenden Code:

<code class="javascript">var frame = document.getElementById("viewer");
frame.width = 100;
frame.height = 100;

var ctx = frame.getContext("2d");
var img = new Image();
img.src = "http://www.ansearch.com/images/interface/item/small/image.png"

img.onload = function() {
    // Draw image
    ctx.drawImage(img, 0, 0)

    // Security exception occurs here:
    window.open(frame.toDataURL("image/png"));
}</code>
Nach dem Login kopieren

Dieser Code versucht, ein Bild von einem anderen Server als Base64-Daten in einem neuen Fenster zu öffnen, löst jedoch eine SECURITY_ERR-Ausnahme aus.

Gemäß den Spezifikationen , löst die toDataURL()-Methode eines Canvas-Elements eine SECURITY_ERR-Ausnahme aus, wenn sein Origin-Clean-Flag auf false gesetzt ist. Wenn ein Bild von einem anderen Server geladen wird, wird die Leinwand beschädigt und das Flag „Origin-Clean“ wird auf „false“ gesetzt.

Daher ist es nicht möglich, toDataURL() direkt zu verwenden, um Base64-Daten für Bilder zu erhalten, von denen die Quelle stammt verschiedene Server. Für den Umgang mit ursprungsübergreifenden Bildern können alternative Techniken wie CORS oder Proxys erforderlich sein.

Das obige ist der detaillierte Inhalt vonWarum löst canvas.toDataURL() beim Laden von Bildern von verschiedenen Servern eine Sicherheitsausnahme aus?. 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
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!