Show Menu
SUJETS×

Démonter un document PDF à l’aide de l’API du service Web

Démontez un document PDF à l’aide de l’API Assembler Service (service Web) :
  1. Incluez des fichiers de projet.
    Créez un projet Microsoft .NET qui utilise MTOM. Veillez à utiliser la définition WSDL suivante lors de la définition d’une référence de service : http://localhost:8080/soap/services/AssemblerService?WSDL&lc_version=9.0.1 .
    Remplacez localhost par l’adresse IP du serveur hébergeant AEM Forms.
  2. Créez un client PDF Assembler.
    • Créez un AssemblerServiceClient objet à l’aide de son constructeur par défaut.
    • Créez un AssemblerServiceClient.Endpoint.Address objet à l’aide du System.ServiceModel.EndpointAddress constructeur. Transmettez une valeur de chaîne qui spécifie le WSDL au service AEM Forms (par exemple, http://localhost:8080/soap/services/AssemblerService?blob=mtom ). Vous n’avez pas besoin d’utiliser l’ lc_version attribut. Cet attribut est utilisé lorsque vous créez une référence de service.
    • Créez un System.ServiceModel.BasicHttpBinding objet en obtenant la valeur du AssemblerServiceClient.Endpoint.Binding champ. Convertissez la valeur de retour en BasicHttpBinding .
    • Définissez le System.ServiceModel.BasicHttpBinding champ de l’ MessageEncoding objet sur WSMessageEncoding.Mtom . Cette valeur garantit l’utilisation de MTOM.
    • Activez l’authentification HTTP de base en effectuant les tâches suivantes :
      • Attribuez le nom d’utilisateur d’AEM forms au champ AssemblerServiceClient.ClientCredentials.UserName.UserName .
      • Attribuez la valeur de mot de passe correspondante au champ AssemblerServiceClient.ClientCredentials.UserName.Password .
      • Attribuez la valeur constante HttpClientCredentialType.Basic au champ BasicHttpBindingSecurity.Transport.ClientCredentialType .
      • Attribuez la valeur constante BasicHttpSecurityMode.TransportCredentialOnly au champ BasicHttpBindingSecurity.Security.Mode .
  3. Référencez un document DDX existant.
    • Créez un objet BLOB en utilisant son constructeur. L’ BLOB objet est utilisé pour stocker le document DDX.
    • Create a System.IO.FileStream object by invoking its constructor. Transmettez une valeur de chaîne représentant l’emplacement du fichier du document DDX et le mode d’ouverture du fichier.
    • Créez un tableau d’octets qui stocke le contenu de l’ System.IO.FileStream objet. Vous pouvez déterminer la taille du tableau d’octets en obtenant la System.IO.FileStream Length propriété de l’objet.
    • Renseignez le tableau d’octets avec les données de flux en appelant la System.IO.FileStream Read méthode de l’objet et en transmettant le tableau d’octets, la position de départ et la longueur du flux à lire.
    • Renseignez l’ BLOB objet en affectant sa MTOM propriété au contenu du tableau d’octets.
  4. Référencez un document PDF à désassembler.
    • Créez un objet BLOB en utilisant son constructeur. L’ BLOB objet est utilisé pour stocker le document PDF d’entrée. Cet BLOB objet est transmis au invokeOneDocument en tant qu’argument.
    • Créez un System.IO.FileStream objet en appelant son constructeur et en transmettant une valeur de chaîne représentant l’emplacement du fichier PDF d’entrée et le mode d’ouverture du fichier.
    • Créez un tableau d’octets qui stocke le contenu de l’ System.IO.FileStream objet. Vous pouvez déterminer la taille du tableau d’octets en obtenant la System.IO.FileStream Length propriété de l’objet.
    • Renseignez le tableau d’octets avec les données de flux en appelant la System.IO.FileStream Read méthode de l’objet et en transmettant le tableau d’octets, la position de départ et la longueur du flux à lire.
    • Renseignez l’ BLOB objet en affectant à son MTOM champ le contenu du tableau d’octets.
    • Create a MyMapOf_xsd_string_To_xsd_anyType object. Cet objet Collection est utilisé pour stocker le PDF à désassembler.
    • Create a MyMapOf_xsd_string_To_xsd_anyType_Item object.
    • Attribuez une valeur de chaîne représentant le nom de la clé au MyMapOf_xsd_string_To_xsd_anyType_Item key champ de l’objet. Cette valeur doit correspondre à la valeur de l’élément source PDF spécifié dans le document DDX.
    • Affectez l’ BLOB objet qui stocke le document PDF au MyMapOf_xsd_string_To_xsd_anyType_Item value champ de l’objet.
    • Ajoutez l’ MyMapOf_xsd_string_To_xsd_anyType_Item objet à l’ MyMapOf_xsd_string_To_xsd_anyType objet. Appelez la méthode MyMapOf_xsd_string_To_xsd_anyType de l’ Add objet et transmettez-le MyMapOf_xsd_string_To_xsd_anyType .
  5. Définissez les options d’exécution.
    • Créez un AssemblerOptionSpec objet qui stocke les options d’exécution à l’aide de son constructeur.
    • Définissez des options d’exécution pour répondre aux besoins de votre entreprise en attribuant une valeur à un membre de données qui appartient à l’ AssemblerOptionSpec objet. Par exemple, pour demander au service Assembler de poursuivre le traitement d’une tâche en cas d’erreur, affectez-lui le false champ de l’objet AssemblerOptionSpec failOnError .
  6. Désassemblez le document PDF.
    Appelez la méthode AssemblerServiceClient invokeDDX de l’objet et transmettez les valeurs suivantes :
    • Objet BLOB représentant le document DDX qui désassemble le document PDF
    • Objet MyMapOf_xsd_string_To_xsd_anyType contenant le document PDF à désassembler
    • Objet AssemblerOptionSpec spécifiant les options d’exécution
    La invokeDDX méthode renvoie un AssemblerResult objet qui contient les résultats de la tâche et toutes les exceptions survenues.
  7. Enregistrez les documents PDF déassemblés.
    Pour obtenir les documents PDF nouvellement créés, procédez comme suit :
    • Accédez au AssemblerResult champ de l’ documents objet, qui est un Map objet contenant les documents PDF déassemblés.
    • Effectuez une itération dans l’ Map objet pour obtenir chaque document cible. Jetez ensuite le numéro value de l’élément de tableau sur un BLOB .
    • Extrayez les données binaires qui représentent le document PDF en accédant à la BLOB MTOM propriété de son objet. Cette opération renvoie un tableau d’octets que vous pouvez écrire dans un fichier PDF.
Voir également