我将包含以下代码的php文件的位置作为参数传递给viewer.html
文件,它被正确显示,但是当单击pdf查看器中的下载按钮时,文档名称始终是document.pdf
。这带来了一个问题,因为有多少移动用户将下载文件,只是发现他们所有的文件都有名称document.pdf
,他们(对于大多数移动浏览器)不能在下载前更改文件名。
我是否必须传递一些任意参数到文件或重定向到附加文件名的self ?
<?php
$content = "a binary representation of my pdf";
header("Content-type: application/pdf");
header('Content-Transfer-Encoding: binary');
header('Content-Disposition: attachment; filename="someFile.pdf"');
echo $content;
?>
我也遇到过同样的问题。来自pdf.js的viewer.js源代码:
function getPDFFileNameFromURL(url) {
var reURI = /^(?:([^:]+:)?'/'/[^'/]+)?([^?#]*)('?[^#]*)?(#.*)?$/;
// SCHEME HOST 1.PATH 2.QUERY 3.REF
// Pattern to get last matching NAME.pdf
var reFilename = /[^'/?#=]+'.pdf'b(?!.*'.pdf'b)/i;
var splitURI = reURI.exec(url);
var suggestedFilename = reFilename.exec(splitURI[1]) ||
reFilename.exec(splitURI[2]) ||
reFilename.exec(splitURI[3]);
if (suggestedFilename) {
suggestedFilename = suggestedFilename[0];
if (suggestedFilename.indexOf('%') != -1) {
// URL-encoded %2Fpath%2Fto%2Ffile.pdf should be file.pdf
try {
suggestedFilename =
reFilename.exec(decodeURIComponent(suggestedFilename))[0];
} catch(e) { // Possible (extremely rare) errors:
// URIError "Malformed URI", e.g. for "%AA.pdf"
// TypeError "null has no properties", e.g. for "%2F.pdf"
}
}
}
return suggestedFilename || 'document.pdf';
}
所以魔术需要通过reURI
regexp来自URL。
你需要做的是:
http://domain.com/path/to/Named.pdf
http://domain.com/path/to/your/api?fileId=123&saveName=Named.pdf
由于上面的regexp代码,这些都将导致保存为Named.pdf
的文件名。
基于评论
你可以在任何你使用viewer.js文件的地方添加这个。
setTimeout(() => {
// Wait for PDFViewerApplication object to exist
PDFViewerApplication.setTitleUsingUrl('custom-file.pdf');
}, 10);
那么当你下载PDF文件的时候它的文件名就会是