创建自适应Forms的自定义提交操作 writing-custom-submit-action-for-adaptive-forms
自适应表单提供多个现成的提交操作(OOTB)。 提交操作可指定要对通过自适应表单收集的数据执行的操作的详细信息。 例如,通过电子邮件发送数据。
您可以创建自定义提交操作,以添加现成提交操作中未包含或通过单个OOTB提交操作不受支持的功能。 例如,将数据提交到工作流,将数据保存在数据存储中,向提交表单的人员发送电子邮件通知,并通过单个提交操作向负责处理已提交表单以供审批和拒绝的人员发送电子邮件。
XML数据格式 xml-data-format
使用 jcr:data
请求参数将XML数据发送到Servlet。 提交操作可以访问参数以处理数据。 以下代码描述了XML数据的格式。 绑定到表单模型的字段显示在 afBoundData
部分中。 未绑定的字段显示在afUnoundData
部分中。
<?xml ?>
<afData>
<afUnboundData>
<data>
<field1>value</field2>
<repeatablePanel>
<field2>value</field2>
</repeatablePanel>
<repeatablePanel>
<field2>value</field2>
</repeatablePanel>
</data>
</afUnboundData>
<afBoundData>
<!-- xml corresponding to the Form Model /XML Schema -->
</afBoundData>
</afData>
操作字段 action-fields
提交操作可以将隐藏的输入字段(使用HTMLinput标记)添加到渲染的表单HTML。 这些隐藏字段可以包含处理表单提交时所需的值。 在提交表单时,这些字段值作为请求参数回发,提交操作可在提交处理期间使用这些参数。 输入字段称为操作字段。
例如,如果提交操作还捕获填写表单所用的时间,则可以添加隐藏的输入字段startTime
和endTime
。
脚本可分别在表单渲染时和表单提交之前提供startTime
和endTime
字段的值。 然后,提交操作脚本post.jsp
可以使用请求参数访问这些字段,并计算填写表单所需的总时间。
文件附件 file-attachments
“提交操作”还可以使用您通过“文件附件”组件上传的文件附件。 提交操作脚本可以使用sling RequestParameter API访问这些文件。 API的isFormField方法有助于识别请求参数是文件还是表单字段。 您可以在“提交操作”中对“请求”参数进行迭代,以确定“文件附件”参数。
以下示例代码标识请求中的文件附件。 接下来,它使用获取API将数据读取到文件中。 最后,它会使用数据创建一个Document对象,并将其附加到列表中。
RequestParameterMap requestParameterMap = slingRequest.getRequestParameterMap();
for (Map.Entry<String, RequestParameter[]> param : requestParameterMap.entrySet()) {
RequestParameter rpm = param.getValue()[0];
if(!rpm.isFormField()) {
fileAttachments.add(new Document(rpm.get()));
}
}
将文件附加到自适应表单时,服务器会在提交自适应表单后验证文件附件,并在以下情况下返回错误消息:
-
文件附件包括以(.)开头的文件名 字符,包含\ / : * ? “ < > | ; % $,或包含为Windows操作系统保留的特殊文件名,如
nul
、prn
、con
、lpt
或com
。 -
文件附件的大小为0字节。
-
在自适应表单中配置文件附件组件时,支持的文件类型部分中未定义文件附件的格式。
转发路径和重定向URL forward-path-and-redirect-url
执行所需的操作后,提交servlet将请求转发到转发路径。 一个操作使用setForwardPath API在指南提交servlet中设置转发路径。
如果操作不提供转发路径,则提交Servlet将使用重定向URL重定向浏览器。 作者使用“自适应表单编辑”对话框中的“感谢页面”配置来配置重定向URL。 您还可以通过提交操作或指南提交servlet中的setRedirectUrl API配置重定向URL。 您还可以使用指南提交servlet中的setRedirectParameters API配置发送到重定向URL的请求参数。
提交操作 submit-action
提交操作是一个sling:Folder,它包括以下内容:
-
addfields.jsp:此脚本提供在呈现版本期间添加到HTML文件中的操作字段。 此脚本用于在post.context.jsp脚本中添加提交期间所需的POST输入参数。
-
dialog.xml:此脚本类似于CQ组件对话框。 它提供作者自定义的配置信息。 选择提交操作后,这些字段显示在“自适应表单编辑”对话框的“提交操作”选项卡中。
-
POST post.servlet.jsp:“提交”Servlet调用此脚本,其中包含您提交的数据以及前面几节中的其他数据。 本页中有关运行操作的任何内容都表示运行post.post.jspPOST。 Forms要将提交操作注册到自适应表单以在“自适应表单编辑”对话框中显示,请将这些属性添加到
sling:Folder
:-
类型为String的 guideComponentType,值为 fd/af/components/guidesubmittype
-
guideDataModel,类型为String,它指定提交操作适用的自适应表单的类型。 基于XSD的自适应Forms支持xsd。 不使用XDP或XSD的自适应Forms支持 basic。 要在多种类型的自适应Forms上显示操作,请添加相应的字符串。 用逗号分隔每个字符串。 例如,要使某个操作在基于XSD的自适应Forms上可见,请将该值指定为 xsd。
-
字符串类型的 jcr:description。 此属性的值显示在“自适应表单编辑”对话框的“提交操作”选项卡的“提交操作”列表中。 OOTB操作存在于CRX存储库中的位置 /libs/fd/af/components/guidesubmittype。
-
类型为“字符串”的 submitService。 有关详细信息,请参阅计划自定义操作的自适应表单提交。
-
创建自定义提交操作 creating-a-custom-submit-action
执行以下步骤可创建自定义提交操作,将数据保存在CRX存储库中,并向您发送电子邮件。 自适应表单包含OOTB提交操作存储内容(已弃用),可将数据保存在CRX存储库中。 此外,AEM还提供可用于发送电子邮件的邮件 API。 在使用Mail API之前,通过系统控制台配置Day CQ Mail服务。 您可以重用“存储内容(已弃用)”操作将数据存储在存储库中。 在CRX存储库中的/libs/fd/af/components/guidesubmittype/store位置提供了“存储内容(已弃用)”操作。
-
登录到URL https://<server>:<port>/crx/de/index.jsp上的CRXDE Lite。 在/apps/custom_submit_action文件夹中创建具有属性sling:Folder并命名为store_and_mail的节点。 创建custom_submit_action文件夹(如果尚不存在)。
的节点的屏幕截图
-
提供必需的配置字段。
添加存储区操作所需的配置。 将“存储”操作的 cq:dialog 节点从/libs/fd/af/components/guidesubmittype/store复制到/apps/custom_submit_action/store_and_email上的操作文件夹。
-
提供配置字段以提示作者配置电子邮件。
自适应表单还提供向用户发送电子邮件的电子邮件操作。 根据您的要求自定义此操作。 导航到/libs/fd/af/components/guidessubmittype/email/dialog。 将cq:dialog节点中的节点复制到提交操作(https://experienceleague.adobe.com/apps/custom_submit_action/store_and_email/dialog?lang=zh-Hans)的cq:dialog节点。
-
在“自适应表单编辑”对话框中提供操作。
在store_and_email节点中添加以下属性:
-
guideComponentType,类型为 String,值为 fd/af/components/guidesubmittype
-
guideDataModel,类型为 字符串,值为 xsd,基本
-
jcr:description,类型为 字符串,值为 存储和电子邮件操作
-
submitService,类型为 String,值为 Store and Email。 有关详细信息,请参阅计划自定义操作的自适应表单提交。
-
-
打开任意自适应表单。 单击 开始 旁边的 编辑 按钮以打开自适应表单容器的 编辑 对话框。 新操作显示在 提交操作 选项卡中。 选择 存储和电子邮件操作 将显示在对话框节点中添加的配置。
-
使用此操作完成任务。
将post.jsp.jspPOST添加到您的操作中。 (https://experienceleague.adobe.com/apps/custom_submit_action/store_and_mail/?lang=zh-Hans)。
运行OOTB Store操作(post.store.jspPOST)。 使用CQ在您的代码中提供的FormsHelper.runAction(java.lang.String, java.lang.String, org.apache.sling.api.resource.Resource, org.apache.sling.api.SlingHttpServletRequest, org.apache.sling.api.SlingHttpServletResponse) API来运行存储操作。 在JSP文件中添加以下代码:
FormsHelper.runAction("/libs/fd/af/components/guidesubmittype/store", "post", resource, slingRequest, slingResponse);
要发送电子邮件,代码会从配置中读取收件人的电子邮件地址。 要获取操作脚本中的配置值,请使用以下代码读取当前资源的属性。 同样,您可以读取其他配置文件。
ValueMap properties = ResourceUtil.getValueMap(resource);
String mailTo = properties.get("mailTo");
最后,使用CQ Mail API发送电子邮件。 使用SimpleEmail类创建电子邮件对象,如下所述:
note note NOTE 确保JSP文件的名称是post.pository.jspPOST。 code language-java <%@include file="/libs/fd/af/components/guidesglobal.jsp" %> <%@page import="com.day.cq.wcm.foundation.forms.FormsHelper, org.apache.sling.api.resource.ResourceUtil, org.apache.sling.api.resource.ValueMap, com.day.cq.mailer.MessageGatewayService, com.day.cq.mailer.MessageGateway, org.apache.commons.mail.Email, org.apache.commons.mail.SimpleEmail" %> <%@taglib prefix="sling" uri="https://sling.apache.org/taglibs/sling/1.0" %> <%@taglib prefix="cq" uri="https://www.day.com/taglibs/cq/1.0" %> <cq:defineObjects/> <sling:defineObjects/> <% String storeContent = "/libs/fd/af/components/guidesubmittype/store"; FormsHelper.runAction(storeContent, "post", resource, slingRequest, slingResponse); ValueMap props = ResourceUtil.getValueMap(resource); Email email = new SimpleEmail(); String[] mailTo = props.get("mailto", new String[0]); email.setFrom((String)props.get("from")); for (String toAddr : mailTo) { email.addTo(toAddr); } email.setMsg((String)props.get("template")); email.setSubject((String)props.get("subject")); MessageGatewayService messageGatewayService = sling.getService(MessageGatewayService.class); MessageGateway messageGateway = messageGatewayService.getGateway(SimpleEmail.class); messageGateway.send(email); %>
在自适应表单中选择操作。 该操作会发送电子邮件并存储数据。
将submitService属性用于自定义提交操作 submitservice-property
当您设置自定义提交操作(包括submitService
属性)时,表单会在提交时触发FormSubmitActionService。 FormSubmitActionService
使用getServiceName
方法检索submitService
属性的值。 根据submitService
属性的值,服务将调用相应的提交方法。 将FormSubmitActionService
包含到您上传到AEM Forms服务器的自定义捆绑包中。
将字符串类型的submitService
属性添加到自定义提交操作的sling:Folder
中,以便为自适应表单启用Adobe Sign。 只有在自定义提交操作的submitService
属性值设置完毕后,您才能在自适应表单容器属性的 电子签名 区域中选择 启用Adobe Sign 选项。