How to convert image to base64?

I found this code:
getBase64Image function(img) { 
 var canvas = document.createElement("canvas"); 
 canvas.width = img.width; 
 canvas.height = img.height;

 var ctx = canvas.getContext("2d"); 
 ctx.drawImage(img, 0, 0);
 var dataURL = canvas.toDataURL("image/png"); 

 return dataURL.replace(/^data:image\/(png|jpg);base64,/, ""); 
}

But when running error:
VM2785:8 Uncaught DOMException: Failed to execute 'toDataURL' on 'HTMLCanvasElement': Tainted canvases may not be exported.
 at Error (native)
 at getBase64Image (<anonymous>:8:26)
 at <anonymous>:1:1
 at Object.InjectedScript._evaluateOn (<anonymous>:145:167)
 at Object.InjectedScript._evaluateAndWrap (<anonymous>:137:25)
 at Object.InjectedScript.evaluate (<anonymous>:118:14)getBase64Image @ VM2785:8(anonymous function) @ VM3093:1InjectedScript._evaluateOn @ VM3078:145InjectedScript._evaluateAndWrap @ VM3078:137InjectedScript.evaluate @ VM3078:118</anonymous></anonymous></anonymous></anonymous></anonymous>
July 8th 19 at 16:40
3 answers
July 8th 19 at 16:42
Solution
Turned out to be need to register by adding crossorigin="anonymous", but this attribute must be defined in the img once, but not with js
July 8th 19 at 16:44
Solution
I did so: for (var i = 0; i < document.getElementsByTagName('img').length; i++) {
document.getElementsByTagName('img')[i].setAttribute("by adding crossorigin", "anonymous");
}
But it's still not working. - Nikita20 commented on July 8th 19 at 16:47
July 8th 19 at 16:46
If your task does not require writing JavaScript code, you can use Notepad++

- drag the image into the program:
046e6441c1194b45a7b4650438f8ae55.png
- Edit --> Select All or (Ctrl+A)
- then: Plugins -- > -- MIME Tools> Base64 Encode
bc82f841fb7c427f8c1d4c1981b681b7.png
- as a result of the image code looks like this:
9a80ee1a0a8548a48d73d07c4e917f1d.png
- add
<img src=" Here pictures">
to the previous code.
the result:
<img src="">
and if you take dynamically ? ie it is necessary to encrypt the image from db - eat you have an example ? - Nikita20 commented on July 8th 19 at 16:49
Yes, you can. Rarely do it when we need an approach https://habrahabr.ru/post/46466/ - Sasha.Gorczany commented on July 8th 19 at 16:52
I need to get a captcha VC, had to replace the function you used to create the image and add the attribute by adding crossorigin="anonymous". Now it works, captcha razvalivaetsya! - Precious commented on July 8th 19 at 16:55

Find more questions by tags JavaScript