我正在从数据库中检索Blob图像,我希望能够使用JavaScript查看该图像。以下代码在页面上生成一个损坏的图像图标:
var image = document.createElement('image');
image.src = 'data:image/bmp;base64,'+Base64.encode(blob);
document.body.appendChild(image);
Here is a jsFiddle包含所需的所有代码,包括blob。完成的代码应正确显示图像。
答案 0 :(得分:72)
您也可以直接从XMLHttpRequest获取BLOB对象。将responseType设置为blob就可以了。这是我的代码:
var xhr = new XMLHttpRequest();
xhr.open("GET", "http://localhost/image.jpg");
xhr.responseType = "blob";
xhr.onload = response;
xhr.send();
响应函数如下所示:
function response(e) {
var urlCreator = window.URL || window.webkitURL;
var imageUrl = urlCreator.createObjectURL(this.response);
document.querySelector("#image").src = imageUrl;
}
我们只需要在HTML中创建一个空的图像元素:
<img id="image"/>
答案 1 :(得分:32)
如果你想改用fetch:
var myImage = document.querySelector('img');
fetch('flowers.jpg').then(function(response) {
return response.blob();
}).then(function(myBlob) {
var objectURL = URL.createObjectURL(myBlob);
myImage.src = objectURL;
});
来源:
https://developer.mozilla.org/en-US/docs/Web/API/Fetch_API/Using_Fetch
答案 2 :(得分:10)
在您的示例中,您应该createElement('img')
。
在您的链接中base64blob != Base64.encode(blob)
。
只要您的数据有效http://jsfiddle.net/SXFwP/(我没有任何BMP图片,因此我必须使用PNG),这是有效的。
答案 3 :(得分:8)
您可以将字符串转换为Uint8Array以获取原始数据。然后为该数据创建Blob并传递给URL.createObjectURL(blob),将Blob转换为您传递给img.src的网址。
var data = '424D5E070000000000003E00000028000000EF...';
// Convert the string to bytes
var bytes = new Uint8Array(data.length / 2);
for (var i = 0; i < data.length; i += 2) {
bytes[i / 2] = parseInt(data.substring(i, i + 2), /* base = */ 16);
}
// Make a Blob from the bytes
var blob = new Blob([bytes], {type: 'image/bmp'});
// Use createObjectURL to make a URL for the blob
var image = new Image();
image.src = URL.createObjectURL(blob);
document.body.appendChild(image);
您可以尝试以下完整示例:http://jsfiddle.net/nj82y73d/
答案 4 :(得分:2)
我猜你的图片的内嵌代码有错误。 试试这个:
var image = document.createElement('img');
image.src="";
image.width=100;
image.height=100;
image.alt="here should be some image";
document.body.appendChild(image);
答案 5 :(得分:2)
问题是我有十六进制数据需要在被base64编码之前转换为二进制数据。
PHP中的:
base64_encode(pack("H*", $subvalue))
答案 6 :(得分:0)
在小提琴中,您的Blob不是Blob,而是十六进制数据的字符串表示形式。 尝试一下,然后完成
var image = document.createElement('img');
let reader=new FileReader()
reader.addEventListener('loadend',()=>{
let contents=reader.result
image.src = contents
document.body.appendChild(image);
})
if(blob instanceof Blob) reader.readAsDataURL(blob)
readAsDataURL为您提供了一个base64编码的图像,可用于您的图像元素()源(src)