Esta página ha sido traducida del inglés por la comunidad.Aprende más y únete a la comunidad de MDN Web Docs.
Imagen con CORS habilitado
La especificación HTML introduce un atributocrossorigin para imágenes que, en conjunto con el encabezadoCORS apropiado, permite definir imágenes con el elemento<img> que se carguen de orígenes externos dentro de un lienzo (canvas) como si estas fuesen cargadas del origen actual.
Vea el artículo"Atributos de configuración CORS" para mas detalles de como el atributo "crossorigin" es usado.
In this article
¿Qué es un "tainted" canvas?
Aunque puedes usar imágenes sin la aprobación del CORS en el elemento canvas, hacerlo puede "manchar" el canvas. Por ejemplo, no puedes usar los métodos canvastoBlob(),toDataURL(), orgetImageData(). Si los usas se lanzará un mensaje de seguridad.
Esto protegerá a los usuarios de tener información privada usada por medio de imágenes que cogen información desde otras web sin permiso.
Ejemplo: Almacenando una imagen desde un origen externo
Debes de tener un servidor de hosting de imágenes con el apropiadoAccess-Control-Allow-Origin header. Añadiendo el atributo crossOrigin crea un request header.
Puedes utilizar este fragemto de la configuración del servidor Apache del Boilerplate HTML5 para responder apropiadamente con este encabezado de respuesta.
<IfModule mod_setenvif.c> <IfModule mod_headers.c> <FilesMatch "\.(cur|gif|ico|jpe?g|png|svgz?|webp)$"> SetEnvIf Origin ":" IS_CORS Header set Access-Control-Allow-Origin "*" env=IS_CORS </FilesMatch> </IfModule></IfModule>Dado que está todo ordenado, serás capás de guardar esas imagenes en el almacenamiento del DOM, así como si fueran solicitados de tu dominio.
var img = new Image(), canvas = document.createElement("canvas"), ctx = canvas.getContext("2d"), src = "http://example.com/image"; // insert image url hereimg.crossOrigin = "Anonymous";img.onload = function () { canvas.width = img.width; canvas.height = img.height; ctx.drawImage(img, 0, 0); localStorage.setItem("savedImageData", canvas.toDataURL("image/png"));};img.src = src;// make sure the load event fires for cached images tooif (img.complete || img.complete === undefined) { img.src = ""; img.src = src;}