建立轉譯Forms的網頁應用程式 creating-web-applications-thatrenders-forms
本檔案中的範例和範例僅適用於JEE環境上的AEM Forms。
建立轉譯Forms的網頁應用程式 creating-web-applications-that-renders-forms
您可以建立使用Java servlet來叫用Forms服務和轉譯表單的網頁型應用程式。 使用Java™ servlet的優點在於,您可以將處理程式的傳回值寫入使用者端Web瀏覽器。 也就是說,Java servlet可當作傳回表單的使用者端Web瀏覽器與Forms服務之間的連結。
您可以使用Java servlet將表單寫入使用者端網頁瀏覽器,讓客戶可以檢視表單並在表單中輸入資料。 將資料填入表單後,網頁使用者按一下表單上的提交按鈕,將資訊傳回Java servlet,以便擷取和處理資料。 例如,可將資料傳送至另一個程式。
本節討論如何建立網頁式應用程式,讓使用者能夠選取美式表單資料或加拿大表單資料,如下圖所示。
           
          
呈現的表單是以片段為基礎的表單。 也就是說,如果使用者選取美國資料,則傳回的表單會使用以美國資料為基礎的片段。 例如,表單的頁尾包含美國地址,如下圖所示。
           
          
同樣地,如果使用者選取加拿大資料,則傳回的表單會包含加拿大地址,如下圖所示。
           
          
範例檔案
本節使用位於以下位置的範例檔案:
<Forms Designer安裝目錄>/Samples/Forms/採購訂單/表單片段
其中<install directory>是安裝路徑。 就使用者端應用程式而言,已從這個安裝位置複製採購單Dynamic.xdp檔案,並部署至名為 Applications/FormsApplication 的Forms應用程式。 Purchase Order Dynamic.xdp檔案放置在名為FormsFolder的資料夾中。 同樣地,片段會放置在名為Fragments的資料夾中,如下圖所示。
           
          
若要存取Purchase Order Dynamic.xdp表單設計,請將Applications/FormsApplication/1.0/FormsFolder/Purchase Order Dynamic.xdp指定為表單名稱(傳遞給renderPDFForm方法的第一個引數),並將repository:///指定為內容根URI值。
Web應用程式使用的XML資料檔案已從Data資料夾移至C:\Adobe (屬於裝載AEM Forms的J2EE應用程式伺服器的檔案系統)。 檔案名稱是採購單 加拿大.xml 和採購單 US.xml。
步驟摘要 summary-of-steps
若要建立根據片段轉譯表單的網頁型應用程式,請執行下列步驟:
- 建立網站專案。
- 建立代表Java Servlet的Java應用程式邏輯。
- 建立網頁應用程式的網頁。
- 將Web應用程式封裝成WAR檔案。
- 將WAR檔案部署至J2EE應用程式伺服器。
- 測試您的網頁應用程式。
建立網站專案 creating-a-web-project
建立包含可呼叫Forms服務的Java servlet的Web應用程式的第一個步驟是建立Web專案。 此檔案所根據的Java IDE為Eclipse 3.3。使用Eclipse IDE建立Web專案,並將必要的JAR檔案新增至專案。 最後,將名為 index.html 的HTML頁面和Java Servlet新增至專案。
下列清單指定您必須新增至Web專案的JAR檔案:
- adobe-forms-client.jar
- adobe-livecycle-client.jar
- adobe-usermanager-client.jar
- adobe-utilities.jar
如需這些JAR檔案的位置,請參閱包含AEM Forms Java程式庫檔案。
若要建立Web專案:
- 啟動Eclipse並按一下 檔案 > 新增專案。
- 在 新專案 對話方塊中,選取 Web > 動態Web專案。
- 輸入專案名稱FragmentsWebApplication,然後按一下 完成。
若要新增必要的JAR檔案至您的專案:
- 在[專案總管]視窗中,用滑鼠右鍵按一下FragmentsWebApplication專案並選取 屬性。
- 按一下 Java組建路徑,然後按一下 資料庫 標籤。
- 按一下 新增外部JAR 按鈕,並瀏覽至要包含的JAR檔案。
若要新增Java servlet至您的專案:
- 在[專案總管]視窗中,用滑鼠右鍵按一下FragmentsWebApplication專案,然後選取 新增 > 其他。
- 展開 Web 資料夾,選取 Servlet,然後按一下 下一步。
- 在[建立Servlet]對話方塊中,輸入RenderFormFragment作為Servlet的名稱,然後按一下[完成]。
若要將HTML頁面新增至專案:
- 在[專案總管]視窗中,用滑鼠右鍵按一下FragmentsWebApplication專案,然後選取 新增 > 其他。
- 展開 Web 資料夾,選取 HTML,然後按一下 下一步。
- 在[新增HTML]對話方塊中,輸入index.html檔案名稱,然後按一下[完成]。
RenderFormFragment Java Servlet的HTML頁面的資訊,請參閱建立網頁。為servlet建立Java應用程式邏輯 creating-java-application-logic-for-the-servlet
您可以建立Java應用程式邏輯,以便從Java Servlet內叫用Forms服務。 下列程式碼顯示RenderFormFragment Java Servlet的語法:
     public class RenderFormFragment extends HttpServlet implements Servlet {
         public void doGet(HttpServletRequest req, HttpServletResponse resp
         throws ServletException, IOException {
         doPost(req,resp);
         }
         public void doPost(HttpServletRequest req, HttpServletResponse resp
         throws ServletException, IOException {
             //Add code here to invoke the Forms service
             }
一般而言,您不會將使用者端代碼放在Java servlet的doGet或doPost方法中。 較佳的程式設計實務是將這個程式碼放在個別的類別中,從doPost方法(或doGet方法)內將類別具現化,然後呼叫適當的方法。 不過,為了程式碼簡潔,本節中的程式碼範例會維持在最小值,而且程式碼範例會放在doPost方法中。
若要使用Forms服務API根據片段轉譯表單,請執行以下工作:
- 
                  在您的Java專案的類別路徑中包含使用者端JAR檔案,例如adobe-forms-client.jar。 如需這些檔案位置的相關資訊,請參閱包含AEM Forms Java程式庫檔案。 
- 
                  擷取從HTML表單提交的選項按鈕值,並指定使用美國或加拿大資料。 如果提交American,請建立在 採購單US.xml 中儲存資料的 com.adobe.idp.Document。 同樣地,如果是Canadian,則建立在 採購單Canada.xml 檔案中儲存資料的com.adobe.idp.Document。
- 
                  建立包含連線屬性的 ServiceClientFactory物件。 (請參閱設定連線屬性。)
- 
                  使用它的建構函式並傳遞 ServiceClientFactory物件來建立FormsServiceClient物件。
- 
                  使用它的建構函式建立儲存URI值的 URLSpec物件。
- 
                  叫用 URLSpec物件的setApplicationWebRoot方法,並傳遞代表應用程式網頁根目錄的字串值。
- 
                  叫用 URLSpec物件的setContentRootURI方法,並傳遞指定內容根URI值的字串值。 確認表單設計和片段位於內容根URI中。 否則,Forms服務會擲回例外狀況。 若要參考AEM Forms存放庫,請指定repository://。
- 
                  叫用 URLSpec物件的setTargetURL方法,並傳遞字串值,該值指定要將表單資料張貼到的目標URL值。 如果您在表單設計中定義目標URL,您可以傳遞空字串。 您也可以指定傳送表單以執行計算的URL。
- 
                  叫用 FormsServiceClient物件的renderPDFForm方法,並傳遞下列值:- 字串值,指定表單設計名稱,包括副檔名。
- 包含要與表單(在步驟2中建立)合併之資料的com.adobe.idp.Document物件。
- 儲存執行階段選項的PDFFormRenderSpec物件。 如需詳細資訊,請參閱AEM Forms API參考。
- URLSpec物件包含Forms服務根據片段轉譯表單所需的URI值。
- 儲存檔案附件的java.util.HashMap物件。 這是選用引數,如果您不想將檔案附加至表單,可以指定null。
 renderPDFForm方法傳回FormsResult物件,其中包含必須寫入使用者端網頁瀏覽器的表單資料流。
- 
                  呼叫 FormsResult物件的getOutputContent方法,以建立com.adobe.idp.Document物件。
- 
                  透過叫用物件的 getContentType方法,取得com.adobe.idp.Document物件的內容型別。
- 
                  透過叫用其 setContentType方法並傳遞com.adobe.idp.Document物件的內容型別來設定javax.servlet.http.HttpServletResponse物件的內容型別。
- 
                  呼叫 javax.servlet.http.HttpServletResponse物件的getOutputStream方法,建立用來將表單資料流寫入使用者端網頁瀏覽器的javax.servlet.ServletOutputStream物件。
- 
                  呼叫 com.adobe.idp.Document物件的getInputStream方法,以建立java.io.InputStream物件。
- 
                  呼叫 InputStream物件的read方法,並將位元組陣列作為引數傳遞,以表單資料流填入位元組陣列。
- 
                  叫用 javax.servlet.ServletOutputStream物件的write方法,將表單資料流傳送至使用者端網頁瀏覽器。 將位元組陣列傳遞至write方法。
下列程式碼範例代表Java servlet,它會叫用Forms服務並根據片段轉譯表單。
 /*
     * This Java Quick Start uses the following JAR files
     * 1. adobe-forms-client.jar
     * 2. adobe-livecycle-client.jar
     * 3. adobe-usermanager-client.jar
     *
     * (Because Forms quick starts are implemented as Java servlets, it is
     * not necessary to include J2EE specific JAR files - the Java project
     * that contains this quick start is exported as a WAR file which
     * is deployed to the J2EE application server)
     *
     * These JAR files are in the following path:
     * <install directory>/sdk/client-libs
     *
     * For complete details about the location of these JAR files,
     * see "Including AEM Forms library files" in Programming with AEM forms
     */
 import java.io.File;
 import java.io.FileInputStream;
 import java.io.IOException;
 import java.io.PrintWriter;
 import javax.servlet.Servlet;
 import javax.servlet.ServletException;
 import javax.servlet.ServletOutputStream;
 import javax.servlet.http.HttpServlet;
 import javax.servlet.http.HttpServletRequest;
 import javax.servlet.http.HttpServletResponse;
 import com.adobe.livecycle.formsservice.client.*;
 import java.util.*;
 import java.io.InputStream;
 import java.net.URL;
 import com.adobe.idp.Document;
 import com.adobe.idp.dsc.clientsdk.ServiceClientFactory;
 import com.adobe.idp.dsc.clientsdk.ServiceClientFactoryProperties;
 public class RenderFormFragment extends HttpServlet implements Servlet {
     public void doGet(HttpServletRequest req, HttpServletResponse resp)
         throws ServletException, IOException {
             doPost(req,resp);
     }
     public void doPost(HttpServletRequest req, HttpServletResponse resp)
     throws ServletException, IOException {
         try{
             //Set connection properties required to invoke AEM Forms
             Properties connectionProps = new Properties();
             connectionProps.setProperty(ServiceClientFactoryProperties.DSC_DEFAULT_SOAP_ENDPOINT, "https://'[server]:[port]'");
             connectionProps.setProperty(ServiceClientFactoryProperties.DSC_TRANSPORT_PROTOCOL,ServiceClientFactoryProperties.DSC_SOAP_PROTOCOL);
             connectionProps.setProperty(ServiceClientFactoryProperties.DSC_SERVER_TYPE, "JBoss");
             connectionProps.setProperty(ServiceClientFactoryProperties.DSC_CREDENTIAL_USERNAME, "administrator");
             connectionProps.setProperty(ServiceClientFactoryProperties.DSC_CREDENTIAL_PASSWORD, "password");
             //Get the value of selected radio button
             String radioValue = req.getParameter("radio");
             //Create an Document object to store form data
             Document oInputData = null;
             //The value of the radio button determines the form data to use
             //which determines which fragments used in the form
             if (radioValue.compareTo("AMERICAN") == 0)            {
                 FileInputStream myData = new FileInputStream("C:\\Adobe\Purchase Order US.xml");
                 oInputData = new Document(myData);
             }
             else if (radioValue.compareTo("CANADIAN") == 0)            {
                 FileInputStream myData = new FileInputStream("C:\\Adobe\Purchase Order Canada.xml");
                 oInputData = new Document(myData);
             }
             //Create a ServiceClientFactory object
             ServiceClientFactory myFactory = ServiceClientFactory.createInstance(connectionProps);
             //Create a FormsServiceClient object
             FormsServiceClient formsClient = new FormsServiceClient(myFactory);
             //Set the parameter values for the renderPDFForm method
             String formName = "Applications/FormsApplication/1.0/FormsFolder/Purchase Order Dynamic.xdp";
             //Cache the PDF form
             PDFFormRenderSpec pdfFormRenderSpec = new PDFFormRenderSpec();
             pdfFormRenderSpec.setCacheEnabled(new Boolean(true));
             //Specify URI values that are required to render a form
             //design based on fragments
             URLSpec uriValues = new URLSpec();
             uriValues.setApplicationWebRoot("https://'[server]:[port]'/RenderFormFragment");
             uriValues.setContentRootURI("repository:///");
             uriValues.setTargetURL("https://'[server]:[port]'/FormsServiceClientApp/HandleData");
             //Invoke the renderPDFForm method and write the
             //results to a client web browser
             FormsResult formOut = formsClient.renderPDFForm(
                         formName,               //formQuery
                         oInputData,             //inDataDoc
                         pdfFormRenderSpec,      //PDFFormRenderSpec
                         uriValues,                //urlSpec
                         null                    //attachments
                         );
             //Create a Document object that stores form data
             Document myData = formOut.getOutputContent();
             //Get the content type of the response and
             //set the HttpServletResponse object’s content type
             String contentType = myData.getContentType();
             resp.setContentType(contentType);
             //Create a ServletOutputStream object
             ServletOutputStream oOutput = resp.getOutputStream();
             //Create an InputStream object
             InputStream inputStream = myData.getInputStream();
             //Write the data stream to the web browser
             byte[] data = new byte[4096];
             int bytesRead = 0;
             while ((bytesRead = inputStream.read(data)) > 0)
             {
                 oOutput.write(data, 0, bytesRead);
             }
         }catch (Exception e) {
              System.out.println("The following exception occurred: "+e.getMessage());
       }
     }
 }
建立網頁 creating-the-web-page
index.html網頁提供Java servlet的進入點並叫用Forms服務。 此網頁是基本的HTML表單,包含兩個選項按鈕和一個提交按鈕。 選項按鈕的名稱是單選按鈕。 當使用者按一下提交按鈕時,表單資料會張貼到RenderFormFragment Java servlet。
Java servlet會使用下列Java程式碼來擷取從HTML頁面張貼的資料:
             Document oInputData = null;
             //Get the value of selected radio button
             String radioValue = req.getParameter("radio");
             //The value of the radio button determines the form data to use
             //which determines which fragments used in the form
             if (radioValue.compareTo("AMERICAN") == 0)            {
                 FileInputStream myData = new FileInputStream("C:\\Adobe\Purchase Order US.xml");
                 oInputData = new Document(myData);
             }
             else if (radioValue.compareTo("CANADIAN") == 0)            {
                 FileInputStream myData = new FileInputStream("C:\\Adobe\Purchase Order Canada.xml");
                 oInputData = new Document(myData);
             }
下列HTML程式碼位於開發環境設定期間建立的index.html檔案中。 (請參閱建立Web專案。)
 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
 <html xmlns="https://www.w3.org/1999/xhtml">
 <head>
 <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
 <title>Untitled Document</title>
 </head>
 <body>
 <form name="myform" action="https://'[server]:[port]'/FragmentsWebApplication/RenderFormFragment" method="post">
      <table>
      <tr>
        <th>Forms Fragment Web Client</th>
      </tr>
      <tr>
        <td>
          <label>
          <input type="radio" name="radio" id="radio_Data" value="CANADIAN" />
          Canadian data<br />
          </label>
          <p>
            <label>
            <input type="radio" name="radio" id="radio_Data" value="AMERICAN" checked/>
            American data</label>
          </p>
        </td>
      </tr>
      <tr>
      <td>
        <label>
          <input type="submit" name="button_Submit" id="button_Submit" value="Submit" />
            </label>
            </td>
         </tr>
        </table>
      </form>
 </body>
 </html>
封裝網頁應用程式 packaging-the-web-application
若要部署叫用Forms服務的Java servlet,請將您的Web應用程式封裝成WAR檔案。 確定元件的商業邏輯所依賴的外部JAR檔案(例如adobe-livecycle-client.jar和adobe-forms-client.jar)也包含在WAR檔案中。
若要將Web應用程式封裝到WAR檔案:
- 在 專案總管 視窗中,用滑鼠右鍵按一下FragmentsWebApplication專案,然後選取 匯出 > WAR檔案。
- 在 Web模組 文字方塊中,輸入Java專案名稱的FragmentsWebApplication。
- 在 目的地 文字方塊中,輸入 檔案名稱的FragmentsWebApplication.war,指定WAR檔案的位置,然後按一下[完成]。
將WAR檔案部署至J2EE應用程式伺服器 deploying-the-war-file-to-the-j2ee-application-server
您可以將WAR檔案部署至部署AEM Forms的J2EE應用程式伺服器。 部署WAR檔案後,您可以使用網頁瀏覽器存取HTML網頁。
若要將WAR檔案部署至J2EE應用程式伺服器:
- 將WAR檔案從匯出路徑複製到[Forms Install]\Adobe\Adobe Experience Manager Forms\jboss\server\all\deploy。
測試您的網頁應用程式 testing-your-web-application
在您部署Web應用程式後,可以使用網頁瀏覽器來測試它。 假設您使用裝載AEM Forms的同一部電腦,您可以指定下列URL:
- 
                  http://localhost:8080/FragmentsWebApplication/index.html 選取選項按鈕並按一下「提交」按鈕。 基於片段的表單將顯示在網頁瀏覽器中。 如果發生問題,請參閱J2EE應用程式伺服器的記錄檔。