Show Menu
TEMAS×

Desmontaje de un documento PDF mediante la API de servicio Web

Desmontar un documento PDF mediante la API de servicio de ensamblador (servicio Web):
  1. Incluir archivos de proyecto.
    Cree un proyecto de Microsoft .NET que utilice MTOM. Asegúrese de utilizar la siguiente definición WSDL al configurar una referencia de servicio: http://localhost:8080/soap/services/AssemblerService?WSDL&lc_version=9.0.1 .
    Reemplazar localhost por la dirección IP del servidor que aloja AEM Forms.
  2. Cree un cliente de ensamblador de PDF.
    • Cree un AssemblerServiceClient objeto utilizando su constructor predeterminado.
    • Cree un AssemblerServiceClient.Endpoint.Address objeto mediante el System.ServiceModel.EndpointAddress constructor. Pase un valor de cadena que especifique el WSDL al servicio de AEM Forms (por ejemplo, http://localhost:8080/soap/services/AssemblerService?blob=mtom ). No es necesario usar el lc_version atributo. Este atributo se utiliza al crear una referencia de servicio.
    • Cree un System.ServiceModel.BasicHttpBinding objeto obteniendo el valor del AssemblerServiceClient.Endpoint.Binding campo. Convierta el valor devuelto a BasicHttpBinding .
    • Establezca el System.ServiceModel.BasicHttpBinding campo del MessageEncoding objeto en WSMessageEncoding.Mtom . Este valor garantiza que se utilice MTOM.
    • Habilite la autenticación HTTP básica realizando las siguientes tareas:
      • Asigne el nombre de usuario de los formularios AEM 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 campo BasicHttpBindingSecurity.Transport.ClientCredentialType .
      • Asigne el valor constante BasicHttpSecurityMode.TransportCredentialOnly al campo BasicHttpBindingSecurity.Security.Mode .
  3. Haga referencia a un documento DDX existente.
    • Cree un BLOB objeto con su constructor. El BLOB objeto se utiliza para almacenar el documento DDX.
    • Cree un System.IO.FileStream objeto invocando su constructor. Pase un valor de cadena que represente la ubicación del archivo del documento DDX y el modo en que se abre el archivo.
    • Cree una matriz de bytes que almacene el contenido del System.IO.FileStream objeto. Puede determinar el tamaño de la matriz de bytes obteniendo la System.IO.FileStream propiedad del Length objeto.
    • Rellene la matriz de bytes con datos de flujo invocando el System.IO.FileStream método Read del objeto y pasando la matriz de bytes, la posición inicial y la longitud de flujo que se va a leer.
    • Rellene el BLOB objeto asignando su MTOM propiedad con el contenido de la matriz de bytes.
  4. Haga referencia a un documento PDF para desmontarlo.
    • Cree un BLOB objeto con su constructor. El BLOB objeto se utiliza para almacenar el documento PDF de entrada. Este BLOB objeto se pasa al invokeOneDocument como argumento.
    • Cree un System.IO.FileStream objeto invocando su constructor y pasando un valor de cadena que representa la ubicación del archivo del documento PDF de entrada y el modo en que se abre el archivo.
    • Cree una matriz de bytes que almacene el contenido del System.IO.FileStream objeto. Puede determinar el tamaño de la matriz de bytes obteniendo la System.IO.FileStream propiedad del Length objeto.
    • Rellene la matriz de bytes con datos de flujo invocando el System.IO.FileStream método Read del objeto y pasando la matriz de bytes, la posición inicial y la longitud de flujo que se va a leer.
    • Rellene el BLOB objeto asignando su MTOM campo al contenido de la matriz de bytes.
    • Create a MyMapOf_xsd_string_To_xsd_anyType object. Este objeto de colección se utiliza para almacenar el PDF que se va a desmontar.
    • Create a MyMapOf_xsd_string_To_xsd_anyType_Item object.
    • Asigne un valor de cadena que represente el nombre clave al MyMapOf_xsd_string_To_xsd_anyType_Item campo del key objeto. Este valor debe coincidir con el valor del elemento de origen PDF especificado en el documento DDX.
    • Asigne el BLOB objeto que almacena el documento PDF al MyMapOf_xsd_string_To_xsd_anyType_Item campo del value objeto.
    • Agregue el MyMapOf_xsd_string_To_xsd_anyType_Item objeto al MyMapOf_xsd_string_To_xsd_anyType objeto. Invocar el MyMapOf_xsd_string_To_xsd_anyType método del Add objeto y pasar el MyMapOf_xsd_string_To_xsd_anyType objeto.
  5. Configure las opciones de tiempo de ejecución.
    • Cree un AssemblerOptionSpec objeto que almacene opciones de tiempo de ejecución mediante su constructor.
    • Configure las opciones de tiempo de ejecución para cumplir los requisitos comerciales asignando un valor a un miembro de datos que pertenece al AssemblerOptionSpec objeto. Por ejemplo, para indicar al servicio Ensamblador que continúe procesando un trabajo cuando se produzca un error, asigne false al AssemblerOptionSpec campo del failOnError objeto.
  6. Desmontar el documento PDF.
    Invoque el AssemblerServiceClient método del invokeDDX objeto y pase los valores siguientes:
    • Un BLOB objeto que representa el documento DDX que desmonta el documento PDF
    • El MyMapOf_xsd_string_To_xsd_anyType objeto que contiene el documento PDF que se va a desmontar
    • Un AssemblerOptionSpec objeto que especifica opciones de tiempo de ejecución
    El invokeDDX método devuelve un AssemblerResult objeto que contiene los resultados del trabajo y las excepciones que se hayan producido.
  7. Guarde los documentos PDF desmontados.
    Para obtener los documentos PDF recién creados, realice las siguientes acciones:
    • Acceda al AssemblerResult campo del documents objeto, que es un Map objeto que contiene los documentos PDF desensamblados.
    • Repita el Map objeto para obtener cada documento resultante. A continuación, convierta los miembros de la matriz value a un BLOB .
    • Extraiga los datos binarios que representan el documento PDF accediendo a la propiedad del BLOB objeto MTOM . Esto devuelve una matriz de bytes que puede escribir en un archivo PDF.
Consulte también