Dav*_*tti 3 pdf node.js google-cloud-print unirest
我想发送一个使用Google Cloud Print API打印的PDF文件。下面的代码将给我一个积极的信息,告诉我已生成一页。当我去检查结果时,我在空白页上打上了门。
如果我将打印内容保存在Google云端硬盘中,也会发生相同的结果。
unirest.post('https://www.google.com/cloudprint/submit')
.header('Authorization', 'Bearer ' + token)
.header("Accept-Charset", "utf-8")
.field('xsrf', xsrf_token)
.field('printerid', printerId)
.field('ticket', '{"version": "1.0", "print": {}}')
.field('title', 'Test from Simpe.li')
.field('contentType', 'application/pdf')
.attach('content', buffer)
.end(function (res) {
console.log(res);
});
Run Code Online (Sandbox Code Playgroud)
我知道我要发送的是PDF,因为当我更改
.field('contentType', 'application/pdf')
Run Code Online (Sandbox Code Playgroud)
至
.field('contentType', 'text/plain')
Run Code Online (Sandbox Code Playgroud)
我将获得53页文本,这是PDF文件的原始内容。
我做错了什么?
事实证明,Google文档遗漏了一些关键信息。要发送二进制类型的数据(例如PDF),您需要将文件转换为base64。除此之外,您还需要告知Google您将向其发送一个带有add字段的base64 blob,contentTransferEncoding并将其值设置为base64。
另一个重要的事情。Unirest(至少针对NodeJS)存在一个错误,即发送base64文件不会设置Content-Size标头。甚至自己设置也无法解决问题。为了避免这个问题,我不得不切换到Request。以下代码显示了有效的Google Cloud Print帖子:
let buffer64 = buffer.toString('base64');
let formData = {
xsrf: xsrf_token,
printerid: printerId,
ticket: '{"version": "1.0"}',
title: 'Test Print',
contentTransferEncoding: 'base64',
contentType: 'application/pdf',
content: buffer64
};
let headersData = {
'Authorization': 'Bearer ' + token
};
request.post({
url: 'https://www.google.com/cloudprint/submit',
headers: headersData,
formData: formData
}, function (err, httpResponse, body) {
if (err) {
return console.error('upload failed:', err);
}
console.log('Upload successful! Server responded with:', body);
});
Run Code Online (Sandbox Code Playgroud)
我希望这会帮助其他人:)