Je souhaite enregistrer ma toile dans une image. J'ai cette fonction:
function save() {
document.getElementById("canvasimg").style.border = "2px solid";
var dataURL = canvas.toDataURL();
document.getElementById("canvasimg").src = dataURL;
document.getElementById("canvasimg").style.display = "inline";
}
Cela me donne une erreur:
Uncaught SecurityError: Impossible d'exécuter 'toDataURL' sur 'HTMLCanvasElement': les toiles contaminées ne peuvent pas être exportées.
Que devrais-je faire?
javascript
html5-canvas
user3465096
la source
la source
Réponses:
Pour des raisons de sécurité, votre lecteur local est déclaré "autre domaine" et entachera le canevas.
(C'est parce que vos informations les plus sensibles sont probablement sur votre lecteur local!).
Pendant le test, essayez ces solutions de contournement:
Placez tous les fichiers liés à la page (.html, .jpg, .js, .css, etc.) sur votre bureau (pas dans des sous-dossiers).
Publiez vos images sur un site prenant en charge le partage entre domaines (comme dropbox.com). Assurez-vous de placer vos images dans le dossier public de Dropbox et de définir également l'indicateur d'origine croisée lors du téléchargement de l'image (var img = new Image (); img.crossOrigin = "anonymous" ...)
Installez un serveur Web sur votre ordinateur de développement (les serveurs Web IIS et PHP ont tous deux des éditions gratuites qui fonctionnent bien sur un ordinateur local).
la source
Dans la balise img, définissez crossorigin sur Anonymous.
<img crossorigin="anonymous"></img>
la source
Si quelqu'un regarde ma réponse, vous êtes peut-être dans cette condition:
1. Essayer d'obtenir une capture d'écran de la carte dans le canevas en utilisant openlayers (version> = 3)
2. Et vu l'exemple d' exportation de la carte
3. Utilisation de ol.source.XYZ pour rendre la couche de carte
Bingo!
En utilisant ol.source.XYZ.crossOrigin = 'Anonymous' pour résoudre votre confusion. Ou comme le code suivant:
var baseLayer = new ol.layer.Tile({ name: 'basic', source: new ol.source.XYZ({ url: options.baseMap.basic, crossOrigin: "Anonymous" }) });
la source
Si vous utilisez la
ctx.drawImage()
fonction, vous pouvez effectuer les opérations suivantes:var img = loadImage('../yourimage.png', callback); function loadImage(src, callback) { var img = new Image(); img.onload = callback; img.setAttribute('crossorigin', 'anonymous'); // works for me img.src = src; return img; }
Et dans votre rappel, vous pouvez maintenant l'utiliser
ctx.drawImage
et l'exporter en utilisanttoDataURL
la source
Tainted canvases may not be exported.
message d'erreur.Dans mon cas, je dessinais sur une étiquette de toile à partir d'une vidéo. Pour résoudre l'erreur de toile contaminée, j'ai dû faire deux choses:
<video id="video_source" crossorigin="anonymous"> <source src="http://crossdomain.example.com/myfile.mp4"> </video>
la source
J'ai résolu le problème en utilisant l'
useCORS: true
optionhtml2canvas(document.getElementsByClassName("droppable-area")[0], { useCORS:true}).then(function (canvas){ var imgBase64 = canvas.toDataURL(); // console.log("imgBase64:", imgBase64); var imgURL = "data:image/" + imgBase64; var triggerDownload = $("<a>").attr("href", imgURL).attr("download", "layout_"+new Date().getTime()+".jpeg").appendTo("body"); triggerDownload[0].click(); triggerDownload.remove(); });
la source
On dirait que vous utilisez une image à partir d'une URL qui n'a pas défini l'en-tête correct Access-Control-Allow-Origin et donc le problème .. Vous pouvez récupérer cette image sur votre serveur et l'obtenir sur votre serveur pour éviter les problèmes CORS.
la source
Découvrez [Image activée CORS] [1] de MDN. Fondamentalement, vous devez avoir un serveur hébergeant des images avec l'en-tête Access-Control-Allow-Origin approprié.
<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>
Vous pourrez enregistrer ces images sur le stockage DOM comme si elles étaient servies à partir de votre domaine, sinon vous rencontrerez un problème de sécurité.
var img = new Image, canvas = document.createElement("canvas"), ctx = canvas.getContext("2d"), src = "https://www.google.com/images/branding/googlelogo/1x/googlelogo_color_272x92dp.png"; // insert image url here img.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 too if ( img.complete || img.complete === undefined ) { img.src = ""; img.src = src; }
la source
Juste comme une construction sur la réponse de @ markE - si vous voulez créer un serveur local. Vous n'aurez pas cette erreur sur un serveur local.
Si PHP est installé sur votre ordinateur:
php -S localhost:3000
← Notez le 'S' majusculeou
Si Node.js est installé sur votre ordinateur:
npm init -y
npm install live-server -g
ousudo npm install live-server -g
sur un Maclive-server
et il devrait automatiquement ouvrir un nouvel onglet dans le navigateur avec votre site Web ouvert.Remarque: n'oubliez pas d'avoir un fichier index.html à la racine de votre dossier, sinon vous pourriez avoir des problèmes.
la source
J'ai également résolu cette erreur en ajoutant
useCORS : true,
dans mon code comme -html2canvas($("#chart-section")[0], { useCORS : true, allowTaint : true, scale : 0.98, dpi : 500, width: 1400, height: 900 }).then();
la source