在我正在处理的Google Chrome扩展中,一个文件是从具有
XMLHttpRequest的服务器下载的.该文件包含存储在ArrayBuffer对象中的一些二进制数据.为了提供下载此文件的可能性,我使用的是createObjectURL API.
function publish(data) {
if (!window.BlobBuilder && window.WebKitBlobBuilder) {
window.BlobBuilder = window.WebKitBlobBuilder;
}
var builder = new BlobBuilder();
builder.append(data);
var blob = builder.getBlob();
var url = window.webkitURL.createObjectURL(blob);
$("#output").append($("<a/>").attr({href: url}).append("Download"));
}
工作正常除了文件名是不透明的UUID,像9a8f6a0f-dd0c-4715-85dc-7379db9ce142.有没有什么办法强制这个文件名到更友好的用户?
解决方法
我以前从来没有尝试过,但是应该可以创建一个新的File对象(它允许你指定一个文件名),并将blob写入它.沿着以下方向的东西:
function publish(data,filename) {
if (!window.BlobBuilder && window.WebKitBlobBuilder) {
window.BlobBuilder = window.WebKitBlobBuilder;
}
fs.root.getFile(filename,{
create: true
},function (fileEntry) {
// Create a FileWriter object for our FileEntry (log.txt).
fileEntry.createWriter(function (fileWriter) {
fileWriter.onwriteend = function (e) {
console.log('Write completed.');
};
fileWriter.onerror = function (e) {
console.log('Write Failed: ' + e.toString());
};
var builder = new BlobBuilder();
builder.append(data);
var blob = builder.getBlob();
fileWriter.write(blob);
},errorHandler);
},errorHandler);
}
我认为这可能适合你.