You need to sign in to do that
Don't have an account?
prasanth sfdc
HTTP repose converting attachment showing blank PDF pages.
I am trying to get the data PDF file from REST API, while storing it into the attachment object as PDF it is showing the empty PDF pages, kidnly help me to solve this issue.
Note:- Encodeutil decode and encode not wokring while attachment creating converting the response,getBody() into attachment.
Note:- Encodeutil decode and encode not wokring while attachment creating converting the response,getBody() into attachment.
string url = AWSUtility.viewS3Object('a1h0n00000187sc'); system.debug('The url is:' + url); Http http = new Http(); HttpRequest request = new HttpRequest(); request.setEndpoint(url); request.setMethod('GET'); request.setHeader('Content-Type', 'application/pdf'); request.setHeader('Content-Encoding', 'UTF-8'); //req.setHeader('Content-Disposition', 'attachment; filename=' + fileName); //req.setHeader('Connection', 'keep-alive'); HttpResponse response = http.send(request); system.debug('The response is :' +response.getBody()); attachment att = new attachment(); att.parentId = 'a1h2g000000I1IN'; att.Name = 'Testing Raja2.pdf'; att.contentType = 'application/pdf'; att.body = blob.valueof(response.getBody()); //att.body = EncodingUtil.Base64Decode(response.getBody()); //att.body = EncodingUtil.base64Decode(response.getBody()); //att.body = EncodingUtil.base64Decode(blob.valueof(response.getBody())); //att.body = EncodingUtil.base64Encode(blob.valueof(response.getBody())); insert att; (// attachment is getting created but, all empty pages only).
It took me many hours to figure this out. Its important to understand why blob.valueof(response.getBody()) did not work and response.getbodyasblob() works.
When using this
response.getBody() is getting the body from the response in String format. the PDF file gets corrupted here itself. We the use blob.valueof() to convert the String to Blob for saving as contentversion.attachment.
this methods retrieves the body from response directly as Blob. So no conversion takes place and pdf file is intact.
Why EncodingUtil.Base64Decode(response.getBody()) does not work here is because the response from the API is not a Base64 string. If you actually check the response you will find strange characters. Base64 only supports these characters:
Uppercase letters (indices 0-25): ABCDEFGHIJKLMNOPQRSTUVWXYZ
Lowercase letters (indices 26-51): abcdefghijklmnopqrstuvwxyz
Digits (indices 52-61): 0123456789
Special symbols (indices 62-63): +/
So trying to using EncodingUtil.Base64Decode(response.getBody()) with our response will give error of invalid characters. If you dig deeper and check the response received using System.debug(response.getBody()) you will realize that it is actually a PDF file format (the PDF specification for creating pdf files here (https://resources.infosecinstitute.com/topic/pdf-file-format-basic-structure/)). So we do not have to decode or uncompress the response in any way. We have to just retrieve the file as it is (as a blob) and save it to salesforce.
Example of (response.getBody()) you will see for these api responses which return PDF files.
%PDF-1.4
%����
2 0 obj
<</ColorSpace/DeviceRGB/Subtype/Image/Height 200/Filter/FlateDecode/Type/XObject/DecodeParms<</Columns 420/Colors 3/Predictor 15/BitsPerComponent 8>>/Width 420/Length 6827/BitsPerComponent 8>>stream
x�� |���gfw�MBr�r�p1Ax)X�QZ,�*Z����h��`�XĖ��Z���)��A���A�=f�'��
�3��N�e��}?���d���;��3��
�����Bv� ;����
Below is Apex class code
------------------------------------------
Http h = new Http();
HttpRequest req = new HttpRequest();
req.setEndpoint(docUrlEndpoint);
req.setMethod('GET');
req.setHeader('Authorization', 'Bearer '+token);
req.setHeader('responseType', 'arraybuffer');
req.setHeader('Content-Type','application/octet-stream');
HttpResponse res = h.send(req);
if(res.getStatusCode()==200){
Blob pdfContent = res.getBodyAsBlob();
return EncodingUtil.base64Encode(pdfContent);
}
Below is Aura component JS code
------------------------------------------------
if(blobData!=null){
var arrBuffer = this.base64ToArrayBuffer(blobData);
let newFile = new Blob([arrBuffer], {type: "application/pdf"});
const link = document.createElement("a");
link.style.display = "none";
link.href = URL.createObjectURL(newFile);
link.download = "abc.pdf";
document.body.appendChild(link);
link.click();
},
base64ToArrayBuffer: function(data) {
var binaryString = window.atob(data);
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;
},