本文档中的示例和示例仅适用于AEM Forms on JEE环境。
位于服务容器中的AEM Forms服务(包括标准服务,如加密服务、长生命周期和短生命周期进程)可以使用各种提供程序(如EJB提供程序)调用。 通过EJB提供程序,可通过RMI/IIOP调用AEM Forms服务。 Web服务提供商使用SOAP/HTTP和SOAP/JMS等标准将服务公开为Web服务(WSDL生成)。
下表描述了以编程方式调用AEM Forms服务的各种方式。
调用方法 |
描述 |
---|---|
远程集成 |
远程集成使Flex客户端能够调用服务操作。 (请参阅 使用AEM Forms调用(已为AEM表单弃用) AEM Forms远程处理.) |
Java API |
Java API可以调用AEM Forms服务。 Java API被组织到客户端库和Java调用API中。 (请参阅 使用Java API调用AEM Forms.) |
Web服务 |
AEM Forms支持SOAP/HTTP等Web服务标准。 服务可以公开为Web服务,WSDL遵循W3C定义的Web服务标准。 可以从任何Web服务栈栈调用服务,包括.NET Framework和Sun™ Web Services SDK。 (请参阅 使用Web服务调用AEM Forms.) |
REST请求 |
AEM Forms支持REST请求。 可以直接从HTML页面调用服务。 (请参阅 使用REST请求调用AEM Forms.) |
下图直观地显示了以编程方式调用AEM Forms服务的各种方式。
除了使用AEM Forms SDK创建可以调用AEM Forms服务的客户端应用程序之外,您还可以创建可以部署到服务容器的组件。 例如,您可以创建包含可在流程中使用的自定义数据类型的银行组件。 也就是说,您可以创建一个数据类型,例如 com.adobe.idp.BankAccount
. 然后,您可以创建 com.adobe.idp.BankAccount
客户端应用程序中的实例。
服务容器提供以下功能:
允许使用其他方法调用AEM Forms服务。 您可以通过设置端点来配置服务,以便可以使用所有方法调用该服务:远程处理、Java API、Web服务和REST。 (请参阅 以编程方式管理端点.)
将消息转换为称为调用请求的规范化格式。 调用请求从客户端应用程序(或其它服务)发送到位于服务容器中的服务。 调用请求包含要调用的服务名称和执行操作所需的数据值等信息。 许多服务都需要文档来执行操作。 因此,一个调用请求通常包含一个文档,可以是PDF数据、XDP数据、XML数据等。
将调用请求路由到适当的服务(要调用的服务的名称是调用请求的一部分)。
执行诸如确定调用方是否具有调用指定服务操作的权限之类的任务。 调用请求必须包含有效的AEM Forms用户名和密码。
有多种不同的方法可以将调用请求发送到服务。 此外,还有不同的方法可以将所需的输入值发送到服务。 例如,假设您使用Java API调用需要PDF文档的服务。 相应的Java方法包含一个接受PDF文档的参数。 在这种情况下,参数的数据类型为 com.adobe.idp.Document
. (请参阅 使用Java API将数据传递到AEM Forms服务.)
如果您使用watched文件夹调用服务,则当您将文件放在配置的watched文件夹中时,会发送调用请求。 如果使用电子邮件调用服务,则当电子邮件到达配置的收件箱时,会向服务发送调用请求。
执行操作后,服务容器会发送回调用响应。 调用响应包含操作结果等信息。 例如,如果操作修改了PDF文档,则调用响应将包含修改后的PDF文档。 如果操作不成功,则调用响应将包含错误消息。
可以通过发送调用请求的相同方式来检索调用响应。 也就是说,如果使用Java API发送调用请求,则可以使用Java API检索调用响应。 例如,假定操作修改了PDF文档。 您可以通过获取调用服务的Java方法的返回值来检索修改后的PDF文档。
在调用长期进程时,调用响应将包含与调用请求关联的标识符值。 使用此标识符值,您可以稍后检查进程的状态。 例如,以MortgageLoan长期服务为例。 使用标识符值,您可以检查以确定进程是否成功完成。 (请参阅 调用以人为中心的长期进程.)
下图显示调用服务的客户端应用程序(使用Java API)。
当客户端应用程序调用服务时,会发生三个事件:
另请参阅
使用AEM Forms调用(已为AEM表单弃用) AEM Forms远程处理