轉譯已啟用許可權的Forms rendering-rights-enabled-forms

Forms服務可轉譯已套用使用許可權的表單。 使用許可權與Acrobat中預設提供的功能有關,但不適用於Adobe Reader,例如新增註解至表單或填寫表單欄位及儲存表單的功能。 已套用使用許可權的Forms稱為許可權啟用表單。 在Adobe Reader中開啟許可權啟用表單的使用者,可以執行為該表單啟用的操作。

若要將使用許可權套用至表單,Acrobat Reader DC擴充功能服務必須是AEM表單安裝的一部分。 此外,您必須具備有效的認證,才能將使用許可權套用至PDF檔案。 也就是說,您必須先正確設定Acrobat Reader DC擴充功能服務,才能轉譯啟用許可權的表單。 (請參閱 關於Acrobat Reader DC擴充功能服務.)

NOTE
若要呈現包含使用許可權的表單,您必須使用XDP檔案作為輸入,而非PDF檔案。 如果您使用PDF檔案作為輸入,表單仍會呈現;但是,它不會是啟用許可權的表單。
NOTE
指定下列使用許可權時,您無法預先填入XML資料的表單: enableCommentsenableCommentsOnlineenableEmbeddedFiles,或 enableDigitalSignatures. (請參閱 使用可流程配置預先填入Forms.)
NOTE
如需Forms服務的詳細資訊,請參閱 AEM Forms服務參考.

步驟摘要 summary-of-steps

若要轉譯啟用許可權的表單,請執行下列工作:

  1. 包含專案檔案。
  2. 建立Forms使用者端API物件。
  3. 設定使用許可權執行階段選項。
  4. 轉譯啟用許可權的表單。
  5. 將啟用許可權的表單寫入使用者端網頁瀏覽器。

包含專案檔案

將必要的檔案納入您的開發專案中。 如果您使用Java建立使用者端應用程式,請包含必要的JAR檔案。 如果您使用Web服務,請確定您包含Proxy檔案。

建立Forms使用者端API物件

您必須先建立Forms服務使用者端,才能以程式設計方式執行Forms服務使用者端API作業。

設定使用許可權執行階段選項

設定使用許可權執行階段選項,以顯示啟用許可權的表單。 指定用來套用使用許可權至表單的認證別名。 指定別名值之後,您即可指定要套用至表單的每個使用許可權。

轉譯啟用許可權的表單

若要轉譯已啟用許可權的表單,您可以使用與轉譯沒有使用許可權的表單相同的應用程式邏輯。 唯一的區別是,您必須確保使用許可權執行階段選項包含在應用程式邏輯中。

NOTE
使用Forms Web服務API轉譯啟用許可權的表單時,您無法將檔案附加至表單。

將表單資料流寫入使用者端網頁瀏覽器

Forms服務轉譯啟用許可權的表單時,會傳回您必須寫入使用者端網頁瀏覽器的表單資料流。 將表單寫入使用者端網頁瀏覽器後,使用者即可看到表單。 在Adobe Reader中檢視許可權啟用表單的使用者,可執行針對該表單啟用的操作。

另請參閱

使用Java API轉譯啟用許可權的表單

使用網站服務API轉譯啟用許可權的表單

包含AEM Forms Java程式庫檔案

設定連線屬性

Forms服務API快速入門

呈現互動式PDF forms

建立轉譯Forms的網頁應用程式

使用Java API轉譯啟用許可權的表單 render-rights-enabled-forms-using-the-java-api

