Geração de documentos pdf usando fragmentos developing-with-output-and-forms-services-in-aem-forms

Neste artigo, usaremos o serviço de saída para gerar arquivos pdf usando fragmentos xdp. O xdp principal e os fragmentos residem no repositório crx. É importante imitar a estrutura de pastas do sistema de arquivos no AEM. Por exemplo, se estiver usando um fragmento na pasta de fragmentos do xdp, você deve criar uma pasta chamada fragmentos na pasta base do AEM. A pasta base conterá o modelo base xdp. Por exemplo, se você tiver a seguinte estrutura em seu sistema de arquivos

  • c:\xdptemplates - Conterá o modelo base xdp
  • c:\xdptemplates\fragments - Essa pasta conterá fragmentos e o modelo principal fará referência ao fragmento conforme mostrado abaixo
    fragment-xdp .
  • A pasta xdpdocuments conterá o modelo base e os fragmentos na pasta fragmentos

Você pode criar a estrutura necessária usando os formulários e a interface do usuário do documento

A seguir está a estrutura de pastas da amostra xdp que usa 2 fragmentos
formuláriosdocumento

  • Serviço de saída - Normalmente, esse serviço é usado para mesclar dados xml com modelo xdp ou pdf para gerar pdf nivelado. Para obter mais detalhes, consulte o javadoc para o Serviço de saída. Nesta amostra, estamos usando fragmentos que residem no repositório crx.

O código a seguir foi usado para incluir fragmentos no arquivo PDF

System.out.println("I am in using fragments POST.jsp");
// contentRootURI is the base folder. All fragments are relative to this folder
String contentRootURI = request.getParameter("contentRootURI");
String xdpName = request.getParameter("xdpName");
javax.servlet.http.Part xmlDataPart = request.getPart("xmlDataFile");
System.out.println("Got xml file");
String filePath = request.getParameter("saveLocation");
java.io.InputStream xmlIS = xmlDataPart.getInputStream();
com.adobe.aemfd.docmanager.Document xmlDocument = new com.adobe.aemfd.docmanager.Document(xmlIS);
com.adobe.fd.output.api.OutputService outputService = sling.getService(com.adobe.fd.output.api.OutputService.class);

if (outputService == null) {
  System.out.println("The output service is  null.....");
} else {
  System.out.println("The output service is  not null.....");

}
com.adobe.fd.output.api.PDFOutputOptions pdfOptions = new com.adobe.fd.output.api.PDFOutputOptions();
pdfOptions.setAcrobatVersion(com.adobe.fd.output.api.AcrobatVersion.Acrobat_11);

pdfOptions.setContentRoot(contentRootURI);

com.adobe.aemfd.docmanager.Document generatedDocument = outputService.generatePDFOutput(xdpName, xmlDocument, pdfOptions);
generatedDocument.copyToFile(new java.io.File(filePath));
out.println("Document genreated and saved to " + filePath);

Para testar o pacote de exemplo em seu sistema

incluir na lista de permissões Depois de instalar o pacote, você terá que copiar as seguintes URLs no Filtro CSRF do Adobe Granite.

  1. Siga as etapas mencionadas abaixo para incluir na lista de permissões os caminhos mencionados acima.
  2. Logon no configMgr
  3. Pesquisar filtro CSRF do Adobe Granite
  4. Adicione o seguinte caminho nas seções excluídas e salve
  5. /content/AemFormsSamples/usingfragments

Há várias maneiras de testar o código de amostra. O mais rápido e fácil é usar o aplicativo Postman. O Postman permite fazer solicitações POST no servidor. Instale o aplicativo Postman no sistema.
Inicie o aplicativo e insira o seguinte URL para testar a API de dados de exportação

Verifique se você selecionou "POST" na lista suspensa
http://localhost:4502/content/AemFormsSamples/usingfragments.html
Certifique-se de especificar "Autorização" como "Autenticação básica". Especifique o nome de usuário e a senha do AEM Server
Navegue até a guia "Corpo" e especifique os parâmetros da solicitação, conforme mostrado na imagem abaixo
exportar
Clique no botão Send

Você poderia importar essa coleção do carteiro para testar a API

recommendation-more-help
8de24117-1378-413c-a581-01e660b7163e