は、私は、DocuSignのから署名された文書を取得しようとDocuSignのノードSDKを使用して、このコードを使用しています、正常にログインしたので、封筒から文書のリストを持っている:Docusign Node SDKでenvelopesApi.getDocumentを呼び出すとき、どの形式でデータが返されますか?どのようにファイルに書き込むのですか?
envelopesApi.getDocument(accountId, envelopeId, documents[0].documentId, function(err, data, response) {
log.info({data: data.substring(0, 100)}, 'getDocument data');
log.info({response}, 'getDocument response');
fs.writeFile('/home/martin/downloaded.pdf', data, (err) => {
next(err);
});
});
data
変数であります文字列。これはbase64でエンコードされていません。
%PDF-1.4
%ûüýþ
4 0 obj
<<
/Parent 3 0 R
/Resources 5 0 R
/MediaBox [0.00000 0.00000 595.00000 842.00
ので、私はそれがbase64エンコードではないことがわかります(バニヤンログインモジュールを使用して)最初のログステートメントは、文字列がこれらの文字で始まることを示しています。 pdfファイルの内容を文字列で保持することは私にとっては奇妙なことです。私はBuffer
オブジェクトを期待していました。
このコードが保存したファイルを開くと(Chromeで)、有効なPDFファイル(Chromeにファイルが破損しているとエラーが表示されない)が表示され、適切なページ数になりますそれは完全に判読不能です。ページには読みやすいテキストがありません。何かが壊れていることを示しています。文字列に追加読めるストリーム&から読んように見える -
私はそれがPDFを要求していることがわかります、そしてそれは、特にPDFファイルを扱うためのApiClientでコードがあるSDKからEnvelopesApi.jsとApiClient.jsファイルを見ます。
NODE SDKを使用しないで、代わりにREST APIを直接使用することをお勧めします(公式REST API Recipe: Getting an Envelope's Document Listの例を参照)。可能であればSDKを使用したいと思います。
このdata
パラメータで何かすべきことがありませんか?