OSGi上以Forms為中心的工作流程 forms-centric-workflow-on-osgi
企業會從數以百計的表單、各種後端系統以及線上或離線資料來源收集資料。 此外也有一組動態的使用者來對資料做出決策,其中涉及反複的稽核和核准流程。
除了針對內部和外部對象的檢閱和核准工作流程,大型組織和企業還會有重複性的任務。 例如,將PDF檔案轉換為另一種格式。 手動完成時,這些工作會佔用大量時間和資源。 企業也有對檔案和封存表單資料進行數位簽署的法律要求,以供日後以預先定義的格式使用。
OSGi上Forms中心工作流程簡介 introduction-to-forms-centric-workflow-on-osgi
您可以使用AEM Workflow快速建立最適化表單式工作流程。 這些工作流程可用於稽核和核准、業務流程流、啟動檔案服務、與Adobe Sign簽名工作流程整合以及類似操作。 例如,信用卡申請處理、員工休假核准工作流程、將表單儲存為PDF檔案。 此外,這些工作流程也可在組織內或跨網路防火牆使用。
透過OSGi上的Forms工作流程,您可以在OSGi棧疊上快速建置和部署各種工作的工作流程,而不需要在JEE棧疊上安裝完整的流程管理功能。 工作流程的開發和管理使用熟悉的AEM Workflow和AEM Inbox功能。 工作流程構成了自動化跨越多個軟體系統、網路、部門甚至組織的真實業務流程的基礎。
設定後,這些工作流程可以手動觸發,以完成定義的流程,或在使用者提交表單或以程式設計方式執行,或 通訊管理 字母。 透過這項增強的AEM Workflow功能,AEM Forms提供兩種相異但相似的功能。 在部署策略中,您需要決定哪一個適合您。 檢視 比較 OSGi上的Forms中心AEM工作流程和JEE上的流程管理。 此外,關於部署拓撲,請參閱 AEM Forms的架構和部署拓撲.
OSGi上的Forms中心工作流程延伸 AEM收件匣 並為AEM工作流程編輯器提供額外元件(步驟),以新增對AEM Forms工作流程的支援。 擴充的AEM收件匣具有類似於 AEM Forms工作區. 除了管理以人為中心的工作流程(核准、稽核等)外,您還可以使用AEM工作流程進行自動化 檔案服務 — 相關作業(例如產生PDF)和以電子方式簽署(Adobe Sign)檔案。
所有AEM Forms工作流程步驟都支援使用變數。 變數可讓工作流程步驟在執行階段跨步驟保留和傳遞中繼資料。 您可以建立不同型別的變數來儲存不同型別的資料。 您也可以建立變數集合(陣列),以儲存多個相關、相同型別資料的執行個體。 通常情況下,當您需要根據變數或變數集合持有的值來做出決定,或儲存您稍後在程式中需要的資訊時,會使用變數或變數集合。 如需有關在這些以Forms為中心的工作流程元件中使用變數的詳細資訊(步驟),請參閱 OSGi上的Forms中心工作流程 — 步驟參考. 如需建立和管理變數的詳細資訊,請參閱 AEM工作流程中的變數.
下圖說明在OSGi上建立、執行和監視Forms工作流程的端對端程式。
開始之前 before-you-start
- 工作流程是真實世界業務流程的表示法。 讓您的真實商業程式與商業程式參與者清單隨時待命。 此外,在開始建立工作流程之前,請準備好附屬資料(調適型表單、PDF檔案等)。
- 一個工作流程可以有多個階段。 這些階段會顯示在AEM收件匣中,並協助報告工作流程的進度。 將您的業務流程劃分為邏輯階段。
- 您可以設定AEM Workflows的指派工作步驟,以傳送電子郵件通知給使用者或受指派人。 所以, 啟用電子郵件通知.
- 工作流程也可以使用Adobe簽章進行數位簽章。 如果您打算在工作流程中使用Adobe Sign,請 設定適用於AEM Forms的Adobe Sign 將其用於工作流程之前。
建立工作流程模型 create-a-workflow-model
工作流程模型包含商務處理的邏輯與流程。 它由一系列步驟組成。 這些步驟是AEM元件。 您可以利用引數和指令碼擴充工作流程步驟,以視需要提供更多功能與控制。 除了開箱即用的AEM步驟外,AEM Forms還提供一些步驟。 如需AEM和AEM Forms步驟的詳細清單,請參閱 AEM工作流程步驟參考 和 OSGi上的Forms中心工作流程 — 步驟參考.
AEM提供直覺式使用者介面,讓您使用提供的工作流程步驟建立工作流程模型。 如需建立工作流程模型的逐步指示,請參閱 建立工作流程模型. 下列範例提供逐步指示,讓您為核准與複查工作流程建立工作流程模型:
建立核准和稽核工作流程的模型 create-a-model-for-an-approval-and-review-workflow
核准和稽核工作流程適用於需要人為干預才能做出決定的任務。 下列範例會建立由前台銀行代理商填寫的按揭貸款申請的工作流程模型。 填妥應用程式後,就會傳送以進行核准。 稍後會使用Adobe Sign將核准的申請傳送給申請者,以索取電子簽章。
此範例可作為以下附加的套件提供。 使用封裝管理員匯入並安裝範例。 您也可以執行下列步驟,手動建立應用程式的工作流程模型:
此範例會建立工作流程模型,作為前台銀行代理商填寫的貸款應用程式。 填寫後,將傳送申請以供核准。 稍後,核准的應用程式會傳送給客戶,以使用Adobe Sign進行電子簽章。 您可以使用封裝管理員匯入及安裝範例。
-
開啟「工作流程模型」主控台。 預設URL為
https://[server]:[port]/libs/cq/workflow/admin/console/content/models.html/etc/workflow/models
-
選取 建立,然後 建立模型. 「新增工作流程模型」對話方塊隨即顯示。
-
輸入 標題 和 名稱 (選擇性)。 例如,抵押貸款應用程式。 選取 完成.
-
選取新建立的工作流程模型並選取 編輯. 現在,您可以新增工作流程步驟以建立商業邏輯。 第一次建立工作流程模型時,模型會包含:
- 步驟:流程開始與流程結束。 這些步驟代表工作流程的開始和結束。 這些步驟為必要步驟,無法編輯或移除。
- 名為步驟1的範例參與者步驟。 此步驟已設定為將工作專案指派給管理員使用者。 移除此步驟。
-
啟用電子郵件通知。 您可以在OSGi上設定以Forms為中心的工作流程,以傳送電子郵件通知給使用者或受指派人。 執行以下設定以啟用電子郵件通知:
- 前往AEM設定管理員,位於
https://[server]:[port]/system/console/configMgr
. - 開啟 Day CQ郵件服務 設定。 指定值 smtp伺服器主機名稱, SMTP伺服器連線埠、 和 「寄件者」地址 欄位。 按一下「儲存」。
- 開啟 Day CQ連結外部化器 設定。 在 網域 欄位中,指定本機、作者和發佈執行個體的實際主機名稱/IP位址和連線埠號碼。 按一下「儲存」。
- 前往AEM設定管理員,位於
-
建立工作流程階段。 一個工作流程可以有多個階段。 這些階段會顯示在AEM收件匣中,並報告工作流程的進度。
若要定義階段,請選取 圖示若要開啟工作流程模型屬性,請開啟 階段 標籤,為工作流程模型新增階段,然後選取 儲存並關閉. 以按揭申請為例,建立階段:貸款請求、貸款請求狀態、要簽署的檔案和已簽署的貸款檔案。
-
拖放 指派任務 步驟瀏覽器至工作流程模型。 使其成為模型的第一步。
指派任務元件會指派由工作流程建立的任務給使用者或群組。 除了指派工作之外,您也可以使用元件來指定工作的調適型表單或非互動式PDF。 自適應表單需要接受使用者的輸入且非互動式PDF,或唯讀自適應表單用於僅稽核工作流程。
您也可以使用步驟來控制工作的行為。 例如,建立自動記錄檔案、將任務指派給特定使用者或群組、提交資料的路徑、要預先填入的資料路徑以及預設動作。 如需指派工作步驟之選項的詳細資訊,請參閱 OSGi上的Forms中心工作流程 — 步驟參考 檔案。
以按揭應用程式為例,設定指派工作步驟以使用唯讀調適型表單,並在工作完成後顯示PDF檔案。 此外,選取允許核准貸款請求的使用者群組。 在 動作 標籤,停用 提交 選項。 建立 actionTaked 變數,並將變數指定為 路由變數. 例如,actionTaken。 此外,請新增核准與拒絕路由。 路由會在AEM收件匣中顯示為個別的動作(按鈕)。 工作流程會根據使用者點選的動作(按鈕)選取分支。
您可以為設定的指派工作步驟的所有欄位(例如,抵押應用程式)匯入範例套件(可在區段開頭下載)。
-
將OR拆分元件從步驟瀏覽器拖放至工作流程模型。 「OR分割」會在工作流程中建立分割,之後只有一個分支處於作用中狀態。 此步驟可讓您將條件式處理路徑匯入工作流程中。 您可以視需要將工作流程步驟新增到每個分支。
您可以使用規則定義、ECMA命令檔或外部命令檔來定義分支的路由表示式。
使用運算式編輯器為Branch 1和Branch 2建立路由運算式。 這些路由運算式可協助您根據AEM收件匣中的使用者動作選擇分支。
分支1的路由運算式
使用者點選時 核准 在AEM收件匣中,分支1為已啟動。
分支2的路由運算式
使用者點選時 拒絕 在AEM收件匣中,分支2已啟用。
如需有關使用變數建立路由運算式的資訊,請參閱 AEM Forms工作流程中的變數.
-
新增其他工作流程步驟以建置商業邏輯。
在抵押範例中,新增產生記錄檔案、兩個指派工作步驟,以及一個簽署檔案步驟至模型的「分支1」,如下圖所示。 一個指派工作步驟是顯示並傳送 將簽署給申請者的貸款檔案 另一個指派工作元件為 顯示已簽署的檔案. 此外,新增指派工作元件至分支2。 當使用者點選AEM收件匣中的拒絕時,它會啟動。
針對指派任務步驟、記錄檔案步驟和簽署檔案步驟的所有欄位(例如,抵押應用程式)的完整值集,匯入範例套件,可於本節開頭下載。
工作流程模型已準備就緒。 您可以透過各種方法啟動工作流程。 如需詳細資訊,請參閱 在OSGi上啟動以Forms為中心的工作流程.
建立以Forms為中心的工作流程應用程式 create-a-forms-centric-workflow-application
應用程式是與工作流程關聯的最適化表單。 透過「收件匣」提交應用程式時,它會啟動相關的工作流程。 若要讓Forms工作流程可作為AEM收件匣和AEM Forms應用程式中的應用程式,請執行以下動作來建立工作流程應用程式:
- 在您的AEM編寫執行個體上,前往 > Forms > 管理工作流程應用程式 和點選 建立.
- 在「建立工作流程應用程式」視窗中,為下列欄位提供輸入,然後點選 建立. 隨即建立新應用程式,並列在「工作流程應用程式」畫面中。
在OSGi上啟動以Forms為中心的工作流程 launch
您可以透過以下方式啟動或觸發以Forms為中心的工作流程:
從AEM收件匣提交應用程式 inbox
您建立的工作流程應用程式可在「收件匣」中作為應用程式使用。 工作流程 — 使用者群組成員的使用者可以填寫並提交觸發相關工作流程的應用程式。 如需使用AEM收件匣提交應用程式和管理工作的相關資訊,請參閱 管理AEM收件匣中的Forms應用程式和工作.
從AEM Forms應用程式提交應用程式 afa
AEM Forms應用程式會與AEM Forms伺服器同步,可讓您變更帳戶中的表單資料、工作、工作流程應用程式和儲存的資訊(草稿/範本)。 如需詳細資訊,請參閱 AEM Forms應用程式 和相關文章。
提交最適化表單 af
您可以設定最適化表單的提交動作,以在提交最適化表單時啟動工作流程。 調適型表單提供 叫用AEM工作流程 提交動作,以便在提交最適化表單時開始工作流程。 如需提交動作的詳細資訊,請參閱 設定提交動作. 若要透過AEM Forms應用程式提交調適型表單,請啟用調適型表單屬性中的「與AEM Forms應用程式同步」 。
您可以設定最適化表單,以從AEM Forms應用程式同步、提交及觸發工作流程。 如需詳細資訊,請參閱 使用表單.
使用watched資料夾 watched
管理員(fd-administrators群組的成員)可以設定網路資料夾,以在使用者將檔案(例如PDF檔案)放入資料夾時執行預先設定的工作流程。 工作流程完成後,它可以將結果檔案儲存到指定的輸出資料夾。 這類資料夾稱為 Watched資料夾. 執行以下程式來設定watched資料夾以啟動工作流程:
- 在您的AEM編寫執行個體上,前往 > Forms > 設定Watched資料夾. 會顯示已設定的watched資料夾清單。
- 選取 新增. 畫面隨即顯示欄位清單。 指定下列欄位的值,以設定工作流程的Watched資料夾:
-
選取 進階. 指定下列欄位的值,然後點選 建立. Watched資料夾已設定為啟動工作流程。 現在,每當檔案置於Watched資料夾的輸入目錄中時,就會觸發指定的工作流程。
table 0-row-2 1-row-2 欄位 說明 承載對應程式篩選條件 當您建立watched資料夾時,它會在crx-repository中建立一個資料夾結構。 資料夾結構可作為工作流程的裝載。 您可以撰寫指令碼來對應AEM工作流程,以接受來自watched資料夾結構的輸入。 現成可用的實作專案並列於裝載對應工具篩選器中。 如果您沒有自訂實施,請選取預設實施。 進階索引標籤包含更多欄位。 這些欄位大多包含預設值。 若要瞭解所有欄位,請參閱 建立或設定watched資料夾 文章。
提互動動式通訊或信件 letter
您可以在提互動動式通訊或信函時,在OSGi上關聯並執行以Forms為中心的工作流程。 在通訊管理中,工作流程用於後處理互動式通訊和信件。 例如,寄送電子郵件、列印、傳真或封存最終信件。 如需詳細步驟,請參閱 互動式通訊和信函的後處理.
其他設定 additional-configurations
設定電子郵件服務 configure-email-service
您可以使用AEM Workflows的指派任務和傳送電子郵件步驟來傳送電子郵件。 執行以下步驟,指定電子郵件伺服器和傳送電子郵件所需的其他設定:
- 前往AEM設定管理員,位於
https://[server]:[port]/system/console/configMgr
. - 開啟 Day CQ郵件服務 設定。 指定值 smtp伺服器主機名稱, SMTP伺服器連線埠、 和 「寄件者」地址 欄位。 按一下「儲存」。
- 開啟 Day CQ連結外部化器 設定。 在 網域 欄位中,指定本機、作者和發佈執行個體的實際主機名稱/IP位址和連線埠號碼。 按一下「儲存」。
清除工作流程例項 purge-workflow-instances
將工作流程例項的數目降至最低會提升工作流程引擎的效能,因此您可以定期從儲存庫中清除已完成或執行中的工作流程例項。 如需詳細資訊,請參閱 定期清除工作流程執行個體 清除工作流程例項。
將工作流程變數的敏感資料引數化,並儲存在外部資料存放區中 externalize-wf-variables
從調適型表單提交到的任何資料 Experience Manager 工作流程可以包含您企業一般使用者的PII (個人識別資訊)或SPD (敏感個人資料)。 不過,不需要強制將您的資料儲存在 Adobe Experience Manager JCR存放庫. 您可以將資訊引數化,將一般使用者資料的儲存空間外部化至您的受管理資料儲存空間(例如Azure blob儲存空間) 工作流程變數.
在 Adobe Experience Manager Forms工作流程中,會透過工作流程變數,透過一系列工作流程步驟處理和傳遞資料。 這些變數是儲存在工作流程例項中繼資料節點中的已命名屬性或機碼值組;例如 /var/workflow/instances/<serverid>/<datebucket>/<uniquenameof model>_<id>/data/metaData
. 這些工作流程變數可以外部化到JCR以外的獨立存放庫,然後由處理 Adobe Experience Manager 工作流程。 Adobe Experience Manager 提供API UserMetaDataPersistenceProvider
以將工作流程變數儲存在您的受管理外部儲存空間中。 若要進一步瞭解在中針對客戶擁有的資料存放區使用工作流程變數 Adobe Experience Manager,請參閱 管理外部資料存放區的工作流程變數.
Adobe 提供下列內容 範例 若要使用API將變數從工作流程中繼資料對應儲存至Azure blob儲存體 UserMetaDataPersistenceProvider. 在類似的行上,您可以使用範例作為使用指南 [UserMetaDataPersistenceProvider] API可將任何外部資料儲存中的工作流程變數外部化 Adobe Experience Manager 並管理相同專案。
安裝工作流程API實作範例
若要將工作流程變數儲存在受管理的Azure Blob儲存空間中:
-
安裝 範例 工作流程API UserMetaDataPersistenceProvider 如下所示:
-
在專案根目錄中執行
mvn clean install
使用Maven 3執行命令。 -
若要將套件組合和內容套件部署給作者,請執行
mvn clean install -PautoInstallPackage
. -
若只要將套件組合部署給作者,請執行
mvn clean install -PautoInstallBundle
.
-
-
在的外部化程式OSGi設定檔中,初始化以下屬性
ui.config
內容封裝:code language-jql accountKey="" accountName="" endpointSuffix="" containerName="" protocol=""
以下是這些屬性的用途(和範例):
-
accountKey 是授權存取的金鑰。
-
帳戶名稱 是必須儲存資料的azure帳戶。
-
端點尾碼 例如,
core.windows.net
. -
containername 是帳戶中需要儲存資料的容器。 範例假設容器存在。
-
通訊協定 例如,
https
或http
.
- 在中設定工作流程模型 Adobe Experience Manager. 若要瞭解如何設定外部儲存的工作流程模型,請參閱 設定工作流程模型.
在中設定工作流程模型 Adobe Experience Manager 用於外部資料儲存 configure-aem-wf-model
若要設定外部資料儲存的AEM Workflow模型:
-
瀏覽至 工具 > 工作流程 > 模型.
-
選取模型名稱並選取 編輯.
-
選取「頁面資訊」圖示,然後選取 開啟屬性.
-
選取 將工作流程資料儲存區外部化.
-
選取 儲存並關閉 以儲存屬性。
外部資料儲存的AEM工作流程准則 guidelines-workflows-external-data-storage
使用時,請遵循下列准則 Adobe Experience Manager 工作流程並將資料儲存至外部資料儲存庫(例如Microsoft Azure儲存伺服器):
-
在工作流程模型步驟中定義輸入和輸出資料檔案及附件時,使用變數來儲存資料。 不要選取 相對於承載 和 在絕對路徑上可用 選項。 此 相對於承載 和 在絕對路徑上可用 選項不會在您之後自動顯示 設定 Adobe Experience Manager 外部資料儲存的工作流程模型.
-
將最適化表單提交至AEM Workflow時,請使用變數來儲存資料檔案和附件。 不要選取 相對於承載 選項,同時將最適化表單提交至 Adobe Experience Manager 工作流程。 此 相對於承載 選項不會在您之後自動顯示 設定 Adobe Experience Manager 外部資料儲存的工作流程模型.
-
不要使用自訂 Adobe Experience Manager 工作流程模型中用於儲存資料的工作流程步驟 CRX DE 存放庫。
-
當您 設定 Adobe Experience Manager 外部資料儲存的工作流程模型,不建立自訂欄 Adobe Experience Manager 收件匣 因為如果工作專案在中,則不會擷取自訂欄的值 Adobe Experience Manager 收件匣 屬於標籤為外部儲存的工作流程。