有没有办法强制在 ff 中为 www.example.com/example.pdf 保存为对话框?(我无法更改标题)
2 回答
如果您可以将文件以 base64 格式输出到客户端,则可以使用 data 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 类型
查看图片(预览缩短的 url)——mime 类型:image/png
下载图片(预览缩短的 url)——mime 类型:application/octet-stream
你问你用什么代替了appendPDFContentHere,答案是构成 PDF 的 base64 编码字节。我使用这个在线base64 编码器对示例中使用的图像进行编码。
我能想到的唯一其他方法是修改 Firefox 设置。我假设你不能这样做。
编辑:
我根据数据 URI 的想法拼凑了一个客户端解决方案。它使用base64 编码器的修改版本和二进制 XMLHTTPrequests技术 脚本下载 PDF 文件,然后使用 base64 编码器动态生成和放置数据 URI 链接。
当您想要八位字节流编码但无权访问服务器时(对于 OP 来说似乎就是这种情况),它应该很有用。
请注意,我刚刚发布了一个使用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>';
}