Die Beispiele in diesem Dokument gelten nur für eine AEM Forms on JEE-Umgebung.
Der Barcode-Formular-Service automatisiert die Erfassung von Daten aus Formularen zum Ausfüllen und Ausdrucken und integriert die erfassten Informationen in die IT-Kernsysteme eines Unternehmens.
Mit dem Barcode-Formular-Service können Sie ein- und zweidimensionale Barcodes zu interaktiven PDF-Formularen hinzufügen. Sie können die Barcode-Formulare dann auf einer Website veröffentlichen oder per E-Mail oder CD verteilen. Wenn ein Benutzer ein Barcode-Formular mit Adobe Reader, Acrobat Professional oder Acrobat Standard ausfüllt, wird der Barcode automatisch aktualisiert, um die vom Benutzer eingegebenen Formulardaten zu codieren. Der Benutzer kann das Formular elektronisch übermitteln oder auf Papier drucken und per Post, Fax oder Hand einreichen. Sie können die vom Benutzer eingegebenen Daten später im Rahmen eines automatisierten Workflows extrahieren und die Daten zwischen Genehmigungsprozessen und Geschäftssystemen weiterleiten.
Weitere Informationen zum Barcode-Formular-Service finden Sie in der Service-Referenz für AEM Forms.
Sie können die Barcode-Formular-Service-API verwenden, um Daten aus einem PDF-Formular oder einem Bild mit einem Barcode zu decodieren. Das Decodieren von Formulardaten bedeutet das Extrahieren von Daten, die im Barcode enthalten sind. Bevor Daten aus einem PDF-Formular (oder Bild) decodiert werden können, muss ein Benutzer das Formular mit Daten ausfüllen.
Weitere Informationen zum Barcode-Formular-Service finden Sie in der Service-Referenz für AEM Forms.
Um Daten aus einem PDF-Formular zu decodieren, führen Sie die folgenden Schritte aus:
Projektdateien einbeziehen
Schließen Sie die erforderlichen Dateien in Ihr Entwicklungsprojekt ein. Wenn Sie ein Client-Programm mit Java erstellen, schließen Sie die erforderlichen JAR-Dateien ein. Wenn Sie Web-Services verwenden, stellen Sie sicher, dass Sie die Proxy-Dateien einschließen.
Die folgenden JAR-Dateien müssen zum Klassenpfad Ihres Projekts hinzugefügt werden:
Wenn AEM Forms auf einem unterstützten J2EE-Programm-Server bereitgestellt wird, bei dem es sich nicht um JBoss handelt, müssen Sie die Dateien „adobe-utilities.jar“ und „jbossall-client.jar“ durch JAR-Dateien ersetzen, die spezifisch für den J2EE-Programm-Server sind, auf dem AEM Forms bereitgestellt wird. Informationen zum Speicherort aller AEM Forms-JAR-Dateien finden Sie unter Einbeziehen von AEM Forms-Java-Bibliotheksdateien.
Erstellen eines Client-API-Objekts für Barcode-Formulare
Bevor Sie einen Barcode-Formular-Service-Vorgang programmgesteuert durchführen können, müssen Sie einen Client für den Barcode-Formular-Service erstellen. Wenn Sie die Java-API verwenden, erstellen Sie ein BarcodedFormsServiceClient
-Objekt. Wenn Sie die Barcode-Formular-Webservice-API verwenden, erstellen Sie ein BarcodedFormsServiceService
-Objekt.
Abrufen eines PDF-Formulars, das mit Barcodes versehene Daten enthält
Sie müssen ein PDF-Formular mit einem Barcode abrufen, der mit Benutzerdaten ausgefüllt wurde.
Decodieren der Daten aus dem PDF-Formular
Nachdem Sie ein PDF-Formular (oder ein Bild) mit einem Barcode erhalten haben, können Sie Daten decodieren. Der Barcode-Formular-Service unterstützt die folgenden Barcode-Typen:
Die Eingabe des Zeichensatzes als Hexadezimalwert in der Decodierungs-API bedeutet, dass der Inhalt des Barcodes als hexadezimale Zeichenfolge codiert wird. Wenn beispielsweise UTF-8 als Codierung der Zeichen im Formular und Hex im Decodierungsvorgang angegeben ist, wird der Inhalt des Barcodes als hexadezimale Zeichenfolge im Element <xb:content
> in der decodierten Ausgabe codiert. Sie können diesen Hexadezimalwert konvertieren, um den ursprünglichen Inhalt zu erhalten, indem Sie eine Anwendungslogik in Ihrem Client-Programm erstellen.
Konvertieren der Daten in eine XML-Datenquelle
Nachdem Sie Formulardaten decodiert haben, können Sie sie in XDP- oder XFDF-Daten konvertieren. Angenommen, Sie möchten die Daten in ein anderes Formular importieren. Um die Daten in ein XFA-Formular zu importieren, müssen Sie die Daten in XDP-Daten konvertieren. Weitere Informationen finden Sie unter Importieren von Formulardaten.
Verarbeiten der dekodierten Daten
Sie können die konvertierten Daten verarbeiten, um Ihre Geschäftsanforderungen zu erfüllen. Nachdem Sie beispielsweise die Daten decodiert und konvertiert haben, können Sie sie in einer Datei speichern, in einer Unternehmensdatenbank speichern, ein anderes Formular ausfüllen usw. In diesem Abschnitt wird beschrieben, wie Sie die konvertierten Daten als XML-Datei speichern.
Der Barcode-Formular-Service kann Barcode-Daten nicht decodieren, wenn die Parameter der Trennzeichen für Zeilen und Felder denselben Wert haben
Siehe auch
Decodieren von mit Barcode versehenen Formulardaten mit der Java-API
Dekodieren von mit Barcode versehenen Formulardaten mithilfe der Webservice-API
Einbeziehung von AEM Forms Java-Bibliotheksdateien
Verbindungseigenschaften festlegen
So decodieren Sie Formulardaten mithilfe der Barcode-Formulare-API (Java):
Projektdateien einschließen
Schließen Sie Client-JAR-Dateien in den Klassenpfad Ihres Java-Projekts ein.
Erstellen eines Client-API-Objekts für Barcode-Formulare
Erstellen Sie ein BarcodedFormsServiceClient
-Objekt, indem Sie seinen Konstruktor verwenden und ein ServiceClientFactory
-Objekt übergeben, das Verbindungseigenschaften enthält.
Abrufen eines PDF-Formulars mit Barcode-Daten
java.io.FileInputStream
-Objekt, das das PDF-Formular darstellt, welches Barcode-Daten enthält, indem Sie seinen Konstruktor verwenden und einen Zeichenfolgenwert übergeben, der den Speicherort des PDF-Dokuments angibt.com.adobe.idp.Document
-Objekt, indem Sie seinen Konstruktor verwenden und das java.io.FileInputStream
-Objekt übergeben.Decodieren der Daten aus dem PDF-Formular
Decodieren Sie die Formulardaten, indem Sie die Methode decode
des BarcodedFormsServiceClient
-Objekts aufrufen und die folgenden Werte übergeben:
com.adobe.idp.Document
-Objekt, das das PDF-Formular enthält.java.lang.Boolean
-Objekt, das angibt, ob ein PDF417-Barcode decodiert werden soll.java.lang.Boolean
-Objekt, das, das angibt, ob ein Datenmatrix-Barcode decodiert werden soll.java.lang.Boolean
-Objekt, das angibt, ob ein QR-Code-Barcode decodiert werden soll.java.lang.Boolean
-Objekt, das angibt, ob ein Codabar-Barcode decodiert werden soll.java.lang.Boolean
-Objekt, das angibt, ob ein Code-128-Barcode decodiert werden soll.java.lang.Boolean
-Objekt, das angibt, ob ein Code-39-Barcode decodiert werden soll.java.lang.Boolean
-Objekt, das angibt, ob ein EAN-13-Barcode decodiert werden soll.java.lang.Boolean
-Objekt, das angibt, ob ein EAN-8-Barcode decodiert werden soll.com.adobe.livecycle.barcodedforms.CharSet
-Auflistungswert, der den im Barcode verwendeten Wert für die Codierung des Zeichensatzes angibt.Die Methode decode
gibt ein org.w3c.dom.Document
-Objekt zurück, das decodierte Formulardaten enthält.
Konvertieren der Daten in eine XML-Datenquelle
Konvertieren Sie die decodierten Daten entweder in XDP- oder in XFDF-Daten, indem Sie die Methode extractToXML
des BarcodedFormsServiceClient
-Objekts aufrufen und die folgenden Werte übergeben:
org.w3c.dom.Document
-Objekt, das die decodierten Daten enthält (stellen Sie sicher, dass Sie den Rückgabewert der Methode decode
verwenden).com.adobe.livecycle.barcodedforms.Delimiter
-Auflistungswert, der das Trennzeichen für die Zeile angibt. Es wird empfohlen, Delimiter.Carriage_Return
anzugeben.com.adobe.livecycle.barcodedforms.Delimiter
-Auflistungswert, der das Feldtrennzeichen angibt. Geben Sie zum Beispiel Delimiter.Tab
an.com.adobe.livecycle.barcodedforms.XMLFormat
-Auflistungswert, der angibt, ob die Barcode-Daten in XDP- oder XFDF-XML-Daten konvertiert werden sollen. Geben Sie beispielsweise XMLFormat.XDP
an, um die Daten in XDP-Daten zu konvertieren.Geben Sie nicht dieselben Werte für die Parameter „Zeilentrennzeichen“ und „Feldtrennzeichen“ an.
Die Methode extractToXML
gibt ein java.util.List
-Objekt zurück, bei dem jedes Element ein org.w3c.dom.Document
-Objekt ist. Für jeden Barcode im Formular gibt es ein eigenes Element. Das heißt, wenn das Formular vier Barcodes enthält, gibt es vier Elemente im zurückgegebenen java.util.List
-Objekt.
Verarbeiten der decodierten Daten
java.util.List
-Objekt, um jedes org.w3c.dom.Document
-Objekt zu erhalten, das sich in der Liste befindet.org.w3c.dom.Document
-Objekt in ein com.adobe.idp.Document
-Objekt. (Die Anwendungslogik, die ein org.w3c.dom.Document
-Objekt in ein com.adobe.idp.Document
-Objekt umwandelt, wird im Beispiel zum Dekodieren von Barcode-Formulardaten mithilfe der Java-API gezeigt).copyToFile
des com.adobe.idp.Document
-Objekts aufrufen und ein Dateiobjekt übergeben, das die XML-Datei darstellt.Siehe auch
Schnellstart (SOAP-Modus): Dekodieren von Barcode-Formulardaten mithilfe der Java-API
Einbeziehung von AEM Forms Java-Bibliotheksdateien
Verbindungseigenschaften festlegen
Dekodieren Sie Formulardaten mithilfe der Barcode-Formulare-API (Web-Service):
Projektdateien einschließen
Erstellen eines Client-API-Objekts für Barcode-Formulare
Erstellen Sie mithilfe der Microsoft .NET-Client-Assembly, die die WSDL des Barcode-Formular-Services verwendet, ein BarcodedFormsServiceService
-Objekt, indem Sie seinen Standardkonstruktor aufrufen.
Abrufen eines PDF-Formulars mit Barcode-Daten
BLOB
, indem Sie den Konstruktor verwenden. Das BLOB
-Objekt wird zum Speichern eines PDF-Dokuments verwendet, das einen Barcode enthält.System.IO.FileStream
-Objekt, indem Sie seinen Konstruktor aufrufen und einen Zeichenfolgenwert übergeben, der den Dateispeicherort des PDF-Dokuments und den Modus darstellt, in dem die Datei geöffnet werden soll.System.IO.FileStream
-Objekts speichert. Sie können die Größe des Byte-Arrays bestimmen, indem Sie die Length
-Eigenschaft des System.IO.FileStream
-Objekts abrufen.Read
-Methode des System.IO.FileStream
-Objekts aufrufen und das Byte-Array, die Startposition und die zu lesende Stream-Länge übergeben.BLOB
-Objekt, indem Sie seiner binaryData
-Eigenschaft den Inhalt des Byte-Arrays zuweisen.Decodieren der Daten aus dem PDF-Formular
Decodieren Sie die Formulardaten, indem Sie die Methode decode
des BarcodedFormsServiceService
-Objekts aufrufen und die folgenden Werte übergeben:
BLOB
-Objekt, das das PDF-Formular enthält.Boolean
-Objekt, das angibt, ob ein PDF417-Barcode decodiert werden soll.Boolean
-Objekt, das, das angibt, ob ein Datenmatrix-Barcode decodiert werden soll.Boolean
-Objekt, das angibt, ob ein QR-Code-Barcode decodiert werden soll.Boolean
-Objekt, das angibt, ob ein Codabar-Barcode decodiert werden soll.Boolean
-Objekt, das angibt, ob ein Code-128-Barcode decodiert werden soll.Bolean
-Objekt, das angibt, ob ein Code-39-Barcode decodiert werden soll.Boolean
-Objekt, das angibt, ob ein EAN-13-Barcode decodiert werden soll.Boolean
-Objekt, das angibt, ob ein EAN-8-Barcode decodiert werden soll.CharSet
-Auflistungswert, der den im Barcode verwendeten Wert für die Codierung des Zeichensatzes angibt.Die Methode decode
gibt einen Zeichenfolgenwert zurück, der decodierte Formulardaten enthält.
Konvertieren der Daten in eine XML-Datenquelle
Konvertieren Sie die decodierten Daten entweder in XDP- oder in XFDF-Daten, indem Sie die Methode extractToXML
des BarcodedFormsServiceService
-Objekts aufrufen und die folgenden Werte übergeben:
decode
verwenden).Delimiter
-Auflistungswert, der das Trennzeichen für die Zeile angibt. Es wird empfohlen, Delimiter.Carriage_Return
anzugeben.Delimiter
-Auflistungswert, der das Feldtrennzeichen angibt. Geben Sie zum Beispiel Delimiter.Tab
an.XMLFormat
-Auflistungswert, der angibt, ob die Barcode-Daten in XDP- oder XFDF-XML-Daten konvertiert werden sollen. Geben Sie beispielsweise XMLFormat.XDP
an, um die Daten in XDP-Daten zu konvertieren.Geben Sie nicht dieselben Werte für die Parameter „Zeilentrennzeichen“ und „Feldtrennzeichen“ an.
Die Methode extractToXML
gibt ein Object
-Array zurück, bei dem jedes Element eine BLOB
-Instanz ist. Für jeden Barcode im Formular gibt es ein eigenes Element. Das heißt, wenn es vier Barcodes auf dem Formular gibt, dann befinden sich vier Elemente in dem zurückgegebenen Object
-Array.
Verarbeiten der decodierten Daten
System.IO.FileStream
-Objekt, indem Sie seinen Konstruktor aufrufen und einen Zeichenfolgenwert übergeben, der den Dateispeicherort des gesicherten PDF-Dokuments darstellt.BLOB
-Objekts speichert, das von der Methode encryptPDFUsingPassword
zurückgegeben wurde. Füllen Sie das Byte-Array, indem Sie den Wert des binaryData
-Datenelements des BLOB
-Objekts abrufen.System.IO.BinaryWriter
-Objekt, indem Sie seinen Konstruktor aufrufen und das System.IO.FileStream
-Objekt übergeben.Write
des System.IO.BinaryWriter
-Objekts aufrufen und das Byte-Array übergeben.Siehe auch
Aufrufen von AEM Forms mit Base64-Kodierung