Generare documenti PDF utilizzando il servizio di output

[AEM Forms as a Cloud Service]{class="badge informative"}

Il servizio di output è un servizio OSGi che fa parte di AEM Document Services. Supporta vari formati di output e funzioni di progettazione di AEM Forms Designer. Il servizio di output converte i modelli XFA e i dati XML per generare documenti di stampa in formati diversi.

Il servizio di output in AEM Forms as a Cloud Service è molto simile a quello di AEM Forms 6.5, quindi se hai familiarità con l’utilizzo del servizio di output in AEM Forms 6.5, la transizione ad AEM Forms as a Cloud Service dovrebbe essere semplice.

Con il servizio di output, è possibile creare applicazioni che consentono di:

  • Generare i documenti compilando i file modello con dati XML.
  • Genera moduli di output in vari formati, inclusi flussi di stampa non interattivi PDF, PostScript, PCL e ZPL.
  • Generare PDF di stampa da PDF modulo XFA.
  • Generare in blocco documenti PDF, PostScript, PCL e ZPL unendo più set di dati con i modelli forniti.

Questo servizio è progettato per essere utilizzato nel contesto di un’istanza as a Cloud Service di AEM Forms. Il seguente frammento di codice genera un documento PDF in un servlet utilizzando OutputService.

import com.adobe.fd.output.api.OutputService;
import com.adobe.fd.output.api.PDFOutputOptions;
import com.adobe.fd.output.api.AcrobatVersion;
import com.adobe.aemfd.docmanager.Document;
import org.apache.sling.api.servlets.HttpConstants;
import org.apache.sling.api.servlets.SlingAllMethodsServlet;
import org.apache.sling.api.servlets.SlingServletPaths;
import org.apache.sling.api.SlingHttpServletRequest;
import org.apache.sling.api.SlingHttpServletResponse;
import org.osgi.service.component.annotations.Component;
import org.osgi.service.component.annotations.Reference;

import java.io.ByteArrayInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.nio.charset.StandardCharsets;

@Component(service = Servlet.class,
           property = {
               "sling.servlet.methods=" + HttpConstants.METHOD_POST,
               "sling.servlet.paths=/bin/generateStatement"
           })
public class GenerateStatementServlet extends SlingAllMethodsServlet {

    @Reference
    private OutputService outputService;

    @Override
    protected void doPost(SlingHttpServletRequest request, SlingHttpServletResponse response) throws IOException {
        // Access the submitted form data
        String formData = request.getParameter("formData");

        // Define the XDP template document
        String templateName = "/content/dam/formsanddocuments/adobe/statement.xdp";
        Document xdpDocument = new Document(templateName);

        // Set the PDF output options
        PDFOutputOptions pdfOutputOptions = new PDFOutputOptions();
        pdfOutputOptions.setAcrobatVersion(AcrobatVersion.Acrobat_10);

        // Create the submitted data document from the form data
        InputStream inputStream = new ByteArrayInputStream(formData.getBytes(StandardCharsets.UTF_8));
        Document submittedData = new Document(inputStream);

        // Use the output service to generate the PDF output
        Document generatedPDF = outputService.generatePDFOutput(xdpDocument, submittedData, pdfOutputOptions);

        // Process the generated PDF as per your use case
    }
}
recommendation-more-help
4859a77c-7971-4ac9-8f5c-4260823c6f69