Quick Start (MTOM): Creating multiple PDF files using the web service API

The following C# code creates multiple PDF files for each data record that is located in an XML data file named Loan_data_batch.xml. The files are written to the C:\Adobe\ directory. The PDF files are written to the C:\Adobe folder located on the J2EE application server hosting LiveCycle, not the client computer. (See Creating Multiple Output Files.)

/** 
    * Ensure that you create a .NET project that uses  
    * MS Visual Studio 2008 and version 3.5 of the .NET 
    * framework. This is required to invoke a  
    * LiveCycle service using MTOM. 
    *      
    * For information, see "Invoking LiveCycle using MTOM" in Programming with LiveCycle   
    */ 
using System; 
using System.Collections.Generic; 
using System.Linq; 
using System.Text; 
using System.ServiceModel; 
using System.IO; 
 
//A reference to the Output service  
using BatchDocuments.ServiceReference1; 
 
 
namespace BatchDocuments 
{ 
       class Program 
       { 
           static void Main(string[] args) 
           { 
               try 
               { 
                   //Create an OutputServiceClient object 
                   OutputServiceClient outputClient = new OutputServiceClient(); 
                   outputClient.Endpoint.Address = new System.ServiceModel.EndpointAddress("http://hiro-xp:8080/soap/services/OutputService?blob=mtom"); 
 
                   //Enable BASIC HTTP authentication 
                   BasicHttpBinding b = (BasicHttpBinding)outputClient.Endpoint.Binding; 
                   b.MessageEncoding = WSMessageEncoding.Mtom; 
                   outputClient.ClientCredentials.UserName.UserName = "administrator"; 
                   outputClient.ClientCredentials.UserName.Password = "password"; 
                   b.Security.Transport.ClientCredentialType = HttpClientCredentialType.Basic; 
                   b.Security.Mode = BasicHttpSecurityMode.TransportCredentialOnly; 
                   b.MaxReceivedMessageSize = 2000000; 
                   b.MaxBufferSize = 2000000; 
                   b.ReaderQuotas.MaxArrayLength = 2000000; 
 
                   //Create a BLOB object to store form data 
                   BLOB inData = new BLOB(); 
 
                   //Specify the XML data file that contains multiple records 
                   string path = "C:\\Adobe\Loan_data_batch.xml"; 
                   FileStream fs = new FileStream(path, FileMode.Open); 
 
                   //Get the length of the file stream  
                   int len = (int)fs.Length; 
                   byte[] ByteArray = new byte[len]; 
 
                   //Populate the byte array with the contents of the FileStream object 
                   fs.Read(ByteArray, 0, len); 
                   inData.MTOM = ByteArray; 
 
                   //Set output run-time options to create  
                   //multiple PDF files 
                   PDFOutputOptionsSpec pdfOptions = new PDFOutputOptionsSpec(); 
                   pdfOptions.generateManyFiles = true; 
                   pdfOptions.fileURI = "C:\\Adobe\forms\Loan.pdf"; 
                   pdfOptions.recordName = "LoanRecord"; 
                   pdfOptions.lookAhead = 300; 
 
                   //Set rendering run-time options  
                   RenderOptionsSpec renderOptions = new RenderOptionsSpec(); 
                   renderOptions.cacheEnabled = true; 
 
                   //Create empty objects to pass as arguments 
                   //to the generatePDFOutput method 
                   //These objects are populated by the method 
                   BLOB generatePDFOutputMetaDataDoc = new BLOB(); 
                   BLOB generatePDFOutputResultDoc = new BLOB(); 
                   OutputResult outResult = new OutputResult(); 
 
                   //Create multiple PDF files 
                   outputClient.generatePDFOutput( 
                       TransformationFormat.PDF, 
                       "Loan.xdp", 
                       "C:\\Adobe", 
                       pdfOptions, 
                       renderOptions, 
                       inData, 
                       out generatePDFOutputMetaDataDoc, 
                       out generatePDFOutputResultDoc, 
                       out outResult); 
 
                   //Write the result data to Output.xml 
                   //Populate a byte array with BLOB data 
                   byte[] outByteArray = generatePDFOutputResultDoc.MTOM; 
 
                   //Create a new file to store result data 
                   string FILE_NAME = "C:\\Adobe\Output.xml"; 
                   FileStream fs2 = new FileStream(FILE_NAME, FileMode.OpenOrCreate); 
 
                   //Create a BinaryWriter object 
                   BinaryWriter w = new BinaryWriter(fs2); 
                   w.Write(outByteArray); 
                   w.Close(); 
                   fs2.Close(); 
               } 
 
               catch (Exception ee) 
               { 
                   Console.WriteLine(ee.Message); 
               } 
           } 
       } 
}