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
- 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
- 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.
- Siga as etapas mencionadas abaixo para incluir na lista de permissões os caminhos mencionados acima.
- Logon no configMgr
- Pesquisar filtro CSRF do Adobe Granite
- Adicione o seguinte caminho nas seções excluídas e salve
- /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
Clique no botão Send
Você poderia importar essa coleção do carteiro para testar a API