aki*_*ara 4 encryption cryptojs pdf.js
我正在开发一个项目,所有pdf文件都在Web Server上加密.
使用XMLHttpRequest,我获得加密的pdf文件的内容.然后使用JavaScript工具解密文件.毕竟将文件内容作为decrypted_file分配给javascript变量.所有这些都是在客户端完成的.
这是我想要做的;
pdf.js呈现和查看位于Web服务器或同一目录库中的pdf文件.
我怎么能处理pdf.js从javascript变量而不是url获取内容为"http // yourdomain.com/first-test.pdf或文件为"first-test.pdf"?
欢迎任何答案,谢谢.
假设您使用的是PDF.js的viewer.html,从数据中打开PDF文件就像PDFViewerApplication.open使用正确的参数调用一样简单.
// in viewer.html
var data = new Uint8Array( /* ... data ... */ );
PDFViewerApplication.open(data);
Run Code Online (Sandbox Code Playgroud)
// in viewer.html
var data = new Blob([ '%PDF....'] , {type: 'application/pdf'});
var url = URL.createObjectURL(data);
PDFViewerApplication.open(url);
Run Code Online (Sandbox Code Playgroud)
var url = 'data:application/pdf;base64,....';
PDFViewerApplication.open(url);
Run Code Online (Sandbox Code Playgroud)
这包括两个步骤:解码base64数据URL,然后将二进制字符串转换为Uint8Array.
var url = 'data:application/pdf;base64,....';
var data = url.split(';base64,')[1];
// Decode base64
var binaryString = atob(data);
// Convert binary string to Uint8Array
data = new Uint8Array(binaryString.length);
for (var i = 0, ii = binaryString.length; i < ii; ++i) {
data[i] = binaryString.charCodeAt(i);
}
PDFViewerApplication.open(data);
Run Code Online (Sandbox Code Playgroud)
<iframe src="viewer.html" id="pdfjsframe"></iframe>
<script>
var pdfjsframe = document.getElementById('pdfjsframe');
// At the very least, wait until the frame is ready, e.g via onload.
pdfjsframe.onload = function() {
var data = ... data here or elsewhere ... ;
pdfjsframe.contentWindow.PDFViewerApplication.open(data);
};
</script>
Run Code Online (Sandbox Code Playgroud)