이 문서의 샘플 및 예제는 JEE 환경의 AEM Forms에 대해서만 적용됩니다.
사용자가 대화형 양식을 작성할 수 있도록 해 주는 웹 기반 응용 프로그램을 사용하려면 데이터를 다시 서버로 제출해야 합니다. Forms 서비스를 사용하면 사용자가 대화형 양식에 입력한 양식 데이터를 검색할 수 있습니다. 그런 다음 양식 데이터를 다른 AEM Forms 서비스 작업에 전달하고 데이터를 사용하여 PDF 문서를 만들 수 있습니다.
이 콘텐츠를 읽기 전에 제출된 양식 처리에 대해 깊이 있게 이해하는 것이 좋습니다. 양식 디자인과 제출된 XML 데이터 간의 관계와 같은 개념은 제출된 Forms 처리에서 다룹니다.
세 가지 AEM Forms 서비스를 포함하는 다음 워크플로를 고려하십시오.
다음 다이어그램은 이 워크플로를 시각적으로 보여 줍니다.
사용자가 클라이언트 웹 브라우저에서 양식을 제출하면 비대화형 PDF 문서가 Content Services에 저장됩니다(더 이상 사용되지 않음). 다음 그림은 Content Services(더 이상 사용되지 않음)에 저장된 PDF 문서를 보여 줍니다.
제출된 XML 데이터로 비대화형 PDF 문서를 만들고 Content Services(더 이상 사용되지 않음)의 PDF 문서에 저장하려면 다음 작업을 수행합니다.
프로젝트 파일 포함
개발 프로젝트에 필요한 파일을 포함하십시오. Java를 사용하여 클라이언트 응용 프로그램을 만드는 경우 필요한 JAR 파일을 포함합니다. 웹 서비스를 사용하는 경우 프록시 파일을 포함해야 합니다.
Forms, 출력 및 문서 관리 개체 만들기
Forms 서비스 API 작업을 프로그래밍 방식으로 수행하려면 먼저 Forms 클라이언트 API 개체를 만듭니다. 마찬가지로 이 워크플로우는 출력 및 문서 관리 서비스를 호출하므로 출력 클라이언트 API 개체와 문서 관리 클라이언트 API 개체를 모두 만듭니다.
Forms 서비스를 사용하여 양식 데이터 검색
Forms 서비스에 제출된 양식 데이터를 검색합니다. 비즈니스 요구 사항을 충족하기 위해 제출된 데이터를 처리할 수 있습니다. 예를 들어 기업 데이터베이스에 양식 데이터를 저장할 수 있습니다. 그러나 비대화형 PDF 문서를 만들기 위해 양식 데이터가 출력 서비스로 전달됩니다.
출력 서비스를 사용하여 비대화형 PDF 문서를 만듭니다.
출력 서비스를 사용하여 양식 디자인과 XML 양식 데이터를 기반으로 하는 비대화형 PDF 문서를 만듭니다. 워크플로우에서는 양식 데이터를 Forms 서비스에서 검색합니다.
문서 관리 서비스를 사용하여 PDF 양식을 컨텐츠 서비스(더 이상 사용되지 않음)에 저장
Document Management 서비스 API를 사용하여 컨텐츠 서비스에 PDF 문서를 저장합니다(더 이상 사용되지 않음).
추가 참조
Forms, 출력 및 Document Management API(Java)를 사용하여 제출된 XML 데이터로 PDF 문서를 생성합니다.
프로젝트 파일 포함
Java 프로젝트의 클래스 경로에 adobe-forms-client.jar, adobe-output-client.jar 및 adobe-contentservices-client.jar과 같은 클라이언트 JAR 파일을 포함합니다.
Forms, 출력 및 문서 관리 개체 만들기
ServiceClientFactory
연결 속성을 포함하는 개체입니다.FormsServiceClient
개체를 생성자를 사용하고 ServiceClientFactory
개체.OutputClient
개체를 생성자를 사용하고 ServiceClientFactory
개체.DocumentManagementServiceClientImpl
개체를 생성자를 사용하고 ServiceClientFactory
개체.Forms 서비스를 사용하여 양식 데이터 검색
호출 FormsServiceClient
개체 processFormSubmission
메서드를 실행하고 다음 값을 전달합니다.
com.adobe.idp.Document
양식 데이터가 포함된 개체입니다.CONTENT_TYPE
환경 변수입니다. 예를 들어 XML 데이터를 처리하려면 이 매개변수에 대해 다음 문자열 값을 지정합니다. CONTENT_TYPE=text/xml
.HTTP_USER_AGENT
헤더 값(예: ) Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1; .NET CLR 1.1.4322)
.RenderOptionsSpec
런타임 옵션을 저장하는 개체입니다.다음 processFormSubmission
메서드가 을 반환합니다. FormsResult
양식 제출 결과를 포함하는 개체입니다.
다음을 호출하여 Forms 서비스가 양식 데이터 처리를 완료했는지 여부 확인 FormsResult
개체 getAction
메서드를 사용합니다. 이 메서드가 값을 반환하는 경우 0
, 데이터를 처리할 준비가 되었습니다.
다음을 만들어 양식 데이터 검색 com.adobe.idp.Document
를 호출하여 개체 FormsResult
개체 getOutputContent
메서드를 사용합니다. (이 개체에는 출력 서비스로 전송할 수 있는 양식 데이터가 포함되어 있습니다.)
만들기 java.io.InputStream
를 호출하여 개체 java.io.DataInputStream
생성자 및 전달 com.adobe.idp.Document
개체.
만들기 org.w3c.dom.DocumentBuilderFactory
static을 호출하여 org.w3c.dom.DocumentBuilderFactory
개체 newInstance
메서드를 사용합니다.
만들기 org.w3c.dom.DocumentBuilder
를 호출하여 개체 org.w3c.dom.DocumentBuilderFactory
개체 newDocumentBuilder
메서드를 사용합니다.
만들기 org.w3c.dom.Document
를 호출하여 개체 org.w3c.dom.DocumentBuilder
개체 parse
메서드 및 전달 java.io.InputStream
개체.
XML 문서 내에서 각 노드의 값을 검색합니다. 이 작업을 수행하는 한 가지 방법은 두 매개 변수를 허용하는 사용자 지정 메서드를 만드는 것입니다. org.w3c.dom.Document
객체 및 값을 검색할 노드의 이름입니다. 이 메서드는 노드의 값을 나타내는 문자열 값을 반환합니다. 이 프로세스를 따르는 코드 예제에서 이 사용자 지정 메서드는 이라고 합니다 getNodeText
. 이 메서드의 본문이 표시됩니다.
출력 서비스를 사용하여 비대화형 PDF 문서를 만듭니다.
를 호출하여 PDF 문서 만들기 OutputClient
개체 generatePDFOutput
메서드 및 다음 값 전달:
TransformationFormat
열거형 값입니다. PDF 문서를 생성하려면 다음을 지정합니다 TransformationFormat.PDF
.PDFOutputOptionsSpec
PDF 런타임 옵션이 포함된 객체입니다.RenderOptionsSpec
렌더링 런타임 옵션이 포함된 객체입니다.com.adobe.idp.Document
폼 디자인과 병합할 데이터가 들어 있는 XML 데이터 원본을 포함하는 개체입니다. 에서 이 개체가 반환되었는지 확인합니다. FormsResult
개체 getOutputContent
메서드를 사용합니다.generatePDFOutput
메서드가 다음을 반환합니다. OutputResult
작업의 결과를 포함하는 개체입니다.OutputResult
개체 getGeneratedDoc
메서드를 사용합니다. 이 메서드는 com.adobe.idp.Document
비대화형 PDF 문서를 나타내는 인스턴스입니다.문서 관리 서비스를 사용하여 PDF 양식을 컨텐츠 서비스에 저장(더 이상 사용되지 않음)
를 호출하여 콘텐츠 추가 DocumentManagementServiceClientImpl
개체 storeContent
메서드 및 다음 값 전달:
SpacesStore
. 이 값은 필수 매개 변수입니다./Company Home/Test Directory
). 이 값은 필수 매개 변수입니다.MortgageForm.pdf
). 이 값은 필수 매개 변수입니다.{https://www.alfresco.org/model/content/1.0}content
. 이 값은 필수 매개 변수입니다.com.adobe.idp.Document
컨텐츠를 나타내는 객체입니다. 이 값은 필수 매개 변수입니다.UTF-8
). 이 값은 필수 매개 변수입니다.UpdateVersionType
버전 정보를 처리하는 방법을 지정하는 열거형 값(예: UpdateVersionType.INCREMENT_MAJOR_VERSION
컨텐츠 버전을 늘리려면 다음을 수행합니다. ) 이 값은 필수 매개 변수입니다.java.util.List
콘텐츠와 관련된 측면을 지정하는 인스턴스입니다. 이 값은 선택적 매개 변수이며 다음을 지정할 수 있습니다 null
.java.util.Map
컨텐츠 속성을 저장하는 객체입니다.다음 storeContent
메서드가 을 반환합니다. CRCResult
컨텐츠를 설명하는 개체입니다. 사용 CRCResult
예를 들어 콘텐츠의 고유 식별자 값을 얻을 수 있습니다. 이 작업을 수행하려면 CRCResult
개체 getNodeUuid
메서드를 사용합니다.
추가 참조