Desagrupar de un documento PDF mediante la API de servicio web disassemble-a-pdf-document-usingthe-web-service-api
Las muestras y los ejemplos de este documento solo son para AEM Forms en un entorno JEE.
Desmontar un documento de PDF mediante la API del servicio Assembler (servicio web):
-
Incluir archivos de proyecto.
Cree un proyecto de Microsoft .NET que utilice MTOM. Asegúrese de utilizar la siguiente definición de WSDL al establecer una referencia de servicio:
http://localhost:8080/soap/services/AssemblerService?WSDL&lc_version=9.0.1
.note note NOTE Reemplace localhost
por la dirección IP del servidor que hospeda AEM Forms. -
Cree un cliente de PDF Assembler.
-
Cree un objeto
AssemblerServiceClient
utilizando su constructor predeterminado. -
Cree un objeto
AssemblerServiceClient.Endpoint.Address
mediante el constructorSystem.ServiceModel.EndpointAddress
. Pase un valor de cadena que especifique el WSDL al servicio AEM Forms (por ejemplo,http://localhost:8080/soap/services/AssemblerService?blob=mtom
). No necesita usar el atributolc_version
. Este atributo se utiliza al crear una referencia de servicio. -
Cree un objeto
System.ServiceModel.BasicHttpBinding
obteniendo el valor del campoAssemblerServiceClient.Endpoint.Binding
. Convertir el valor devuelto enBasicHttpBinding
. -
Establezca el campo
MessageEncoding
del objetoSystem.ServiceModel.BasicHttpBinding
enWSMessageEncoding.Mtom
. Este valor garantiza que se utiliza MTOM. -
Habilite la autenticación HTTP básica realizando las siguientes tareas:
- AEM Asigne el nombre de usuario de los formularios de la al campo
AssemblerServiceClient.ClientCredentials.UserName.UserName
. - Asigne el valor de contraseña correspondiente al campo
AssemblerServiceClient.ClientCredentials.UserName.Password
. - Asigne el valor constante
HttpClientCredentialType.Basic
al campoBasicHttpBindingSecurity.Transport.ClientCredentialType
. - Asigne el valor constante
BasicHttpSecurityMode.TransportCredentialOnly
al campoBasicHttpBindingSecurity.Security.Mode
.
- AEM Asigne el nombre de usuario de los formularios de la al campo
-
-
Hacer referencia a un documento DDX existente.
- Crear un objeto
BLOB
mediante su constructor. El objetoBLOB
se usa para almacenar el documento DDX. - Cree un objeto
System.IO.FileStream
invocando su constructor. Pase un valor de cadena que represente la ubicación de archivo del documento DDX y el modo en que se abrirá el archivo. - Cree una matriz de bytes que almacene el contenido del objeto
System.IO.FileStream
. Puede determinar el tamaño de la matriz de bytes obteniendo la propiedadLength
del objetoSystem.IO.FileStream
. - Rellene la matriz de bytes con datos de secuencia invocando el método
Read
del objetoSystem.IO.FileStream
y pasando a leer la matriz de bytes, la posición inicial y la longitud de secuencia. - Rellene el objeto
BLOB
asignando su propiedadMTOM
con el contenido de la matriz de bytes.
- Crear un objeto
-
Hacer referencia a un documento de PDF para desmontar.
- Crear un objeto
BLOB
mediante su constructor. El objetoBLOB
se usa para almacenar el documento del PDF de entrada. Este objetoBLOB
se pasó ainvokeOneDocument
como argumento. - Cree un objeto
System.IO.FileStream
invocando su constructor y pasando un valor de cadena que represente la ubicación de archivo del documento del PDF de entrada y el modo en que se debe abrir el archivo. - Cree una matriz de bytes que almacene el contenido del objeto
System.IO.FileStream
. Puede determinar el tamaño de la matriz de bytes obteniendo la propiedadLength
del objetoSystem.IO.FileStream
. - Rellene la matriz de bytes con datos de secuencia invocando el método
Read
del objetoSystem.IO.FileStream
y pasando a leer la matriz de bytes, la posición inicial y la longitud de secuencia. - Rellene el objeto
BLOB
asignando su campoMTOM
al contenido de la matriz de bytes. - Crear un objeto
MyMapOf_xsd_string_To_xsd_anyType
. Este objeto de colección se utiliza para almacenar el PDF que se va a desmontar. - Crear un objeto
MyMapOf_xsd_string_To_xsd_anyType_Item
. - Asigne un valor de cadena que represente el nombre de clave al campo
key
del objetoMyMapOf_xsd_string_To_xsd_anyType_Item
. Este valor debe coincidir con el valor del elemento de origen PDF especificado en el documento DDX. - Asigne el objeto
BLOB
que almacena el documento del PDF al campovalue
del objetoMyMapOf_xsd_string_To_xsd_anyType_Item
. - Agregue el objeto
MyMapOf_xsd_string_To_xsd_anyType_Item
al objetoMyMapOf_xsd_string_To_xsd_anyType
. Invoque el métodoAdd
del objetoMyMapOf_xsd_string_To_xsd_anyType
y pase el objetoMyMapOf_xsd_string_To_xsd_anyType
.
- Crear un objeto
-
Establecer opciones en tiempo de ejecución.
- Cree un objeto
AssemblerOptionSpec
que almacene opciones en tiempo de ejecución mediante su constructor. - Establezca las opciones en tiempo de ejecución para satisfacer sus necesidades comerciales asignando un valor a un miembro de datos que pertenezca al objeto
AssemblerOptionSpec
. Por ejemplo, para indicar al servicio Assembler que continúe procesando un trabajo cuando se produzca un error, asignefalse
al campofailOnError
del objetoAssemblerOptionSpec
.
- Cree un objeto
-
Desmontar el documento del PDF.
Invoque el método
invokeDDX
del objetoAssemblerServiceClient
y pase los siguientes valores:- Un objeto
BLOB
que representa el documento DDX que desensambla el documento PDF - El objeto
MyMapOf_xsd_string_To_xsd_anyType
que contiene el documento de PDF que se va a desmontar - Un objeto
AssemblerOptionSpec
que especifica opciones en tiempo de ejecución
El método
invokeDDX
devuelve un objetoAssemblerResult
que contiene los resultados del trabajo y las excepciones que se han producido. - Un objeto
-
Guarde los documentos del PDF desmontados.
Para obtener los documentos del PDF recién creados, realice las siguientes acciones:
- Obtenga acceso al campo
documents
del objetoAssemblerResult
, que es un objetoMap
que contiene los documentos de PDF desensamblados. - Recorra en iteración el objeto
Map
para obtener cada documento resultante. A continuación, convierta elvalue
de ese miembro de la matriz en unBLOB
. - Extraiga los datos binarios que representan el documento de PDF al tener acceso a la propiedad
MTOM
de su objetoBLOB
. Devuelve una matriz de bytes que puede escribir en un archivo PDF.
- Obtenga acceso al campo
Consulte también
Desmontaje programático de documentos PDF
Invocar AEM Forms mediante MTOM