使用監視資料夾機制生成用於打印通道的交互通信文檔

在設計並測試打印渠道文檔後,通常需要通過發出REST調用來生成文檔,或使用監看資料夾機制生成打印文檔。

本文說明了使用觀看資料夾機制產生列印通道檔案的使用案例。

將檔案拖放到監看資料夾時,會執行與監看資料夾相關聯的指令碼。 本指令碼將在以下文章中說明。

拖放至已觀看資料夾的檔案具有下列結構。 該代碼將為XML文檔中列出的所有帳號生成語句。

<accountnumbers>

<accountnumber>509840</accountnumber>

<accountnumber>948576</accountnumber>

<accountnumber>398762</accountnumber>

<accountnumber>291723</accountnumber>

</accountnumbers>

下列程式碼執行下列動作:

第1行 — InteractiveCommunicationsDocument的路徑

第15-20行:從XML文檔獲取帳戶號清單,並將其放入監視資料夾中

第24 -25行:獲取與文檔關聯的PrintChannelService和Print Channel。

第30行:將accountnumber作為關鍵元素傳遞至「表單資料模型」。

第32-36行:為要生成的文檔設定資料選項。

第38行:呈現文檔。

第39-40行 — 將生成的文檔保存到檔案系統。

「表單資料模型」的REST端點需要一個ID作為輸入參數。 如下方螢幕擷取所示,此id會對應至名為accountnumber的請求屬性。

requestattribute

var interactiveCommunicationsDocument = "/content/forms/af/retirementstatementprint/channels/print/";
var saveLocation =  new Packages.java.io.File("c:\\scrap\\loadtesting");

if(!saveLocation.exists())
{
 saveLocation.mkdirs();
}

var inputMap = processorContext.getInputMap();
var entry = inputMap.entrySet().iterator().next();
var inputDocument = inputMap.get(entry.getKey());
var aemDemoListings = sling.getService(Packages.com.mergeandfuse.getserviceuserresolver.GetResolver);
var resourceResolver = aemDemoListings.getServiceResolver();
var resourceResolverHelper = sling.getService(Packages.com.adobe.granite.resourceresolverhelper.ResourceResolverHelper);
var dbFactory = Packages.javax.xml.parsers.DocumentBuilderFactory.newInstance();
var dBuilder = dbFactory.newDocumentBuilder();
var xmlDoc = dBuilder.parse(inputDocument.getInputStream());
var nList = xmlDoc.getElementsByTagName("accountnumber");
for(var i=0;i<nList.getLength();i++)
{
 var accountnumber = nList.item(i).getTextContent();
resourceResolverHelper.callWith(resourceResolver, {call: function()
       {
   var printChannelService = sling.getService(Packages.com.adobe.fd.ccm.channels.print.api.service.PrintChannelService);
   var printChannel = printChannelService.getPrintChannel(interactiveCommunicationsDocument);
   var options = new Packages.com.adobe.fd.ccm.channels.print.api.model.PrintChannelRenderOptions();
   options.setMergeDataOnServer(true);
   options.setRenderInteractive(false);
   var map = new Packages.java.util.HashMap();
   map.put("accountnumber",accountnumber);
    // Required Data Options
   var dataOptions = new Packages.com.adobe.forms.common.service.DataOptions();
   dataOptions.setServiceName(printChannel.getPrefillService());
   dataOptions.setExtras(map);
   dataOptions.setContentType(Packages.com.adobe.forms.common.service.ContentType.JSON);
   dataOptions.setFormResource(resourceResolver.resolve(interactiveCommunicationsDocument));
            options.setDataOptions(dataOptions);
    var printDocument = printChannel.render(options);
   var statement = new Packages.com.adobe.aemfd.docmanager.Document(printDocument.getInputStream());
            statement.copyToFile(new Packages.java.io.File(saveLocation+"\\"+accountnumber+".pdf"));

      }
   });
}

若要在您的本地系統上測試此功能,請按照以下說明操作:

  • 按照以下說明安裝Tomcat 文章。 Tomcat具有生成示例資料的war檔案。

  • 設定服務,即系統用戶,如下所述 文章.
    請確保此系統用戶具有以下節點的讀取權限。 將權限登入 使用者管理員 並搜索系統用戶「data」,並通過將按鈕顯示到「權限」頁簽,為以下節點授予讀取權限

    • /content/dam/formsanddocuments
    • /content/dam/formsanddocuments-fdm
    • /content/forms/af
  • 使用套件管理器將下列套件匯入AEM。 此套件包含下列項目:

  • 互動式通訊檔案範例

  • 觀看資料夾指令碼

  • 資料來源組態

  • 開啟/etc/fd/watchfolder/scripts/PrintPDF.ecma檔案。 確保第1行中的interactiveCommunicationsDocument的路徑指向要打印的正確文檔

  • 按照第2行上的首選項修改saveLocation

  • 建立accountnumbers.xml檔案,其內容如下

<accountnumbers>
<accountnumber>1</accountnumber>
<accountnumber>100</accountnumber>
<accountnumber>101</accountnumber>
<accountnumber>1009</accountnumber>
<accountnumber>10009</accountnumber>
<accountnumber>11990</accountnumber>
</accountnumbers>
  • 將accountnumbers.xml拖放到C:\RenderPrintChannel\input folder中。

  • 生成的PDF檔案將按照ecma指令碼中的指定寫入saveLocation。

注意

如果您打算在非windows作業系統上使用,請導覽至

/etc/fd/watchfolder /config/PrintChannelDocument ,並根據您的首選項更改folderPath

本頁內容