我从画布获得base64编码的图像:
var dataURL = canvas.toDataURL( "image/png" );
Run Code Online (Sandbox Code Playgroud)
然后我把它变成这样的数据:
//Remove the beginning identifier and use Chrome/Firefox?safari built int base64Decoder
var data = atob( dataURL.substring( "data:image/png;base64,".length ) );
Run Code Online (Sandbox Code Playgroud)
然后我通过以下方式将其写入文件系统:
event.createWriter(
function(writerEvent)
{
//The success handler
writerEvent.onwriteend = function(finishEvent)
{
...
};
//Error handler
writerEvent.onerror = settings.error;
// Create a new Blob
var blob = new Blob( [ data ], { type: "image/png" } );
//Write it into the path
writerEvent.write( blob );
}
}
Run Code Online (Sandbox Code Playgroud)
我尝试将其设置为图像的src,如下所示:
document.getElementById( "saved" ).src = event.toURL();
Run Code Online (Sandbox Code Playgroud)
这写了文件,我能够找到它并获得一个网址(通过阅读和使用事件:event.toURL() …
我有一个Data:URL(参见:http://en.wikipedia.org/wiki/Data_URI_scheme)(作为NSString),我想在Safari中打开它.你将如何实现这一点(我试过openURL:.)
示例:
data:text/html;base64,(Some Base64 Encoded Data Here)
Run Code Online (Sandbox Code Playgroud) 我有一个画布,我使用以下代码上传图像:
function handleImage(e){
var reader = new FileReader();
reader.onload = function(event){
var img = new Image();
img.onload = function(){
canvas.width = img.width;
canvas.height = img.height;
ctx.drawImage(img,0,0);
}
img.src = event.target.result;
}
reader.readAsDataURL(e.target.files[0]);
}
Run Code Online (Sandbox Code Playgroud)
现在我想使用canvas.toDataURL()它将图像加载到另一个画布.代码是:
var dataURL = canvas.toDataURL();
drawDataURIOnCanvas(dataURL,canvas2);
function drawDataURIOnCanvas(dataURL, name_of_canvas) {
var myCanvas = document.getElementById(name_of_canvas);
var img3 = new Image;
var ctx2 = myCanvas .getContext('2d');
img3.onload = function(){
ctx2.drawImage(img3,0,0); // Or at whatever offset you like
};
img3.src = dataURL;
}
Run Code Online (Sandbox Code Playgroud)
如果我把这个工作网址都搞好了.但是我试过的任何图片中产生的网址都是以
数据:图像/ PNG; BASE64,iVBORw0KGgoAAAANSUhEUgAAASwAAACWCAYAAABkW7XSAAAAxUlEQVR4nO3BMQEAAADCoPVPbQhfoAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAOA1v9QAATX68/0AAAAASUVORK5CYII =. …
我想在javascript中生成一系列MIDI音符,然后播放它.许多插件支持MIDI,但我不知道任何支持"data:"URL.生成MIDI内容并不是什么大问题 - 但是将这些内容提供给播放器就是.任何人都知道如何做到这一点 - 如果不是一般,那么至少对于像QuickTime这样的特定插件?
我需要用Python/Django创建一个Code128条形码,它必须嵌入HTML文档中.
我不想在磁盘上制作任何临时(或缓存)文件.这就是我想将它们嵌入数据URI方案的原因.
结果必须是这样的:
<img src="
AAAFCAYAAACNbyblAAAAHElEQVQI12P4//8/w38GIAXDIBKE0DHxgljNBAAO
9TXL0Y4OHwAAAABJRU5ErkJggg==" alt="Red dot">
Run Code Online (Sandbox Code Playgroud)
你能推荐我一个简单的方法吗?
现在我使用ReportLab创建这样的条形码并将它们嵌入到PDF文件中,但我不知道如何将它们导出为数据URI方案.如果这是建议的方法.
我正在考虑data-url在我的mongoDB中存储s 而不是存储对文件的引用或使用GridFS.
数据网址:

Run Code Online (Sandbox Code Playgroud)
我存储的所有文件都是JPG或PNG,大小不到1MB.
我想知道这是否被认为是不好的做法,以及读取和写入操作的性能影响,将data-urls 1)存储在单独的集合中2)作为集合中的元数据.
我对小文件存储的任何其他建议持开放态度.
我有以下数据

Run Code Online (Sandbox Code Playgroud)
有没有办法在imageview中加载dataUrl?
我希望能够输出包含图像的HTML文件(在文件本身内).通过谷歌搜索,我遇到了几种方法:
javascript:imageData<IMG SRC="data:image/gif;base64,[...]"><object ... > tag(虽然这使用了数据URI,因此可能会继承相同的限制)但我不知道浏览器支持哪个更好,或者有其他替代方案.
任何有实际经验的人能为我提供建议吗?谢谢.
我试图从画布中获取dataUrl以使用在各种元素上作为css background-image.但我总是得到以下错误Uncaught TypeError: Object #<HTMLCanvasElement> has no method 'toDataUrl'
这是我的测试代码
<!DOCTYPE html>
<html>
<body>
<canvas id="myCanvas" width="200" height="100" style="border:1px solid #c3c3c3;">
Your browser does not support the canvas element.
</canvas>
<script type="text/javascript">
var c=document.getElementById("myCanvas");
var ctx=c.getContext("2d");
ctx.fillStyle="#FF0000";
ctx.fillRect(0,0,150,75);
alert(c.toDataUrl());
</script>
</body>
</html>
Run Code Online (Sandbox Code Playgroud)
又是伪装的安全功能吗?或者我只是愚蠢......
提前致谢
我正在开发一个 angular 4 应用程序。我有一个 base64 编码的图像。我用 node.js 将它保存在文件系统中。
if (body.profilepic != "") {
let base64Data = body.profilepic.split(';base64,').pop();
fs.writeFile("out.png", base64Data, 'base64', function(err) {
if (!err) {
console.log("saved file")
}
});
}
Run Code Online (Sandbox Code Playgroud)
问题是我无法检测到我正在保存的图像的文件类型。现在它只保存 png。
如何检测我收到的图像字符串的文件类型?
我得到的 base64 编码字符串是这样的:

Run Code Online (Sandbox Code Playgroud)