Java API를 사용하여 AEM Forms 호출 invoking-aem-forms-using-the-javaapi
AEM Forms Java API를 사용하여 AEM Forms을 호출할 수 있습니다. AEM Forms Java API를 사용할 때 호출 API 또는 Java 클라이언트 라이브러리를 사용할 수 있습니다. Java 클라이언트 라이브러리는 Rights Management 서비스와 같은 서비스에 사용할 수 있습니다. 이러한 강력한 형식의 API를 사용하면 AEM Forms을 호출하는 Java 애플리케이션을 개발할 수 있습니다.
Invocation API는 com.adobe.idp.dsc
패키지. 이러한 클래스를 사용하여 서비스에 직접 호출 요청을 보내고 반환된 호출 응답을 처리할 수 있습니다. Workbench를 사용하여 만든 단기 또는 장기 프로세스를 호출하려면 호출 API를 사용하십시오.
서비스를 프로그래밍 방식으로 호출하는 데 권장되는 방법은 호출 API가 아니라 서비스에 해당하는 Java 클라이언트 라이브러리를 사용하는 것입니다. 예를 들어, 암호화 서비스를 호출하려면 암호화 서비스 클라이언트 라이브러리를 사용합니다. 암호화 서비스 작업을 수행하려면 암호화 서비스 클라이언트 개체에 속하는 메서드를 호출합니다. 암호를 사용하여 PDF 문서를 암호화할 수 있습니다 EncryptionServiceClient
개체 encryptPDFUsingPassword
메서드를 사용합니다.
Java API는 다음 기능을 지원합니다.
- 원격 호출을 위한 RMI 전송 프로토콜
- 로컬 호출을 위한 VM 전송
- 원격 호출을 위한 SOAP
- 사용자 이름 및 암호와 같은 다른 인증
- 동기 및 비동기 호출 요청
추가 참조
Java API를 사용하여 AEM Forms 서비스에 데이터 전달
인간 중심 장기 프로세스를 호출하는 Java 웹 애플리케이션 만들기
AEM Forms Java 라이브러리 파일 포함 including-aem-forms-java-library-files
Java API를 사용하여 AEM Forms 서비스를 프로그래밍 방식으로 호출하려면 Java 프로젝트의 클래스 경로에 필수 라이브러리 파일(JAR 파일)을 포함합니다. 클라이언트 애플리케이션의 클래스 경로에 포함하는 JAR 파일은 다음과 같은 몇 가지 요소에 따라 다릅니다.
- 호출할 AEM Forms 서비스. 클라이언트 응용 프로그램은 하나 이상의 서비스를 호출할 수 있습니다.
- AEM Forms 서비스를 호출할 모드입니다. EJB 또는 SOAP 모드를 사용할 수 있습니다. (자세한 내용은 연결 속성 설정)
standalone.bat -b <Server IP> -c lc_turnkey.xml
EJB에 대한 서버 IP를 지정하려면- AEM Forms이 배포되는 J2EE 애플리케이션 서버입니다.
서비스별 JAR 파일 service-specific-jar-files
다음 표에는 AEM Forms 서비스를 호출하는 데 필요한 JAR 파일이 나와 있습니다.
adobe-repository-client.jar
commons-codec-1.3.jar
<설치 디렉토리>/sdk/client-libs/common
<설치 디렉토리>/sdk/client-libs\thirdparty
-
adobe-rightsmanagement-client.jar
-
namespace.jar
-
jaxb-api.jar
-
jaxb-impl.jar
-
jaxb-libs.jar
-
jaxb-xjc.jar
-
relaxngDatatype.jar
-
xsdlib.jar
Rights Management 서비스를 호출하는 데 필요합니다.
AEM Forms이 JBoss에 배포된 경우 이러한 파일을 모두 포함합니다.
<설치 디렉토리>/sdk/client-libs/common
JBoss-specific lib 디렉토리
연결 모드 및 J2EE 응용 프로그램 JAR 파일 connection-mode-and-j2ee-application-jar-files
다음 표에는 연결 모드에 따라 달라지는 JAR 파일과 AEM Forms이 배포된 J2EE 애플리케이션 서버가 나열되어 있습니다.
</thead align="left">
-
activation.jar
-
axis.jar
-
commons-codec-1.3.jar
-
commons-collections-3.1.jar
-
commons-discovery.jar
-
commons-logging.jar
-
dom3-xml-apis-2.5.0.jar
-
jaxen-1.1-beta-9.jar
-
jaxrpc.jar
-
log4j.jar
-
mail.jar
-
saaj.jar
-
wsdl4j.jar
-
xalan.jar
-
xbean.jar
- xercesImpl.jar
- commons-httpclient-3.1.jar
AEM Forms이 JBoss Application Server에 배포된 경우 이 JAR 파일을 포함하십시오.
jboss-client.jar 및 참조된 jar이 함께 있지 않으면 classloader에서 필수 클래스를 찾을 수 없습니다.
JBoss 클라이언트 라이브러리 디렉토리
동일한 J2EE 애플리케이션 서버에 클라이언트 응용 프로그램을 배포하는 경우 이 파일을 포함할 필요가 없습니다.
WebLogic-specific lib 디렉토리
동일한 J2EE 애플리케이션 서버에 클라이언트 응용 프로그램을 배포하는 경우 이 파일을 포함할 필요가 없습니다.
-
com.ibm.ws.admin.client_6.1.0.jar
-
com.ibm.ws.webservices.thinclient_6.1.0.jar
-
AEM Forms이 WebSphere Application Server에 배포된 경우 이러한 JAR 파일을 포함합니다.
-
(com.ibm.ws.webservices.thinclient_6.1.0.jar는 웹 서비스 호출에 필요합니다.)
WebSphere 특정 lib 디렉토리([WAS_HOME]/runtimes)
동일한 J2EE 애플리케이션 서버에 클라이언트 응용 프로그램을 배포하는 경우 이러한 파일을 포함할 필요가 없습니다.
시나리오 호출 invoking-scenarios
다음 표는 시나리오 호출을 지정하고 AEM Forms을 성공적으로 호출하는 데 필요한 JAR 파일을 나열합니다.
</thead align="left"> xmp-uti
-
adobe-livecycle-client.jar
-
adobe-usermanager-client.jar
- jboss-client.jar
- adobe-forms-client.jar
- commons-httpclient-3.1.jar
Forms 서비스
Acrobat Reader DC 확장 서비스
서명 서비스
-
adobe-livecycle-client.jar
-
adobe-usermanager-client.jar
- jboss-client.jar
- commons-httpclient-3.1.jar
-
adobe-forms-client.jar
-
adobe-reader-extensions-client.jar
-
adobe-signatures-client.jar
-
adobe-livecycle-client.jar
-
adobe-usermanager-client.jar
-
wlclient.jar
-
activation.jar
-
axis.jar
-
commons-codec-1.3.jar
-
commons-collections-3.1.jar
-
commons-discovery.jar
-
commons-logging.jar
-
dom3-xml-apis-2.5.0.jar
-
jai_imageio.jar
-
jaxen-1.1-beta-9.jar
-
jaxrpc.jar
-
log4j.jar
-
mail.jar
-
saaj.jar
-
wsdl4j.jar
-
xalan.jar
-
xbean.jar
-
xercesImpl.jar
-
adobe-forms-client.jar
Forms 서비스
Acrobat Reader DC 확장 서비스
서명 서비스
-
adobe-livecycle-client.jar
-
adobe-usermanager-client.jar
-
wlclient.jar
-
activation.jar
-
axis.jar
-
commons-codec-1.3.jar
-
commons-collections-3.1.jar
-
commons-discovery.jar
-
commons-logging.jar
-
dom3-xml-apis-2.5.0.jar
-
jai_imageio.jar
-
jaxen-1.1-beta-9.jar
-
jaxrpc.jar
-
log4j.jar
-
mail.jar
-
saaj.jar
-
wsdl4j.jar
-
xalan.jar
-
xbean.jar
-
xercesImpl.jar
-
adobe-forms-client.jar
-
adobe-reader-extensions-client.jar
-
adobe-signatures-client.jar
JAR 파일 업그레이드 upgrading-jar-files
LiveCycle에서 AEM Forms으로 업그레이드하는 경우 Java 프로젝트의 클래스 경로에 AEM Forms JAR 파일을 포함하는 것이 좋습니다. 예를 들어 Rights Management 서비스와 같은 서비스를 사용하는 경우 클래스 경로에 AEM Forms JAR 파일을 포함하지 않으면 호환성 문제가 발생합니다.
AEM Forms으로 업그레이드한다고 가정합니다. Rights Management 서비스를 호출하는 Java 응용 프로그램을 사용하려면 다음 JAR 파일의 AEM Forms 버전을 포함하십시오.
- adobe-rightsmanagement-client.jar
- adobe-livecycle-client.jar
- adobe-usermanager-client.jar
추가 참조
Java API를 사용하여 AEM Forms 서비스에 데이터 전달
연결 속성 설정 setting-connection-properties
Java API를 사용할 때 AEM Forms을 호출하도록 연결 속성을 설정합니다. 연결 속성을 설정할 때 서비스를 원격으로 호출할지 로컬로 호출할지 여부를 지정하고 연결 모드 및 인증 값도 지정합니다. 서비스 보안이 활성화된 경우 인증 값이 필요합니다. 그러나 서비스 보안이 비활성화된 경우에는 인증 값을 지정할 필요가 없습니다.
연결 모드는 SOAP 또는 EJB 모드일 수 있습니다. EJB 모드는 RMI/IIOP 프로토콜을 사용하며 EJB 모드의 성능은 SOAP 모드의 성능보다 좋습니다. SOAP 모드는 J2EE 애플리케이션 서버 종속성을 제거하거나 방화벽이 AEM Forms과 클라이언트 애플리케이션 사이에 있을 때 사용합니다. SOAP 모드는 https 프로토콜을 기본 전송으로 사용하고 방화벽 경계를 넘어 통신할 수 있습니다. J2EE 응용 프로그램 서버 종속성 또는 방화벽이 모두 문제가 아닌 경우 EJB 모드를 사용하는 것이 좋습니다.
AEM Forms 서비스를 성공적으로 호출하려면 다음 연결 속성을 설정하십시오.
-
DSC_DEFAULT_EJB_ENDPOINT: EJB 연결 모드를 사용하는 경우 이 값은 AEM Forms이 배포된 J2EE 응용 프로그램 서버의 URL을 나타냅니다. AEM Forms을 원격으로 호출하려면 AEM Forms이 배포되는 J2EE 애플리케이션 서버 이름을 지정합니다. 클라이언트 응용 프로그램이 동일한 J2EE 응용 프로그램 서버에 있는 경우
localhost
. J2EE 애플리케이션 서버 AEM Forms이 배포되는 위치에 따라 다음 값 중 하나를 지정합니다.- JBoss:
https://<ServerName>:8080 (default port)
- WebSphere:
iiop://<ServerName>:2809 (default port)
- WebLogic:
t3://<ServerName>:7001 (default port)
- JBoss:
-
DSC_DEFAULT_SOAP_ENDPOINT: SOAP 연결 모드를 사용하는 경우 이 값은 호출 요청이 전송되는 종단점을 나타냅니다. AEM Forms을 원격으로 호출하려면 AEM Forms이 배포되는 J2EE 애플리케이션 서버 이름을 지정합니다. 클라이언트 응용 프로그램이 동일한 J2EE 응용 프로그램 서버에 있는 경우
localhost
(예:http://localhost:8080
)- 포트 값
8080
J2EE 애플리케이션이 JBoss인 경우 적용 가능합니다. J2EE 응용 프로그램 서버가 IBM® WebSphere®인 경우 포트를 사용합니다9080
. 마찬가지로 J2EE 응용 프로그램 서버가 WebLogic이면 포트를 사용합니다7001
. 이 값은 기본 포트 값입니다. 포트 값을 변경할 경우 해당 포트 번호를 사용합니다.)
- 포트 값
-
DSC_TRANSPORT_PROTOCOL: EJB 연결 모드를 사용하는 경우
ServiceClientFactoryProperties.DSC_EJB_PROTOCOL
참조하십시오. SOAP 연결 모드를 사용하는 경우ServiceClientFactoryProperties.DSC_SOAP_PROTOCOL
. -
DSC_SERVER_TYPE: AEM Forms이 배포되는 J2EE 애플리케이션 서버를 지정합니다. 유효한 값은
JBoss
,WebSphere
,WebLogic
.- 이 연결 속성을
WebSphere
,java.naming.factory.initial
값이com.ibm.ws.naming.util.WsnInitCtxFactory
. - 이 연결 속성을
WebLogic
,java.naming.factory.initial
값이weblogic.jndi.WLInitialContextFactory
. - 마찬가지로, 이 연결 속성을
JBoss
,java.naming.factory.initial
값이org.jnp.interfaces.NamingContextFactory
. - 을(를) 설정할 수 있습니다
java.naming.factory.initial
기본값을 사용하지 않으려는 경우 요구 사항을 충족하는 값에 속성을 설정합니다.
note note NOTE 문자열을 사용하여 DSC_SERVER_TYPE
연결 등록 정보에서는ServiceClientFactoryProperties
클래스 이름을 지정합니다. 다음 값을 사용할 수 있습니다.ServiceClientFactoryProperties.DSC_WEBSPHERE_SERVER_TYPE
,ServiceClientFactoryProperties.DSC_WEBLOGIC_SERVER_TYPE
, 또는ServiceClientFactoryProperties.DSC_JBOSS_SERVER_TYPE
. - 이 연결 속성을
-
DSC_CREDENTIAL_USERNAME: AEM Forms 사용자 이름을 지정합니다. 사용자가 AEM Forms 서비스를 성공적으로 호출하려면 서비스 사용자 역할이 필요합니다. 사용자는 서비스 호출 권한을 포함하는 다른 역할을 가질 수도 있습니다. 그렇지 않으면 서비스를 호출하려고 할 때 예외가 발생합니다. 서비스 보안이 비활성화된 경우에는 이 연결 속성을 지정할 필요가 없습니다.
-
DSC_CREDENTIAL_PASSWORD: 해당 암호 값을 지정합니다. 서비스 보안이 비활성화된 경우에는 이 연결 속성을 지정할 필요가 없습니다.
-
DSC_REQUEST_TIMEOUT: SOAP 요청에 대한 기본 요청 시간 제한1200000 밀리초(20분)입니다. 때로는 요청이 작업을 완료하는 데 시간이 더 걸릴 수 있습니다. 예를 들어 큰 레코드 세트를 검색하는 SOAP 요청에는 더 긴 시간 제한 제한이 필요할 수 있습니다. 를 사용할 수 있습니다
ServiceClientFactoryProperties.DSC_REQUEST_TIMEOUT
를 추가하여 SOAP 요청에 대한 요청 호출 시간 제한 제한을 늘립니다.note note NOTE SOAP 기반 호출만 DSC_REQUEST_TIMEOUT 속성을 지원합니다.
연결 속성을 설정하려면 다음 작업을 수행합니다.
-
만들기
java.util.Properties
생성자를 사용하여 개체를 작성합니다. -
를 설정하려면
DSC_DEFAULT_EJB_ENDPOINT
연결 속성, 호출java.util.Properties
개체setProperty
메서드를 사용하여 다음 값을 전달합니다.- 다음
ServiceClientFactoryProperties.DSC_DEFAULT_EJB_ENDPOINT
열거형 값 - AEM Forms을 호스팅하는 J2EE 애플리케이션 서버의 URL을 지정하는 문자열 값입니다
note note NOTE SOAP 연결 모드를 사용하는 경우 ServiceClientFactoryProperties.DSC_DEFAULT_SOAP_ENDPOINT
열거형 값 대신ServiceClientFactoryProperties.DSC_DEFAULT_EJB_ENDPOINT
열거형 값. - 다음
-
를 설정하려면
DSC_TRANSPORT_PROTOCOL
연결 속성, 호출java.util.Properties
개체setProperty
메서드를 사용하여 다음 값을 전달합니다.- 다음
ServiceClientFactoryProperties.DSC_TRANSPORT_PROTOCOL
열거형 값 - 다음
ServiceClientFactoryProperties.DSC_EJB_PROTOCOL
열거형 값
note note NOTE SOAP 연결 모드를 사용하는 경우 ServiceClientFactoryProperties.DSC_SOAP_PROTOCOL
열거형 값 대신ServiceClientFactoryProperties.DSC_EJB_PROTOCOL
열거형 값. - 다음
-
를 설정하려면
DSC_SERVER_TYPE
연결 속성, 호출java.util.Properties
개체setProperty
메서드를 사용하여 다음 값을 전달합니다.-
다음
ServiceClientFactoryProperties.DSC_SERVER_TYPE
열거형 값 -
AEM Forms을 호스팅하는 J2EE 애플리케이션 서버를 지정하는 문자열 값(예: AEM Forms이 JBoss에 배포되는 경우)을 지정합니다.
JBoss
).- 를 설정하려면
DSC_CREDENTIAL_USERNAME
연결 속성, 호출java.util.Properties
개체setProperty
메서드를 사용하여 다음 값을 전달합니다.
- 를 설정하려면
-
다음
ServiceClientFactoryProperties.DSC_CREDENTIAL_USERNAME
열거형 값 -
AEM Forms을 호출하는 데 필요한 사용자 이름을 지정하는 문자열 값입니다
- 를 설정하려면
DSC_CREDENTIAL_PASSWORD
연결 속성, 호출java.util.Properties
개체setProperty
메서드를 사용하여 다음 값을 전달합니다.
- 를 설정하려면
-
다음
ServiceClientFactoryProperties.DSC_CREDENTIAL_PASSWORD
열거형 값 -
해당 암호 값을 지정하는 문자열 값
-
JBoss에 대한 EJB 연결 모드 설정
다음 Java 코드 예제에서는 연결 속성을 설정하여 JBoss에 배치된 AEM Forms을 호출하고 EJB 연결 모드를 사용합니다.
Properties ConnectionProps = new Properties();
ConnectionProps.setProperty(ServiceClientFactoryProperties.DSC_DEFAULT_EJB_ENDPOINT, "https://<hostname>:8080");
ConnectionProps.setProperty(ServiceClientFactoryProperties.DSC_TRANSPORT_PROTOCOL,ServiceClientFactoryProperties.DSC_EJB_PROTOCOL);
ConnectionProps.setProperty(ServiceClientFactoryProperties.DSC_SERVER_TYPE, "JBoss");
ConnectionProps.setProperty(ServiceClientFactoryProperties.DSC_CREDENTIAL_USERNAME, "administrator");
ConnectionProps.setProperty(ServiceClientFactoryProperties.DSC_CREDENTIAL_PASSWORD, "password");
ConnectionProps.setProperty(ServiceClientFactoryProperties.DSC_DOCUMENT_HTTP_ENDPOINT,"https://<hostname>:8080");
WebLogic에 대한 EJB 연결 모드 설정
다음 Java 코드 예제에서는 WebLogic에 배치된 AEM Forms을 호출하고 EJB 연결 모드를 사용하여 연결 속성을 설정합니다.
Properties ConnectionProps = new Properties();
ConnectionProps.setProperty(ServiceClientFactoryProperties.DSC_DEFAULT_EJB_ENDPOINT, "t3://localhost:7001");
ConnectionProps.setProperty(ServiceClientFactoryProperties.DSC_TRANSPORT_PROTOCOL,ServiceClientFactoryProperties.DSC_EJB_PROTOCOL);
ConnectionProps.setProperty(ServiceClientFactoryProperties.DSC_SERVER_TYPE, "WebLogic");
ConnectionProps.setProperty(ServiceClientFactoryProperties.DSC_CREDENTIAL_USERNAME, "administrator");
ConnectionProps.setProperty(ServiceClientFactoryProperties.DSC_CREDENTIAL_PASSWORD, "password");
WebSphere에 대한 EJB 연결 모드 설정
다음 Java 코드 예제에서는 연결 속성을 설정하여 WebSphere에 배치된 AEM Forms을 호출하고 EJB 연결 모드를 사용합니다.
Properties ConnectionProps = new Properties();
ConnectionProps.setProperty(ServiceClientFactoryProperties.DSC_DEFAULT_EJB_ENDPOINT, "iiop://localhost:2809");
ConnectionProps.setProperty(ServiceClientFactoryProperties.DSC_TRANSPORT_PROTOCOL,ServiceClientFactoryProperties.DSC_EJB_PROTOCOL);
ConnectionProps.setProperty(ServiceClientFactoryProperties.DSC_SERVER_TYPE, "WebSphere");
ConnectionProps.setProperty(ServiceClientFactoryProperties.DSC_CREDENTIAL_USERNAME, "administrator");
ConnectionProps.setProperty(ServiceClientFactoryProperties.DSC_CREDENTIAL_PASSWORD, "password");
SOAP 연결 모드 설정
다음 Java 코드 예제에서는 SOAP 모드에서 연결 속성을 설정하여 JBoss에 배포된 AEM Forms을 호출합니다.
Properties ConnectionProps = new Properties();
ConnectionProps.setProperty(ServiceClientFactoryProperties.DSC_DEFAULT_SOAP_ENDPOINT, "http://localhost:8080");
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");
서비스 보안을 사용하지 않도록 설정할 때 연결 속성 설정
다음 Java 코드 예제에서는 JBoss Application Server에 배포된 AEM Forms을 호출하는 데 필요한 연결 속성을 설정하고 서비스 보안을 사용하지 않도록 설정할 수 있습니다.
Properties ConnectionProps = new Properties();
ConnectionProps.setProperty(ServiceClientFactoryProperties.DSC_DEFAULT_EJB_ENDPOINT, "jnp://localhost:1099");
ConnectionProps.setProperty(ServiceClientFactoryProperties.DSC_TRANSPORT_PROTOCOL,ServiceClientFactoryProperties.DSC_EJB_PROTOCOL);
ConnectionProps.setProperty(ServiceClientFactoryProperties.DSC_SERVER_TYPE, "JBoss");
사용자 지정 요청 시간 초과 제한을 사용하여 SOAP 연결 모드 설정
Properties ConnectionProps = new Properties();
ConnectionProps.setProperty(ServiceClientFactoryProperties.DSC_DEFAULT_SOAP_ENDPOINT, "http://localhost:8080");
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");
ConnectionProps.setProperty(ServiceClientFactoryProperties.DSC_REQUEST_TIMEOUT, "1800000"); // Request timeout limit 30 Minutes
컨텍스트 개체를 사용하여 AEM Forms 호출
을(를) 사용할 수 있습니다 com.adobe.idp.Context
인증된 사용자로 AEM Forms 서비스를 호출하는 개체(즉, com.adobe.idp.Context
개체는 인증된 사용자를 나타냅니다.) 사용 시 com.adobe.idp.Context
개체를 설정할 필요는 없습니다 DSC_CREDENTIAL_USERNAME
또는 DSC_CREDENTIAL_PASSWORD
속성을 사용합니다. 을 확인할 수 있습니다. com.adobe.idp.Context
개체를 사용하여 사용자를 인증할 때 개체 AuthenticationManagerServiceClient
개체 authenticate
메서드를 사용합니다.
다음 authenticate
메서드 반환 AuthResult
인증 결과가 포함된 객체입니다. 을(를) 만들 수 있습니다 com.adobe.idp.Context
개체를 생성자로 호출하여 개체를 가져옵니다. 그런 다음 com.adobe.idp.Context
개체 initPrincipal
메서드 및 전달 AuthResult
개체(다음 코드에 표시된 대로):
Context myCtx = new Context();
myCtx.initPrincipal(authResult);
를 설정하는 대신 DSC_CREDENTIAL_USERNAME
또는 DSC_CREDENTIAL_PASSWORD
속성을 호출하면 ServiceClientFactory
개체 setContext
메서드 및 전달 com.adobe.idp.Context
개체. AEM Forms 사용자를 사용하여 서비스를 호출하는 경우 해당 사용자에게 라는 역할이 있는지 확인하십시오 Services User
AEM Forms 서비스를 호출하는 데 필요합니다.
다음 코드 예는 를 사용하는 방법을 보여줍니다. com.adobe.idp.Context
를 만드는 데 사용되는 연결 설정 내의 개체 EncryptionServiceClient
개체.
//Authenticate a user and use the Context object within connection settings
// Authenticate the user
String username = "wblue";
String password = "password";
AuthResult authResult = authClient.authenticate(username, password.getBytes());
//Set a Content object that represents the authenticated user
//Use the Context object to invoke the Encryption service
Context myCtx = new Context();
myCtx.initPrincipal(authResult);
//Set connection settings
Properties connectionProps = new Properties();
connectionProps.setProperty(ServiceClientFactoryProperties.DSC_DEFAULT_EJB_ENDPOINT, "jnp://<server>:1099");
connectionProps.setProperty(ServiceClientFactoryProperties.DSC_TRANSPORT_PROTOCOL, ServiceClientFactoryProperties.DSC_EJB_PROTOCOL);
connectionProps.setProperty(ServiceClientFactoryProperties.DSC_SERVER_TYPE, ServiceClientFactoryProperties.DSC_JBOSS_SERVER_TYPE);
connectionProps.setProperty(ServiceClientFactoryProperties.DSC_DOCUMENT_HTTP_ENDPOINT,"jnp://<server>:1099");
//Create a ServiceClientFactory object
ServiceClientFactory myFactory = ServiceClientFactory.createInstance(connectionProps);
myFactory.setContext(myCtx);
//Create an EncryptionServiceClient object
EncryptionServiceClient encryptClient = new EncryptionServiceClient(myFactory);
시나리오 호출 invoking_scenarios-1
이 섹션에서는 다음 호출 시나리오에 대해 설명합니다.
- 자체 JVM(Java Virtual Machine)에서 실행되는 클라이언트 애플리케이션은 독립형 AEM Forms 인스턴스를 호출합니다.
- 자체 JVM에서 실행되는 클라이언트 애플리케이션은 클러스터형 AEM Forms 인스턴스를 호출합니다.
독립형 AEM Forms 인스턴스를 호출하는 클라이언트 애플리케이션 client-application-invoking-a-stand-alone-aem-forms-instance
다음 다이어그램은 자체 JVM에서 실행되는 클라이언트 응용 프로그램과 독립형 AEM Forms 인스턴스를 호출하는 것을 보여 줍니다.
이 시나리오에서는 클라이언트 애플리케이션이 자체 JVM에서 실행되고 AEM Forms 서비스를 호출합니다.
클러스터된 AEM Forms 인스턴스를 호출하는 클라이언트 애플리케이션 client-application-invoking-clustered-aem-forms-instances
다음 다이어그램은 자체 JVM에서 실행되는 클라이언트 응용 프로그램과 클러스터에 있는 AEM Forms 인스턴스를 호출하는 것을 보여 줍니다.
이 시나리오는 독립형 AEM Forms 인스턴스를 호출하는 클라이언트 애플리케이션과 유사합니다. 그러나 공급자 URL은 다릅니다. 클라이언트 응용 프로그램이 특정 J2EE 응용 프로그램 서버에 연결하려는 경우 응용 프로그램은 특정 J2EE 응용 프로그램 서버를 참조하도록 URL을 변경해야 합니다.
애플리케이션 서버가 중지되면 클라이언트 애플리케이션과 AEM Forms 간의 연결이 종료되므로 특정 J2EE 애플리케이션 서버를 참조하지 않는 것이 좋습니다. 공급자 URL은 특정 J2EE 애플리케이션 서버 대신 셀 수준 JNDI 관리자를 참조하는 것이 좋습니다.
SOAP 연결 모드를 사용하는 클라이언트 응용 프로그램은 클러스터에 대해 HTTP 로드 밸런서 포트를 사용할 수 있습니다. EJB 연결 모드를 사용하는 클라이언트 응용 프로그램은 특정 J2EE 응용 프로그램 서버의 EJB 포트에 연결할 수 있습니다. 이 작업은 클러스터 노드 간의 로드 밸런싱을 처리합니다.
WebSphere
다음 예제는 WebSphere에 배포된 AEM Forms에 연결하는 데 사용되는 jndi.properties 파일의 내용을 보여 줍니다.
java.naming.factory.initial=com.ibm.websphere.naming.
WsnInitialContextFactory
java.naming.provider.url=corbaloc::appserver1:9810,:appserver2:9810
WebLogic
다음 예제는 WebLogic에 배포되는 AEM Forms에 연결하는 데 사용되는 jndi.properties 파일의 내용을 보여 줍니다.
java.naming.factory.initial=weblogic.jndi.WLInitialContextFactory
java.naming.provider.url=t3://appserver1:8001, appserver2:8001
JBoss
다음 예제는 JBoss에 배포된 AEM Forms에 연결하는 데 사용되는 jndi.properties 파일의 컨텐츠를 보여줍니다.
java.naming.factory.initial= org.jnp.interfaces.NamingContextFactory
java.naming.provider.url= jnp://appserver1:1099, appserver2:1099,
appserver3:1099
추가 참조
Java API를 사용하여 AEM Forms 서비스에 데이터 전달
Java API를 사용하여 AEM Forms 서비스에 데이터 전달 passing-data-to-aem-forms-services-using-the-java-api
AEM Forms 서비스 작업은 일반적으로 PDF 문서를 소비하거나 생성합니다. 서비스를 호출할 때 경우에 따라 PDF 문서(또는 XML 데이터와 같은 기타 문서 유형)를 서비스에 전달해야 합니다. 마찬가지로 서비스에서 반환되는 PDF 문서를 처리해야 하는 경우가 있습니다. AEM Forms 서비스의 데이터를 전달 및 사용할 수 있는 Java 클래스는 다음과 같습니다 com.adobe.idp.Document
.
AEM Forms 서비스에서는 PDF 문서를 다른 데이터 유형(예: java.io.InputStream
개체 또는 바이트 배열입니다. A com.adobe.idp.Document
개체를 사용하여 XML 데이터와 같은 다른 유형의 데이터를 서비스에 전달할 수도 있습니다.
A com.adobe.idp.Document
객체는 Java 직렬화할 수 있는 유형이므로 RMI 호출을 통해 전달할 수 있습니다. 수신 측(동일한 호스트, 동일한 클래스 로더), 로컬(동일한 호스트, 다른 클래스 로더) 또는 원격(다른 호스트)이 있을 수 있습니다. 문서 컨텐츠 전달은 각 사례에 맞게 최적화되어 있습니다. 예를 들어 보낸 사람과 받은 사람이 동일한 호스트에 있는 경우 로컬 파일 시스템으로 컨텐츠를 전달합니다. (경우에 따라 문서를 메모리로 전달할 수 있습니다.)
에 따라 com.adobe.idp.Document
개체 크기, 데이터는 com.adobe.idp.Document
개체의 파일 시스템에 저장되어 있습니다. 에 의해 사용되는 모든 임시 스토리지 자원 com.adobe.idp.Document
개체는 자동으로 제거됩니다 com.adobe.idp.Document
폐기. (자세한 내용은 문서 객체 배치)
경우에 따라 com.adobe.idp.Document
객체에 대한 객체 전달 예를 들어 작업에 다음과 같은 특정 컨텐츠 유형이 필요한 경우 application/pdf
을 설정하는 것이 좋습니다. 컨텐츠 유형을 결정하는 것이 좋습니다. (자세한 내용은 문서의 컨텐트 유형 확인)
다음 com.adobe.idp.Document
개체는 제공된 데이터를 사용하여 콘텐츠 유형을 확인합니다. 제공된 데이터에서 컨텐츠 유형을 검색할 수 없는 경우(예: 데이터가 바이트 배열로 제공된 경우) 컨텐츠 유형을 설정하십시오. 컨텐츠 유형을 설정하려면 com.adobe.idp.Document
개체 setContentType
메서드를 사용합니다. (자세한 내용은 문서의 컨텐트 유형 확인)
자료 파일이 동일한 파일 시스템에 있는 경우 com.adobe.idp.Document
개체가 더 빠릅니다. 자료 파일이 원격 파일 시스템에 있는 경우 복사 작업을 수행해야 하므로 성능에 영향을 줍니다.
응용 프로그램에는 두 가지가 모두 포함될 수 있습니다 com.adobe.idp.Document
및 org.w3c.dom.Document
데이터 유형. 그러나 자격 조건을 완전히 충족하는지 확인합니다 org.w3c.dom.Document
데이터 유형. 변환 정보 org.w3c.dom.Document
개체 com.adobe.idp.Document
개체 빠른 시작(EJB 모드): Java API를 사용하여 유동형 레이아웃으로 Forms 미리 채우기.
com.adobe.idp.Document
개체, 문서 정보를 2048바이트 이하의 청크 단위로 읽습니다. 예를 들어 다음 코드는 2048바이트 청크 단위로 문서 정보를 읽습니다. // Set up the chunk size to prevent a potential memory leak
int buffSize = 2048;
// Determine the total number of bytes to read
int docLength = (int) inDoc.length();
byte [] byteDoc = new byte[docLength];
// Set up the reading position
int pos = 0;
// Loop through the document information, 2048 bytes at a time
while (docLength > 0) {
// Read the next chunk of information
int toRead = Math.min(buffSize, docLength);
int bytesRead = inDoc.read(pos, byteDoc, pos, toRead);
// Handle the exception in case data retrieval failed
if (bytesRead == -1) {
inDoc.doneReading();
inDoc.dispose();
throw new RuntimeException("Data retrieval failed!");
}
// Update the reading position and number of bytes remaining
pos += bytesRead;
docLength -= bytesRead;
}
// The document information has been successfully read
inDoc.doneReading();
inDoc.dispose();
추가 참조
문서 만들기 creating-documents
만들기 com.adobe.idp.Document
PDF 문서(또는 기타 문서 유형)를 입력 값으로 필요로 하는 서비스 작업을 호출하기 전에 객체를 호출합니다. 다음 com.adobe.idp.Document
클래스는 다음과 같은 컨텐츠 유형에서 문서를 만들 수 있는 생성자를 제공합니다.
- 바이트 배열
- 기존
com.adobe.idp.Document
개체 - A
java.io.File
개체 - A
java.io.InputStream
개체 - A
java.net.URL
개체
바이트 배열을 기반으로 문서 만들기 creating-a-document-based-on-a-byte-array
다음 코드 예제에서는 com.adobe.idp.Document
바이트 배열을 기반으로 하는 개체입니다.
바이트 배열을 기반으로 하는 Document 객체 만들기
Document myPDFDocument = new Document(myByteArray);
다른 문서를 기반으로 문서 만들기 creating-a-document-based-on-another-document
다음 코드 예제에서는 com.adobe.idp.Document
다른 개체를 기반으로 하는 개체 com.adobe.idp.Document
개체.
다른 문서를 기반으로 하는 문서 객체 만들기
//Create a Document object based on a byte array
InputStream is = new FileInputStream("C:\\Map.pdf");
int len = is.available();
byte [] myByteArray = new byte[len];
int i = 0;
while (i < len) {
i += is.read(myByteArray, i, len);
}
Document myPDFDocument = new Document(myByteArray);
//Create another Document object
Document anotherDocument = new Document(myPDFDocument);
파일을 기반으로 문서 만들기 creating-a-document-based-on-a-file
다음 코드 예제에서는 com.adobe.idp.Document
라는 PDF 파일을 기반으로 하는 개체입니다 map.pdf. 이 파일은 C 하드 드라이브의 루트에 있습니다. 이 생성자는 com.adobe.idp.Document
파일 확장명을 사용하는 개체.
다음 com.adobe.idp.Document
수락하는 생성자 java.io.File
객체에도 부울 매개 변수가 사용됩니다. 이 매개 변수를 true
, com.adobe.idp.Document
개체가 파일을 삭제합니다. 즉, 파일을 파일에 전달한 후 제거할 필요가 없습니다 com.adobe.idp.Document
생성자입니다.
이 매개 변수를 로 설정 false
은(는) 이 파일의 소유권을 유지함을 의미합니다. 이 매개 변수를 로 설정 true
가 더 효율적입니다. 이유는 com.adobe.idp.Document
개체는 파일을 복사하는 대신 로컬 관리 영역으로 파일을 직접 이동할 수 있습니다(속도가 느림).
PDF 파일을 기반으로 하는 문서 객체 만들기
//Create a Document object based on the map.pdf source file
File mySourceMap = new File("C:\\map.pdf");
Document myPDFDocument = new Document(mySourceMap,true);
InputStream 개체를 기반으로 문서 만들기 creating-a-document-based-on-an-inputstream-object
다음 Java 코드 예제에서는 com.adobe.idp.Document
를 기반으로 하는 객체 java.io.InputStream
개체.
InputStream 개체를 기반으로 문서 만들기
//Create a Document object based on an InputStream object
InputStream is = new FileInputStream("C:\\Map.pdf");
Document myPDFDocument = new Document(is);
URL에서 액세스할 수 있는 컨텐츠를 기반으로 문서 만들기 creating-a-document-based-on-content-accessible-from-an-url
다음 Java 코드 예제에서는 com.adobe.idp.Document
라는 PDF 파일을 기반으로 하는 개체입니다 map.pdf. 이 파일은 라는 웹 응용 프로그램 내에 있습니다 WebApp
계속 진행 중입니다. localhost
. 이 생성자는 com.adobe.idp.Document
URL 프로토콜과 함께 반환된 콘텐츠 유형을 사용하는 개체의 MIME 콘텐츠 유형입니다.
에 제공된 URL입니다 com.adobe.idp.Document
객체는 항상 원본에서 com.adobe.idp.Document
다음 예와 같이 개체가 만들어집니다.
Document doc = new Document(new java.net.URL("file:c:/temp/input.pdf"));
c:/temp/input.pdf 파일은 서버 컴퓨터가 아닌 클라이언트 컴퓨터에 있어야 합니다. 클라이언트 컴퓨터는 URL이 읽혀지는 위치와 com.adobe.idp.Document
개체가 생성되었습니다.
URL에서 액세스할 수 있는 컨텐츠를 기반으로 문서 만들기
//Create a Document object based on a java.net.URL object
URL myURL = new URL("http", "localhost", 8080,"/WebApp/map.pdf");
//Create another Document object
Document myPDFDocument = new Document(myURL);
추가 참조
반환된 문서 처리 handling-returned-documents
PDF 문서(또는 XML 데이터 등의 기타 데이터 유형)를 출력 값으로 반환하는 서비스 작업은 com.adobe.idp.Document
개체. 을(를) 받은 후 com.adobe.idp.Document
객체를 다음 형식으로 변환할 수 있습니다.
- A
java.io.File
개체 - A
java.io.InputStream
개체 - 바이트 배열
다음 코드 줄은 com.adobe.idp.Document
개체 java.io.InputStream
개체. 다음과 같이 가정하십시오 myPDFDocument
는 com.adobe.idp.Document
개체:
java.io.InputStream resultStream = myDocument.getInputStream();
마찬가지로 com.adobe.idp.Document
다음 작업을 수행하여 로컬 파일에 추가할 수 있습니다.
- 만들기
java.io.File
개체. - 를 호출합니다
com.adobe.idp.Document
개체copyToFile
메서드 및 전달java.io.File
개체.
다음 코드 예제에서는 com.adobe.idp.Document
라는 파일에 개체 AnotherMap.pdf.
문서 객체의 내용을 파일에 복사
File outFile = new File("C:\\AnotherMap.pdf");
myDocument.copyToFile (outFile);
추가 참조
문서의 컨텐트 유형 확인 determining-the-content-type-of-a-document
의 MIME 유형 확인 com.adobe.idp.Document
객체를 호출하여 com.adobe.idp.Document
개체 getContentType
메서드를 사용합니다. 이 메서드는 com.adobe.idp.Document
개체. 다음 표에서는 AEM Forms이 반환하는 다양한 컨텐츠 유형을 설명합니다.
application/pdf
application/vnd.adobe.xdp+xml
text/xml
application/vnd.fdf
application/vnd.adobe.xfdf
application/rdf+xml
application/octet-stream
NULL
다음 코드 예제에서는 com.adobe.idp.Document
개체.
Document 객체의 컨텐트 유형 확인
//Determine the content type of the Document object
String ct = myDocument.getContentType();
System.out.println("The content type of the Document object is " +ct);
추가 참조
문서 객체 배치 disposing-document-objects
더 이상 필요하지 않은 경우 Document
객체, 해당 객체를 호출하여 삭제하는 것이 좋습니다 dispose
메서드를 사용합니다. 각 Document
개체는 파일 설명자와 애플리케이션의 호스트 플랫폼에서 최대 75MB의 RAM 공간을 사용합니다. 다음과 같은 경우 Document
개체가 처리되지 않으면 Java Garage 수집 프로세스에서 해당 개체를 삭제합니다. 그러나 를 사용하여 더 빨리 처리함으로써 dispose
메서드를 사용하면 Document
개체.
추가 참조
Java 클라이언트 라이브러리를 사용하여 서비스 호출 invoking-a-service-using-a-java-client-library
AEM Forms 서비스 작업은 Java 클라이언트 라이브러리라고 하는 서비스의 강력한 형식의 API를 사용하여 호출할 수 있습니다. A Java 클라이언트 라이브러리 는 서비스 컨테이너에 배포된 서비스에 대한 액세스를 제공하는 구체적인 클래스 세트입니다. 를 만드는 대신 호출할 서비스를 나타내는 Java 개체를 인스턴스화합니다 InvocationRequest
개체를 호출 API를 사용하여 검색합니다. 호출 API는 Workbench에서 만든 장기 처리 프로세스와 같은 프로세스를 호출하는 데 사용됩니다. (자세한 내용은 인간 중심 장기 프로세스 호출)
서비스 작업을 수행하려면 Java 객체에 속하는 메서드를 호출합니다. Java 클라이언트 라이브러리에는 일반적으로 서비스 작업과 일대일로 매핑되는 메서드가 있습니다. Java 클라이언트 라이브러리를 사용할 때 필수 연결 속성을 설정하십시오. (자세한 내용은 연결 속성 설정)
연결 속성을 설정한 후 ServiceClientFactory
서비스를 호출할 수 있는 Java 개체를 인스턴스화하는 데 사용되는 개체입니다. Java 클라이언트 라이브러리가 있는 각 서비스에는 해당 클라이언트 개체가 있습니다. 예를 들어 저장소 서비스를 호출하려면 ResourceRepositoryClient
생성자를 사용하여 객체를 전달하고 ServiceClientFactory
개체. 다음 ServiceClientFactory
개체는 AEM Forms 서비스를 호출하는 데 필요한 연결 설정을 유지 관리합니다.
Analytics JavaScript에서 ServiceClientFactory
일반적으로 빠릅니다. 공장이 처음 사용될 때 일부 오버헤드가 발생합니다. 이 개체는 재사용을 위해 최적화되므로 가능한 경우 동일한 개체를 사용합니다 ServiceClientFactory
여러 Java 클라이언트 개체를 만들 때 개체를 사용합니다. 즉, 별도의 ServiceClientFactory
만드는 각 클라이언트 라이브러리 개체의 개체입니다.
사용자 관리자 설정은 com.adobe.idp.Context
에 영향을 주는 객체 ServiceClientFactory
개체. 이 설정은 Java API를 사용하여 수행한 모든 호출을 포함하여 AEM Forms 전체에서 모든 인증 컨텍스트 라이프타임을 제어합니다. 기본적으로 ServiceCleintFactory
개체를 사용할 수 있는 시간은 2시간입니다.
writeResource
작업이 호출됩니다. 이 작업을 수행하면 저장소에 새 리소스가 배치됩니다.Java 클라이언트 라이브러리를 사용하고 다음 단계를 수행하여 저장소 서비스를 호출할 수 있습니다.
-
Java 프로젝트의 클래스 경로에 adobe-repository-client.jar와 같은 클라이언트 JAR 파일을 포함합니다. 이러한 파일의 위치에 대한 자세한 내용은 AEM Forms Java 라이브러리 파일 포함.
-
서비스를 호출하는 데 필요한 연결 속성을 설정합니다.
-
만들기
ServiceClientFactory
객체를 호출하여ServiceClientFactory
개체의 정적createInstance
메서드 및 전달java.util.Properties
연결 속성을 포함하는 객체입니다. -
만들기
ResourceRepositoryClient
생성자를 사용하여 객체를 전달하고ServiceClientFactory
개체. 를 사용하십시오ResourceRepositoryClient
저장소 서비스 작업을 호출할 개체 -
만들기
RepositoryInfomodelFactoryBean
생성자를 사용하여 개체를 전달하고null
. 이 개체를 사용하면Resource
저장소에 추가된 컨텐츠를 나타내는 객체입니다. -
만들기
Resource
객체를 호출하여RepositoryInfomodelFactoryBean
개체newImage
메서드 및 다음 값 전달:- 다음을 지정하여 고유한 ID 값
new Id()
. - 를 지정하여 고유한 UUID 값
new Lid()
. - 리소스의 이름입니다. XDP 파일의 파일 이름을 지정할 수 있습니다.
반환 값을 다음으로 캐스팅합니다.
Resource
. - 다음을 지정하여 고유한 ID 값
-
만들기
ResourceContent
객체를 호출하여RepositoryInfomodelFactoryBean
개체newImage
반환 값 변환 및 변환ResourceContent
. 이 객체는 리포지토리에 추가된 컨텐츠를 나타냅니다. -
만들기
com.adobe.idp.Document
객체를 전달하여java.io.FileInputStream
저장소에 추가할 XDP 파일을 저장하는 개체입니다. (자세한 내용은 InputStream 개체를 기반으로 문서 만들기) -
의 컨텐츠를 추가합니다
com.adobe.idp.Document
개체ResourceContent
객체를 호출하여ResourceContent
개체setDataDocument
메서드를 사용합니다. 전달com.adobe.idp.Document
개체. -
를 호출하여 저장소에 추가할 XDP 파일의 MIME 유형을 설정합니다
ResourceContent
개체setMimeType
방법 및 전달application/vnd.adobe.xdp+xml
. -
의 컨텐츠를 추가합니다
ResourceContent
개체Resource
객체를 호출하여Resource
개체setContent
메서드 및 전달ResourceContent
개체. -
를 호출하여 리소스의 설명을 추가합니다
Resource
개체setDescription
리소스에 대한 설명을 나타내는 문자열 값을 전달하는 메서드입니다. -
을 호출하여 저장소에 양식 디자인을 추가합니다
ResourceRepositoryClient
개체writeResource
메서드 및 다음 값 전달:- 새 리소스를 포함하는 리소스 컬렉션의 경로를 지정하는 문자열 값입니다
- 다음
Resource
생성된 개체
추가 참조
빠른 시작(EJB 모드): Java API를 사용하여 리소스 쓰기
호출 API를 사용하여 단기 프로세스 호출 invoking-a-short-lived-process-using-the-invocation-api
Java 호출 API를 사용하여 단기 프로세스를 호출할 수 있습니다. 호출 API를 사용하여 단기 프로세스를 호출하는 경우 java.util.HashMap
개체. 각 매개 변수가 서비스에 전달되도록 하려면 java.util.HashMap
개체 put
지정한 작업을 수행하기 위해 서비스에 필요한 이름-값 쌍을 메서드 및 지정합니다. 단기 프로세스에 속하는 매개 변수의 정확한 이름을 지정합니다.
여기서는 Invocation API를 사용하여 명명된 다음과 같은 AEM Forms 단기 프로세스를 호출하는 방법에 대해 설명합니다. MyApplication/EncryptDocument
.
MyApplication/EncryptDocument
워크벤치 사용. (자세한 내용은 Workbench 사용)이 프로세스가 호출되면 다음 작업을 수행합니다.
- 프로세스에 전달되는 비보안 PDF 문서를 가져옵니다. 이 작업은
SetValue
작업. 이 프로세스의 입력 매개 변수는document
이름이 지정된 프로세스 변수inDoc
. - 암호로 PDF 문서를 암호화합니다. 이 작업은
PasswordEncryptPDF
작업. 암호로 암호화된 PDF 문서가 이름이 지정된 프로세스 변수에 반환됩니다outDoc
.
Java 호출 API를 사용하여 MyApplication/EncryptDocument 단기 프로세스를 호출합니다 invoke-the-myapplication-encryptdocument-short-lived-process-using-the-java-invocation-api
를 호출합니다 MyApplication/EncryptDocument
Java 호출 API를 사용한 단기 프로세스:
-
Java 프로젝트의 클래스 경로에 adobe-livecycle-client.jar와 같은 클라이언트 JAR 파일을 포함합니다. (자세한 내용은 AEM Forms Java 라이브러리 파일 포함)
-
만들기
ServiceClientFactory
연결 속성을 포함하는 객체입니다. (자세한 내용은 연결 속성 설정) -
만들기
ServiceClient
생성자를 사용하여 객체를 전달하고ServiceClientFactory
개체. AServiceClient
개체를 사용하면 서비스 작업을 호출할 수 있습니다. 호출 요청 찾기, 발송 및 라우팅 요청 등의 작업을 처리합니다. -
만들기
java.util.HashMap
생성자를 사용하여 개체를 작성합니다. -
를 호출합니다
java.util.HashMap
개체put
각 입력 매개 변수가 긴 기간 프로세스로 전달되는 방법입니다. 왜냐하면MyApplication/EncryptDocument
단기 프로세스에 하나의 입력 매개 변수가 필요합니다.Document
를 호출하기만 하면 됩니다put
다음 예와 같이 메서드를 한 번 사용합니다.code language-as3 //Create a Map object to store the parameter value for inDoc Map params = new HashMap(); InputStream inFile = new FileInputStream("C:\\Adobe\Loan.pdf"); Document inDoc = new Document(inFile); params.put("inDoc", inDoc);
-
만들기
InvocationRequest
객체를 호출하여ServiceClientFactory
개체createInvocationRequest
메서드 및 다음 값 전달:- 호출할 장기 프로세스의 이름을 지정하는 문자열 값입니다. 를 호출하려면
MyApplication/EncryptDocument
프로세스, 지정MyApplication/EncryptDocument
. - 프로세스 작업 이름을 나타내는 문자열 값입니다. 일반적으로 단기 프로세스 작업의 이름은 다음과 같습니다
invoke
. - 다음
java.util.HashMap
서비스 작업에 필요한 매개 변수 값을 포함하는 객체입니다. - 를 지정하는 부울 값
true
는 동기 요청을 만듭니다. 이 값은 단기 프로세스를 호출하는 데 적용할 수 있습니다.
- 호출할 장기 프로세스의 이름을 지정하는 문자열 값입니다. 를 호출하려면
-
를 호출하여 서비스에 호출 요청을 보냅니다.
ServiceClient
개체invoke
메서드 및 전달InvocationRequest
개체. 다음invoke
메서드 반환InvocationReponse
개체.note note NOTE 값을 전달하여 장기 프로세스를 호출할 수 있습니다 false
의 네 번째 매개 변수로createInvocationRequest
메서드를 사용합니다. 값 전달false
비동기 요청을 만듭니다. -
를 호출하여 프로세스의 반환 값을 검색합니다.
InvocationReponse
개체getOutputParameter
출력 매개 변수의 이름을 지정하는 문자열 값 전달 및 메서드입니다. 이 경우outDoc
(outDoc
은 의 출력 매개 변수의 이름입니다MyApplication/EncryptDocument
처리)할 수 있습니다. 반환 값을 다음으로 캐스팅합니다.Document
다음 예와 같이,code language-as3 InvocationResponse response = myServiceClient.invoke(request); Document encryptDoc = (Document) response.getOutputParameter("outDoc");
-
만들기
java.io.File
개체 및 파일 확장명이 .pdf인지 확인합니다. -
를 호출합니다
com.adobe.idp.Document
개체copyToFile
컨텐츠의 내용 복사 방법com.adobe.idp.Document
개체를 파일로 가져올 수 있습니다. 를 사용해야 합니다com.adobe.idp.Document
반환되는 개체getOutputParameter
메서드를 사용합니다.
추가 참조
빠른 시작: 호출 API를 사용하여 단기 프로세스 호출