XDP Stitching using assembler Service
I den här artikeln finns de resurser som du kan använda för att visa möjligheten att sammanfoga xdp-dokument med hjälp av sammansättningstjänsten.
Följande jsp-kod har skrivits för att infoga ett delformulär med namnet adress från xdp-dokument med namnet address.xdp till en insättningspunkt med namnet adress i master.xdp-dokument. Den resulterande xdp-filen sparades i rotmappen för AEM.
Assembler-tjänsten förlitar sig på ett giltigt DDX-dokument för att beskriva manipuleringen av PDF-dokument. Du kan se DDX-referensdokument här.Sidan 40 innehåller information om xdp-sammanfogning.
javax.servlet.http.Part ddxFile = request.getPart("xdpstitching.ddx");
System.out.println("Got DDX");
java.io.InputStream ddxIS = ddxFile.getInputStream();
com.adobe.aemfd.docmanager.Document ddxDocument = new com.adobe.aemfd.docmanager.Document(ddxIS);
javax.servlet.http.Part masterXdpPart = request.getPart("masterxdp.xdp");
System.out.println("Got master xdp");
java.io.InputStream masterXdpPartIS = masterXdpPart.getInputStream();
com.adobe.aemfd.docmanager.Document masterXdpDocument = new com.adobe.aemfd.docmanager.Document(masterXdpPartIS);
javax.servlet.http.Part fragmentXDPPart = request.getPart("fragment.xdp");
System.out.println("Got fragment.xdp");
java.io.InputStream fragmentXDPPartIS = fragmentXDPPart.getInputStream();
com.adobe.aemfd.docmanager.Document fragmentXdpDocument = new com.adobe.aemfd.docmanager.Document(fragmentXDPPartIS);
java.util.Map < String, Object > mapOfDocuments = new java.util.HashMap < String, Object > ();
mapOfDocuments.put("master.xdp", masterXdpDocument);
mapOfDocuments.put("address.xdp", fragmentXdpDocument);
com.adobe.fd.assembler.service.AssemblerService assemblerService = sling.getService(com.adobe.fd.assembler.service.AssemblerService.class);
if (assemblerService != null)
System.out.println("Got assembler service");
com.adobe.fd.assembler.client.AssemblerOptionSpec aoSpec = new com.adobe.fd.assembler.client.AssemblerOptionSpec();
aoSpec.setFailOnError(true);
com.adobe.fd.assembler.client.AssemblerResult assemblerResult = assemblerService.invoke(ddxDocument, mapOfDocuments, aoSpec);
com.adobe.aemfd.docmanager.Document finalXDP = assemblerResult.getDocuments().get("stitched.xdp");
finalXDP.copyToFile(new java.io.File("stitched.xdp"));
DDX-filen som infogar fragment i en annan xdp visas nedan. DDX infogar delformuläret adress från address.xdp till insättningspunkten som anropas adress i master.xdp. Det resulterande dokumentet med namnet sydda.xdp sparas i filsystemet.
<?xml version="1.0" encoding="UTF-8"?>
<DDX xmlns="http://ns.adobe.com/DDX/1.0/">
<XDP result="stitched.xdp">
<XDP source="master.xdp">
<XDPContent insertionPoint="address" source="address.xdp" fragment="address"/>
</XDP>
</XDP>
</DDX>
För att få den här funktionen att fungera på din AEM
- Ladda ned XDP Stitching-paket till ditt lokala system.
- Överför och installera paketet med pakethanterare
- Extrahera innehållet i zip-filen för att hämta exempelfilen för xdp och DDX
När du har installerat paketet måste du tillåtslista följande URL:er i Adobe Granite CSRF-filtret.
- Följ stegen nedan för att tillåtslista de sökvägar som nämns ovan.
- Logga in på configMgr
- Sök efter Adobe Granite CSRF-filter
- Lägg till följande sökväg i de uteslutna avsnitten och spara
/content/AemFormsSamples/assemblerservice
- Sök efter filtret "Sling Referrer"
- Markera kryssrutan Tillåt tomt. (Den här inställningen bör endast användas i testsyfte) Det finns flera sätt att testa exempelkoden. Det snabbaste och enklaste är att använda Postman. Med Postman kan du göra förfrågningar om POST till servern. Installera Postman-appen på datorn.
Starta programmet och ange följande URL för att testa API:t för exportdata http://localhost:4502/content/AemFormsSamples/assemblerservice.html
Ange följande indataparametrar enligt skärmbilden. Du kan använda exempeldokumenten som du hämtade tidigare,