有没有办法在ff中强制保存为www.example.com/example.pdf的对话框? (我无法更改标题)
答案 0 :(得分:4)
如果您可以在base64中将文件输出到客户端,则可以使用数据uris进行下载。
location.href = 'data:application/octet-stream;base64,' + appendPDFContentHere
OR
<a href="data:application/octet-stream;base64,appendPDFContentHere">pdf</a>
这只适用于非IE浏览器,但是正如您对firefox所要求的那样,这应该可以很好地工作。
编辑:
下面的两个例子都包含制作PNG的字节数。如果单击第一个,则可以像在浏览器中一样查看图像。但是,如果单击第二个链接,将强制您下载图像。将其保存为.png,您将看到它们是完全相同的图像。两个链接的唯一区别是mime类型
view image(preview shortened url) - mime类型:image / png
download image(preview shortened url) - mime类型:application / octet-stream
您询问了代替 appendPDFContentHere 的内容,答案是构成PDF的base64编码字节。我使用此在线base64 encoder对示例中使用的图像进行编码。
答案 1 :(得分:2)
我能想到的另一种方法是修改Firefox设置。我假设你不能这样做。
编辑:
我拼凑了一个基于数据URI思想的客户端解决方案。它使用了 base64 encoder的修改版本和技术 binary XMLHTTPrequests脚本下载PDF文件,然后使用base64编码器动态生成并放置数据URI链接。
当您需要八位字节流编码但无法访问服务器时(如OP的情况),它应该很有用。
注意,我刚刚使用an example发布了hunts.pdf,OP正在测试。
/**
*
* Base64 encode / decode
* http://www.webtoolkit.info/
*
**/
var Base64 = {
// private property
_keyStr : "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",
// public method for encoding
encode : function (input) {
var output = "";
var chr1, chr2, chr2raw, chr3, chr3raw, enc1, enc2, enc3, enc4;
var i = 0;
//input = Base64._utf8_encode(input);
while (i < input.length) {
chr1 = input.charCodeAt(i++) & 0xFF;
chr2 = isNaN(chr2raw = input.charCodeAt(i++)) ? NaN : (chr2raw & 0xFF);
chr3 = isNaN(chr3raw = input.charCodeAt(i++)) ? NaN : (chr3raw & 0xFF);
enc1 = chr1 >> 2;
enc2 = ((chr1 & 3) << 4) | (chr2 >> 4);
enc3 = ((chr2 & 15) << 2) | (chr3 >> 6);
enc4 = chr3 & 63;
if (isNaN(chr2)) {
enc3 = enc4 = 64;
} else if (isNaN(chr3)) {
enc4 = 64;
}
output = output +
this._keyStr.charAt(enc1) + this._keyStr.charAt(enc2) +
this._keyStr.charAt(enc3) + this._keyStr.charAt(enc4);
}
return output;
}
}
// http://web.archive.org/web/20071103070418/mgran.blogspot.com/2006/08/downloading-binary-streams-with.html
//fetches BINARY FILES synchronously using XMLHttpRequest
load_url = function(url) {
var req = new XMLHttpRequest();
req.open('GET',url,false);
//XHR binary charset opt by Marcus Granado 2006 [http://mgran.blogspot.com]
req.overrideMimeType('text/plain; charset=x-user-defined');
req.send(null);
if (req.status != 200){
alert(req.status);
return '';
}
return req.responseText;
}
function getDataURI(filename)
{
var file = load_url(filename);
var uueFile = Base64.encode(file);
var uri = 'data:application/octet-stream;base64,' + encodeURIComponent(uueFile);
return uri;
}
window.addEventListener("load",
function()
{
var link = getDataURI("foo.pdf");
document.getElementById("myDiv").innerHTML += '<a href="' + link + '"><code>' + link + '</code></a><br><br>';
}