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);
}
}
}
}
|
|
|