已保存的Docusign文档PDF已损坏

时间:2016-12-07 01:41:57

标签: pdf docusignapi

我创建了一个收到Docusign webhooks的监听器页面。一切都在从webhook中提取数据,但是当我循环浏览DocumentPDF时,它会创建PDF文件,但它们已损坏且无法打开(当我尝试在Acrobat中打开它时,我收到了以下消息:Acrobat无法打开...因为它不是受支持的文件类型,或者因为文件已损坏。")

有人可以帮我弄清楚创建的pdf文件被破坏的原因吗?

我的页面代码如下:

 protected void Page_Load(object sender, EventArgs e)
    {
        StreamReader sr = new StreamReader(Request.InputStream);
        string xml = sr.ReadToEnd();
        string fileName = HttpContext.Current.Server.MapPath("") + "\\Results\\" + DateTime.Now.Ticks + ".xml";
        File.WriteAllText(fileName, xml);


        try
        {
            XmlDocument xmldoc = new XmlDocument();
            xmldoc.LoadXml(xml);

            var mgr = new XmlNamespaceManager(xmldoc.NameTable);
            mgr.AddNamespace("a", "http://www.docusign.net/API/3.0");

            XmlNode envelopeStatus = xmldoc.SelectSingleNode("//a:EnvelopeStatus", mgr);
            XmlNode envelopeId = envelopeStatus.SelectSingleNode("//a:EnvelopeID", mgr);
            XmlNode status = envelopeStatus.SelectSingleNode("//a:Status", mgr);

            if (status.InnerText == "Completed")
            {
                LogException("Looking for DocPDF's_" + DateTime.Now.Ticks + ";");
                // Loop through the DocumentPDFs element, storing each document.

                XmlNode docs = xmldoc.SelectSingleNode("//a:DocumentPDFs", mgr);
                foreach (XmlNode doc in docs.ChildNodes)
                {
                    string documentName = doc.ChildNodes[0].InnerText; // pdf.SelectSingleNode("//a:Name", mgr).InnerText;
                    string documentId = doc.ChildNodes[2].InnerText; // pdf.SelectSingleNode("//a:DocumentID", mgr).InnerText;
                    string byteStr = doc.ChildNodes[1].InnerText; // pdf.SelectSingleNode("//a:PDFBytes", mgr).InnerText;

                    LogException("Writing Out PDF_" + HttpContext.Current.Server.MapPath("") + "\\Documents\\" + envelopeId.InnerText + "_" + documentId + "_" + documentName + "_" + DateTime.Now.Ticks + ";");

                    File.WriteAllText(HttpContext.Current.Server.MapPath("") + "\\Documents\\" + envelopeId.InnerText + "_" + documentId + "_" + documentName, byteStr);

                    LogException("Successfully wrote out PDF_" + DateTime.Now.Ticks + ";");
                }
            }
        }
        catch (Exception ex)
        {
            LogException("Exception: " + ex.Message + "; InnerException: " + ex.InnerException.ToString() + "_" + DateTime.Now.Ticks + ";");
        }
    }

2 个答案:

答案 0 :(得分:4)

@mkl是正确的。 Webhook(连接)通知消息的PDF内容是base64编码的。对其进行解码以获取PDF文件。

示例:参见食谱example webhook listener -

的第402行
pdf_file.write(base64.b64decode(pdf.PDFBytes.string))

答案 1 :(得分:0)

我正在使用Azure函数并使用Blob存储来保存它。 这对我有用:

var byteStr = doc.ChildNodes[1].InnerText;
outputBlob.Write(System.Convert.FromBase64String(byteStr));