使用Forms API (Java)轉譯已啟用許可權的表單:

  1. 包含專案檔案

    在您的Java專案的類別路徑中包含使用者端JAR檔案,例如adobe-forms-client.jar。

  2. 建立Forms使用者端API物件

    • 建立 ServiceClientFactory 包含連線屬性的物件。
    • 建立 FormsServiceClient 物件,使用它的建構函式並傳遞 ServiceClientFactory 物件。
  3. 設定使用許可權執行階段選項

    • 建立 ReaderExtensionSpec 物件(使用其建構函式)。
    • 透過叫用 ReaderExtensionSpec 物件的 setReCredentialAlias 方法並指定代表別名值的字串值。
    • 透過叫用屬於 ReaderExtensionSpec 物件。 不過,只有當您參照的認證可讓您進行時,才能設定使用許可權。 也就是說,如果認證不允許您設定使用方式,您就無法設定使用方式。 例如。 若要設定使用許可權,讓使用者能夠填寫表單欄位並儲存表單,請叫用 ReaderExtensionSpec 物件的 setReFillIn 方法與傳遞 true.
    note note
    NOTE
    不需要叫用 ReaderExtensionSpec 物件的 setReCredentialPassword 方法。 Forms服務不使用此方法。
  4. 轉譯啟用許可權的表單

    叫用 FormsServiceClient 物件的 renderPDFFormWithUsageRights 方法並傳遞下列值:

    • 字串值,指定表單設計名稱,包括副檔名。 如果您參照的表單設計屬於Forms應用程式的一部分,請務必指定完整路徑,例如 Applications/FormsApplication/1.0/FormsFolder/Loan.xdp.
    • A com.adobe.idp.Document 包含要與表單合併之資料的物件。 如果您不想合併資料,請傳遞空白字元 com.adobe.idp.Document 物件。
    • A PDFFormRenderSpec 儲存執行階段選項的物件。
    • A ReaderExtensionSpec 儲存使用許可權執行階段選項的物件。
    • A URLSpec 包含Forms服務所需URI值的物件。

    renderPDFFormWithUsageRights 方法傳回 FormsResult 包含必須寫入使用者端Web瀏覽器的表單資料流的物件。

  5. 將表單資料流寫入使用者端網頁瀏覽器

    • 建立 com.adobe.idp.Document 物件(透過叫用 FormsResult 物件 getOutputContent 方法。
    • 取得 com.adobe.idp.Document 物件(透過叫用其 getContentType 方法。
    • 設定 javax.servlet.http.HttpServletResponse 物件的內容型別,透過叫用其 setContentType 方法並傳遞的內容型別 com.adobe.idp.Document 物件。
    • 建立 javax.servlet.ServletOutputStream 用來將表單資料流寫入使用者端網頁瀏覽器的物件,方法是叫用 javax.servlet.http.HttpServletResponse 物件的 getOutputStream 方法。
    • 建立 java.io.InputStream 物件(透過叫用 com.adobe.idp.Document 物件的 getInputStream 方法。
    • 建立位元組陣列,透過叫用 InputStream 物件的 read 方法,並將位元組陣列作為引數傳遞。
    • 叫用 javax.servlet.ServletOutputStream 物件的 write 將表單資料流傳送至使用者端web瀏覽器的方法。 將位元組陣列傳遞至 write 方法。

另請參閱

快速入門(SOAP模式):使用Java API轉譯已啟用許可權的表單

包含AEM Forms Java程式庫檔案

設定連線屬性

使用網站服務API轉譯啟用許可權的表單 render-rights-enabled-forms-using-the-web-service-api

使用Forms API (Web服務)轉譯啟用許可權的表單:

  1. 包含專案檔案

    • 建立使用Forms服務WSDL的Java Proxy類別。
    • 將Java Proxy類別納入您的類別路徑中。
  2. 建立Forms使用者端API物件

    建立 FormsService 物件並設定驗證值。

  3. 設定使用許可權執行階段選項

    • 建立 ReaderExtensionSpec 物件(使用其建構函式)。
    • 透過叫用 ReaderExtensionSpec 物件的 setReCredentialAlias 方法並指定代表別名值的字串值。
    • 透過叫用屬於 ReaderExtensionSpec 物件。 不過,只有當您參照的認證可讓您進行時,才能設定使用許可權。 也就是說,如果認證不允許您設定使用方式,您就無法設定使用方式。 若要設定使用許可權,讓使用者能夠填寫表單欄位並儲存表單,請叫用 ReaderExtensionSpec 物件的 setReFillIn 方法與傳遞 true.
  4. 轉譯啟用許可權的表單

    叫用 FormsService 物件的 renderPDFFormWithUsageRights 方法並傳遞下列值:

    • 字串值,指定表單設計名稱,包括副檔名。 如果您參照的表單設計屬於Forms應用程式的一部分,請務必指定完整路徑,例如 Applications/FormsApplication/1.0/FormsFolder/Loan.xdp.
    • A BLOB 包含要與表單合併之資料的物件。 如果您不想將資料與表單合併,則必須傳遞 BLOB 以空白XML資料來源為基礎的物件。 您無法傳遞 BLOB 為空值的物件;否則,會擲回例外狀況。
    • A PDFFormRenderSpec 儲存執行階段選項的物件。
    • A ReaderExtensionSpec 儲存使用許可權執行階段選項的物件。
    • A URLSpec 包含Forms服務所需URI值的物件。

    renderPDFFormWithUsageRights 方法傳回 FormsResult 包含必須寫入使用者端Web瀏覽器的表單資料流的物件。

  5. 將表單資料流寫入使用者端網頁瀏覽器

    • 建立 BLOB 包含表單資料的物件(透過叫用 FormsResult 物件的 getOutputContent 方法。
    • 取得 BLOB 物件(透過叫用其 getContentType 方法。
    • 設定 javax.servlet.http.HttpServletResponse 物件的內容型別,透過叫用其 setContentType 方法並傳遞的內容型別 BLOB 物件。
    • 建立 javax.servlet.ServletOutputStream 用來將表單資料流寫入使用者端網頁瀏覽器的物件,方法是叫用 javax.servlet.http.HttpServletResponse 物件的 getOutputStream 方法。
    • 建立位元組陣列,並透過叫用 BLOB 物件的 getBinaryData 方法。 此任務會指派 FormsResult 物件至位元組陣列。
    • 叫用 javax.servlet.http.HttpServletResponse 物件的 write 將表單資料流傳送至使用者端web瀏覽器的方法。 將位元組陣列傳遞至 write 方法。

另請參閱

轉譯已啟用許可權的Forms

使用Base64編碼叫用AEM Forms

recommendation-more-help
19ffd973-7af2-44d0-84b5-d547b0dffee2