gpt4 book ai didi

javascript - 如何在javascript中使用pdf的字节数组在浏览器中显示pdf?

转载 作者:行者123 更新时间:2023-11-29 23:07:00 26 4
gpt4 key购买 nike

我有一个 Controller ,它发送响应实体作为对 ajax 调用的响应,它是 pdf 的字节数组形式。现在我想在浏览器中显示,但没有任何效果。我尝试了旧 stackoverlow 问题的所有建议,但没有任何效果。

这是我从 spring controller 得到的回复

     `  %PDF-1.4
%����
6 0 obj
<</Filter/FlateDecode/Length 1983>>stream
x�� .......... [snip rest of the output]`

这是我的ajax代码

 $(".form").submit(function(e) {
var form = $(this);
var url = _contextPath + "pdf/" + id;
$.ajax({
type: "GET",
url: url,
data: form.serialize(),
datatype: "application/pdf",
success: function(data, textStatus, jqXHR)
{
console.log(data);
let pdfWindow = window.open("");
var bb = btoa(encodeURIComponent((data.replace(/[\u00A0-\u2666]/g, function(c) {
return '&#' + c.charCodeAt(0) + ';';
}))));
console.log(bb);
var file = new Blob([bb], {type:'application/pdf'});
console.log(file);
var fileUrl = URL.createObjectURL(file);
pdfWindow.document.write("<iframe width='100%' height='100%' src= '"+file+"'></iframe>");
/*var pdfData = btoa(unescape(encodeURIComponent(data)));
console.log(pdfData);
var pdfDataa = atob(pdfData);
console.log(pdfDataa);*/
/* var bb = btoa(encodeURIComponent((data.replace(/[\u00A0-\u2666]/g, function(c) {
return '&#' + c.charCodeAt(0) + ';';
}))));
console.log(bb);
var file = new Blob([bb], {type:'application/pdf'});
var fileUrl = URL.createObjectURL(file);
window.open(fileUrl,'', 'height=650,width=840');*/
//console.log(data);
// window.open("data:application/pdf;base64, " + data, '', 'height=650,width=840');
/*var blob = new Blob( [data], { type: "application/pdf" });
var fileURL = URL.createObjectURL(blob);
var win = window.open();
win.document.write('<iframe src="' + fileURL + '" frameborder="0"' +
' style="border:0; top:0px; left:0px; bottom:0px;' +
' right:0px; width:100%; height:100%;" allowfullscreen></iframe>')*/
/* var datauri = 'data:application/pdf;base64,' + Base64.encode(data);
var win = window.open();
win.document.write('<iframe src="' + datauri + '" frameborder="0"' +
' style="border:0; top:0px; left:0px; bottom:0px;' +
' right:0px; width:100%; height:100%;" allowfullscreen></iframe>');*/
//var base64EncodedStr = btoa(unescape(encodeURIComponent(data)));
//window.open(data,"_blank","scrollbars=yes,resizable=yes");
//window.open("data:application/pdf," + encodeURI(data));
// window.open("data:application/pdf," + escape(data));
//window.open("data:application/pdf," + base64EncodedStr);
// window.open("data:application/octet-stream;charset=utf-16le;base64,"+base64EncodedStr);

// let pdfWindow = window.open("")
// pdfWindow.document.write("<iframe width='100%' height='100%' src='data:application/pdf;base64, "
// + blob+"'></iframe>");
/* const byteArray = data;
const blob = new Blob([byteArray], {type: 'application/pdf'});
const blobURL = URL.createObjectURL(blob);
var win = window.open();
win.document.write('<iframe src="' + blobURL + '" frameborder="0"' +
' style="border:0; top:0px; left:0px; bottom:0px;' +
' right:0px; width:100%; height:100%;" allowfullscreen></iframe>');*/
/* var len = data.length;
var buffer = new ArrayBuffer(len);
var view = new Uint8Array(buffer);
for (var i = 0; i < len; i++) {
view[i] = binary.charCodeAt(i);
}
*/
/*var base64EncodedStr = btoa(unescape(encodeURIComponent(data.toString())));
var pdfData = base64EncodedStr;

var x = window.open();
var iframe = x.document.createElement('iframe')
iframe.width = '100%'
iframe.height = '100%'
iframe.frameBorder = 0
iframe.style = "border: 0"
iframe.src = "data:application/pdf;base64, " + pdfData
x.document.body.appendChild(iframe);*/
// $('.form').unbind('submit').submit();

}
});
e.preventDefault();
});

我什么都试过了,但还是不行

最佳答案

在这里找到了解决方案,我从 spring Controller 发送字节数组,格式如 %PDF-1 %����。所以我从 spring Controller 发送 base64 编码的字符串并将 base64 编码的字符串发送到浏览器并且它有效。

javascript 代码:

var arrrayBuffer = base64ToArrayBuffer(data); //data is the base64 encoded string
function base64ToArrayBuffer(base64) {
var binaryString = window.atob(base64);
var binaryLen = binaryString.length;
var bytes = new Uint8Array(binaryLen);
for (var i = 0; i < binaryLen; i++) {
var ascii = binaryString.charCodeAt(i);
bytes[i] = ascii;
}
return bytes;
}
var blob = new Blob([arrrayBuffer], {type: "application/pdf"});
var link = window.URL.createObjectURL(blob);
window.open(link,'', 'height=650,width=840');

在 spring Controller 中将字节数组转换为 base64 编码的字符串

String encodedString = Base64.getEncoder().encodeToString(bytearrayofpdf);

关于javascript - 如何在javascript中使用pdf的字节数组在浏览器中显示pdf?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54567948/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com