출력 생성 설정 구성 id181AI0B0E30
AEM Guides에는 출력 생성 프로세스를 사용자 정의할 수 있는 다양한 구성 옵션이 포함되어 있습니다. 이 항목에서는 출력 생성 프로세스를 설정하는 데 도움이 되는 모든 구성 및 사용자 정의에 대해 설명합니다.
DITA 맵 대시보드에서 기준선 탭 구성 id223MD0D0YRM
DITA 맵 대시보드에서 기준선 탭을 숨기려면 다음 단계를 수행합니다.
- 구성 파일을 만들려면 구성 재정의의 지침을 사용하십시오.
- 구성 파일에서 다음 (property) 세부 정보를 입력하여 맵 대시보드에서 기준선 탭을 구성합니다.
com.adobe.fmdita.config.ConfigManager
hide.tabs.baseline
true/false
).기본값: true
기존 AEM 사이트 내에서 혼합 게시 구성 id1691I0V0MGR
DITA 콘텐츠가 포함된 AEM Site가 있는 경우 DITA 콘텐츠를 사이트 내의 사전 정의된 위치에 게시하도록 AEM Site 출력을 구성할 수 있습니다. 예를 들어 AEM 사이트 페이지의 다음 스크린샷에서는 ditacontent
노드가 DITA 콘텐츠를 저장하도록 예약되어 있습니다.
페이지의 나머지 노드는 AEM Site 편집기에서 직접 작성합니다. DITA 콘텐츠를 사전 정의된 위치에 게시하도록 게시 설정을 구성하면 AEM Guides 게시 프로세스에서 기존의 비 DITA 콘텐츠를 수정하지 않아도 됩니다.
사전 정의된 노드에 DITA 컨텐트를 게시할 수 있도록 기존 사이트에서 다음 구성을 수행해야 합니다.
-
사이트의 템플릿 속성 구성
-
사이트에 노드를 추가하여 DITA 콘텐츠 게시
기존 사이트의 템플릿 속성을 구성하려면 다음 단계를 수행하십시오.
-
패키지 관리자를 사용하여 /libs/fmdita/config/templates/default 파일을 다운로드합니다.
note note NOTE libs
노드에서 사용할 수 있는 기본 구성 파일의 사용자 지정을 만들지 마십시오.apps
노드에서libs
노드의 오버레이를 만들고apps
노드에서만 필요한 파일을 업데이트해야 합니다. -
다음 속성을 추가합니다.
table 0-row-3 1-row-3 2-row-3 속성 이름 유형 값 topicContentNode
문자열 DITA 컨텐트를 게시할 노드 이름을 지정합니다. 예를 들어 AEM Guides이 DITA 콘텐츠를 게시하는 기본 노드는
입니다.jcr:content/contentnode
topicHeadNode
문자열 DITA 콘텐츠의 메타데이터 정보를 저장할 노드 이름을 지정합니다. 예를 들어 AEM Guides에서 메타데이터 정보를 저장하는 기본 노드는
입니다.jcr:content/headnode
다음에 사이트의 템플릿 구성을 사용하여 DITA 콘텐츠를 게시하면 해당 콘텐츠가 topicContentNode
및 topicHeadNode
속성에 지정된 노드에 게시됩니다.
AEM 사이트 출력 사용자 지정 id166TG0B30WR
AEM Guides은 다음 형식의 출력 만들기를 지원합니다.
- AEM 사이트
- HTML5
- EPUB
- DITA-OT를 통한 사용자 지정 출력
AEM Site 출력의 경우 출력 작업이 다른 디자인 템플릿을 할당할 수 있습니다. 이러한 디자인 템플릿은 DITA 콘텐츠를 다른 레이아웃으로 렌더링할 수 있습니다. 예를 들어 내부 및 외부 대상에 대해 서로 다른 디자인 템플릿을 지정할 수 있습니다.
AEM Guides에서 사용자 지정된 DITA Open Toolkit (DITA-OT) 플러그인을 사용할 수도 있습니다. 이러한 사용자 지정 DITA-OT 플러그인을 업로드하여 특정 방식으로 PDF 출력을 생성할 수 있습니다.
출력 생성을 위한 디자인 템플릿 맞춤화 customize_xml-add-on
AEM Guides에서는 사전 정의된 디자인 템플릿 세트를 사용하여 AEM Site 출력을 생성합니다. AEM Guides 디자인 템플릿을 사용자 지정하여 회사 브랜딩에 맞는 출력을 생성할 수 있습니다. 디자인 템플릿은 다양한 스타일 (CSS), 스크립트 (서버측과 클라이언트측), 리소스 (이미지, 로고 및 기타 에셋) 및 이러한 모든 리소스를 하나로 묶는 JCR 노드의 컬렉션입니다. 디자인 템플릿은 두 개의 JCR 노드만 사용하거나 스타일, 리소스 및 JCR 노드의 복잡한 조합을 사용하는 단일 서버측 스크립트처럼 단순할 수 있습니다. 디자인 템플릿은 AEM Site 출력을 생성하는 동안 AEM Guides 게시 하위 시스템에서 사용되며 생성된 출력의 구조, 모양 및 느낌을 제어합니다.
서버에서 디자인 템플릿 리소스를 배치해야 하는 위치에는 제한이 없지만, 일반적으로 함수에 따라 논리적으로 구성됩니다. 예를 들어 기본 템플릿의 모든 JavaScript 및 CSS 파일이 /etc/designs/fmdita/clientlibs/siteoutput/default
폴더에 저장되어 있습니다. 이러한 파일은 위치에 관계없이 JCR 노드 컬렉션에 의해 함께 연결됩니다. 이러한 JCR 노드와 파일은 함께 전체 디자인 템플릿을 구성합니다.
AEM Guides과 함께 제공되는 기본 디자인 템플릿을 사용하면 랜딩, 주제 및 검색 페이지 구성 요소를 사용자 정의할 수 있습니다. 기본 설계와 해당 참조 템플릿의 복사본을 만들고 다른 구성 요소를 지정하여 원하는 출력을 생성할 수 있습니다.
다음 단계를 수행하여 AEM Site 출력 생성에 사용할 고유한 디자인 템플릿을 지정합니다.
-
패키지 관리자를 사용하여 다음 위치에서 기본 디자인 템플릿을 다운로드합니다.
/libs/fmdita/config/templates
-
Cloud Manager의 Git 저장소의 다음 위치에 다운로드한 파일의 복사본을 만듭니다.
/apps/fmdita/config/templates
-
또한 기본 템플릿 노드에서 참조된 템플릿을 다운로드하여 복사해야 합니다. 참조된 템플릿은 다음 아래에 배치됩니다.
/libs/fmdita/templates/default/cqtemplates
다음 표에서는 AEM Guides 디자인 템플릿 속성에 대해 설명합니다.
table 0-row-2 1-row-2 2-row-2 3-row-2 4-row-2 5-row-2 6-row-2 7-row-2 8-row-2 9-row-2 10-row-2 11-row-2 12-row-2 13-row-2 속성 설명 landingPageTemplate
,searchPageTemplate
,topicPageTemplate
,shadowPageTemplate
해당 페이지 (랜딩, 검색 및 항목)에 대한 cq:Template
노드를 지정하십시오. 기본적으로 이러한 페이지에 대한cq:Template
노드는/libs/fmdita/templates/default/cqtemplates
노드에서 찾을 수 있습니다. 이 노드는 랜딩, 검색 및 주제 페이지의 구조 및 속성을 정의합니다.shadowPageTemplate
은(는) 청크된 콘텐츠를 최적화하는 데 사용됩니다. 이 속성의 값을 다음으로 설정해야 합니다.fmdita/templates/default/cqtemplates/shadowpage
참고:topicPageTemplate
에 대한 값을 지정해야 합니다.landingPageTemplate
및searchPageTemplate
은(는) 선택적 속성입니다. 검색 및 랜딩 페이지를 생성하지 않으려면 이러한 속성을 지정하지 마십시오.title
디자인 서식 파일을 설명하는 이름입니다. topicContentNode
주제 페이지의 DITA 컨텐트를 포함할 노드의 위치입니다. 경로는 주제 페이지를 기준으로 합니다. topicHeadNode
DITA 콘텐츠에서 파생된 헤드 값 (또는 메타데이터)을 포함할 노드의 위치입니다. 경로는 주제 페이지를 기준으로 합니다. tocNode
목차를 포함할 노드의 위치입니다. 경로는 랜딩 페이지 또는 대상 경로를 기준으로 합니다. basePathProp
게시된 사이트의 루트 경로를 저장하는 속성 이름입니다. indexPathProp
게시된 사이트의 랜딩/인덱스 페이지 경로를 저장하는 속성 이름입니다. pdfPathProp
주제 PDF 생성이 활성화된 경우 주제 PDF 경로를 저장하기 위한 속성 이름입니다. pdfTypeProp
PDF 생성 유형을 저장하는 속성 이름입니다. 현재 이 속성은 항상 "Topic"을 포함합니다. searchPathProp
템플릿에 검색 페이지가 포함된 경우 검색 페이지의 경로를 저장하는 속성 이름입니다. siteTitleProp
게시 중인 사이트의 제목을 저장하는 속성 이름입니다. 이 제목은 일반적으로 게시 중인 맵의 제목과 동일합니다. sourcePathProp
현재 페이지의 소스 DITA 주제 경로를 저장하는 속성 이름입니다. tocPathProp
게시된 사이트에 대한 목차 루트 경로를 저장하는 속성 이름입니다.
자세한 내용은 첫 번째 Adobe Experience Manager 웹 사이트 만들기 및 AEM에서 자체 웹 사이트 개발 기본 사항을 참조하십시오.
AEM 사이트 출력 생성에 문서 제목 사용
AEM Site 출력을 생성할 때 URL을 생성하는 방식은 콘텐츠의 검색 기능에 중요한 역할을 합니다. UUID 기반 파일 이름을 사용하는 경우 파일의 UUID를 기반으로 URL을 생성하면 검색하기 쉽지 않습니다. 관리자 또는 게시자는 AEM Site 출력에 대한 URL을 생성하는 방법을 제어할 수 있습니다. AEM Guides은 UUID 기반 파일 이름이 아닌 파일의 제목을 사용하여 AEM 사이트 출력의 URL을 생성하도록 선택할 수 있는 구성을 제공합니다. 기본적으로 UUID 기반 파일 시스템의 경우 이 옵션이 켜져 있습니다. 이는 UUID 기반 파일 시스템에 대한 AEM Site 출력을 생성할 때 파일의 제목이 파일의 UUID가 아닌 URL을 생성하는 데 사용됨을 의미했습니다.
구성 파일을 만들려면 구성 재정의의 지침을 사용하십시오. AEM Site 출력에서 URL 생성을 구성하려면 구성 파일에서 다음 (property) 세부 정보를 제공합니다.
com.adobe.fmdita.config.ConfigManager
aemsite.pagetitle
기본값: false
문서 제목을 사용하도록 AEM 사이트 출력의 URL을 구성합니다.
AEM Site 출력의 URL에서 문서 제목을 사용할 수 있습니다. 파일 이름이 존재하지 않거나 모든 특수 문자가 포함되어 있는 경우 AEM Site 출력의 URL에서 특수 문자를 구분 기호로 대체하도록 시스템을 구성할 수 있습니다. 첫 번째 하위 항목의 이름으로 바꾸도록 구성할 수도 있습니다.
페이지 이름을 구성하려면 다음 단계를 수행하십시오.
- 구성 파일을 만들려면 구성 재정의의 지침을 사용하십시오.
- 구성 파일에서 다음(등록 정보) 세부 정보를 제공하여 주제에 대한 페이지 이름을 구성합니다.
com.adobe.fmdita.common.SanitizeNodeName
nodename.systemDefinedPageName
true/false
). 기본값: false
예를 들어 <topichead>
의 @navtitle 에 모든 특수 문자가 있고 aemsite.pagetitle
속성을 true로 설정한 경우 기본적으로 구분 기호를 사용합니다. nodename.systemDefinedPageName
속성을 true로 설정하면 첫 번째 하위 주제의 이름이 표시됩니다.
항목을 만들고 AEM 사이트 출력을 게시하기 위한 파일 이름 정리 규칙 구성 id2164D0KD0XA
관리자는 파일 이름에 사용할 수 있는 유효한 특수 문자 목록을 정의하여 AEM Site 출력의 URL을 형성할 수 있습니다. 이전 릴리스에서는 사용자가 @
, $
, >
등의 특수 문자가 포함된 파일 이름을 정의할 수 있었습니다. 이러한 특수 문자로 인해 AEM Site 페이지를 생성할 때 URL이 인코딩되었습니다.
3.8 릴리스부터 파일 이름에 사용할 수 있는 특수 문자 목록을 정의하는 구성이 추가되었습니다. 기본적으로 올바른 파일 이름 구성에는 "a-z A-Z 0-9 - _
"이(가) 포함되어 있습니다. 이는 파일을 만드는 동안 파일 제목에 특수 문자를 사용할 수 있지만 내부적으로 파일 이름에 하이픈 (-
)으로 대체됩니다. 예를 들어 파일 제목을 Introduction 1 또는 Introduction@1으로 지정할 수 있습니다. 이 두 경우에 대해 생성되는 해당 파일 이름은 Introduction-1입니다.
올바른 문자 목록을 정의할 때 이러한 문자 "*/:[\]|#%{}?&<>"/+
" 및 a space
은(는) 항상 하이픈 (-
)으로 대체됩니다.
구성 파일을 만들려면 구성 재정의의 지침을 사용하십시오. 구성 파일에서 다음 (property) 세부 정보를 입력하여 파일 이름 및 AEM Site 출력에 유효한 특수 문자를 구성합니다.
com.adobe.fmdita.common.SanitizeNodeNameImpl
aemsite.DisallowedFileNameChars
'<>`@$
(으)로 설정되어 있는지 확인하십시오. 이 목록에 더 많은 특수 문자를 추가할 수 있습니다.파일 이름에서 소문자 사용, 잘못된 문자를 처리하는 구분 기호, 파일 이름에 사용할 수 있는 최대 문자 수와 같은 다른 속성을 구성할 수도 있습니다. 이러한 속성을 구성하려면 구성 파일에 다음 키 값 쌍을 추가합니다.
nodename.uselower
기본값: true
nodename.separator
기본값: _ (밑줄)
nodename.maxlength
기본값: 50
AEM 사이트 노드 구조의 평면화 구성
AEM Site 출력을 생성하면 주제의 모든 요소에 대한 노드가 내부적으로 생성됩니다. 수천 개의 주제가 있는 DITA 맵의 경우 이 노드 구조가 너무 깊어질 수 있습니다. 이러한 유형의 깊게 중첩된 노드 구조는 더 큰 사이트에 대해 성능 문제가 발생할 수 있습니다. 다음 스냅샷은 AEM 사이트 출력에 대해 깊게 중첩된 노드 구조를 표시합니다.
위의 스냅숏에서는 모든 p
요소 및 후속 하위 요소에 대해 노드가 만들어지고 주제에 사용되는 다른 모든 요소에 대해 유사한 구조가 만들어지는 것을 확인합니다.
AEM Guides을 사용하면 AEM 사이트 출력의 노드 구조를 내부적으로 만드는 방법을 구성할 수 있습니다. 지정된 요소에서 노드 구조를 평면화할 수 있습니다. 즉, 주 요소로 간주될 요소를 정의할 수 있으며 해당 요소 내의 모든 하위 요소가 주 요소와 병합됩니다. 예를 들어 p
요소를 병합하기로 결정한 경우 p
요소 내에 나타나는 모든 요소는 기본 p
요소와 병합됩니다. p
요소 내의 하위 요소에 대해서는 별도의 메모가 만들어지지 않습니다. 다음 스냅숏은 p
요소에서 병합된 노드 구조를 표시합니다.
AEM 사이트 노드 구조를 제거하려면 다음 단계를 수행하십시오.
-
노드 구조를 평면화할 요소를 식별합니다.
-
apps
노드의libs
노드를 오버레이하고 elementmapping.xml 파일을 엽니다. -
노드 구조를 평면화할 요소의 정의에
<flatten>true</flatten>
속성을 추가합니다. 예를 들어p
요소에서 노드 구조를 병합하려면 아래와 같이p
요소의 정의에 병합된 특성을 추가합니다.code language-xml <ditaelement> <name>p</name> <class>- topic/p</class> <componentpath>fmdita/components/dita/wrapper</componentpath> <type>COMPOSITE</type> <target>para</target> <flatten>true</flatten> <wrapelement>div</wrapelement> </ditaelement>
note note NOTE 기본적으로 p
요소에 플랫 노드 속성이 구성되었습니다. -
구성 파일을 만들려면 구성 재정의의 지침을 사용하십시오.
-
구성 파일에서 다음 (property) 세부 정보를 제공합니다.
table 0-row-3 1-row-3 PID 속성 키 속성 값 com.adobe.dxml.flattening.FlatteningConfigurationService
flattening.enabled
부울 (true/false).
기본값:false
이제 AEM Site 출력을 생성하면 p
요소 내의 노드가 병합되고 p
요소 자체에 저장됩니다. CRXDE에서 p
요소에 대한 새 병합 속성을 찾을 수 있습니다.
AEM Site 출력의 콘텐츠 내에서 문자열을 검색합니다
기본적으로 AEM Site 출력 내에서만 제목의 문자열을 검색할 수 있습니다. 제목과 AEM Site 출력의 콘텐츠 또는 본문 모두에서 문자열을 검색하도록 시스템을 구성할 수 있습니다.
검색을 활성화하려면 AEM 사이트 노드 구조의 병합을 구성해야 합니다.
주의:
병합된 콘텐츠를 최대 1MB까지 검색할 수 있습니다. 예를 들어 이전 스크린샷에서 <p> 태그 아래의 컨텐츠가 1Mb 미만인지 검색할 수 있습니다.
<flatten>
특성이 true로 설정된 경우에만 요소에서 검색이 작동합니다. 기본적으로 AEM Guides에는 <p> <ul> <lI>과 같이 일반적으로 사용되는 텍스트 요소에 대해 <flatten>
특성이 true로 설정되어 있습니다. 그러나 사용자 지정 요소를 만든 경우 elementmapping.xml 파일에서 <flatten>
특성을 true로 설정해야 합니다.AEM 사이트 노드 구조의 병합을 방지합니다
AEM Site 출력에서 평면화할 노드를 지정하는 것과 유사하게 이 구성에서 제외할 요소를 지정할 수도 있습니다. 예를 들어 body
요소의 노드를 병합하려고 하지만 body
내의 table
요소를 병합하지 않으려는 경우 table
요소의 정의 내에 exclude 속성을 추가할 수 있습니다.
병합에서 table
요소를 제외하려면 table
요소의 정의에 다음 속성을 추가하십시오.
<preventancestorflattening>true|false</preventancestorflattening>
AEM Site 출력에서 삭제된 페이지에 대한 버전 관리 구성
기존 출력 페이지 설정에 대해 삭제 및 만들기 옵션이 선택된 AEM 사이트 출력을 생성하면 삭제되는 페이지에 대한 버전이 만들어집니다. 삭제하기 전에 버전 생성을 중단하도록 시스템을 구성할 수 있습니다.
삭제할 페이지에 대한 버전 만들기를 중지하려면 다음 단계를 수행하십시오.
-
구성 파일을 만들려면 구성 재정의의 지침을 사용하십시오.
-
구성 파일에서 다음 (property) 세부 정보를 제공하여 삭제된 페이지에 대한 버전을 만들지 않음 옵션을 구성하십시오.
table 0-row-3 1-row-3 PID 속성 키 속성 값 com.adobe.fmdita.confi g.ConfigManager
no.version.creation.on.deletion
부울 (true/false).
기본값:true
note note NOTE 이 옵션을 선택하면 사용자는 자신의 버전을 작성하지 않고도 원하는 페이지를 직접 삭제할 수 있습니다. 옵션을 선택하지 않으면 페이지가 삭제되기 전에 버전이 작성됩니다.
Experience Manager Guides으로 사용자 지정 재작성기 설정 custom-rewriter
Experience Manager Guides에는 교차 맵(서로 다른 두 맵의 주제 간 링크)의 경우 생성되는 링크를 처리하기 위한 사용자 지정 sling rewriter 모듈이 있습니다. 이 재작성기 구성은 다음 경로에 설치됩니다./apps/fmdita/config/rewriter/fmdita-crossmap-link-patcher
코드베이스에 다른 사용자 지정 sling 재작성기가 있는 경우, Experience Manager Guides sling 재작성기는 'order'
50을 사용하므로 50보다 큰 'order'
값을 사용하십시오. 재정의하려면 50 이상의 값이 필요합니다. 자세한 내용은 출력 다시 쓰기 파이프라인을 참조하십시오.
DITA-OT를 통해 출력을 게시할 때 메타데이터 사용 id191LF0U0TY4
AEM Guides에서는 DITA-OT를 사용하여 출력을 게시하는 동안 사용자 지정 메타데이터를 전달하는 방법을 제공합니다. 관리자 및 게시자는 게시된 출력에서 사용자 지정 메타데이터를 구성하고 사용하려면 다음 작업을 수행해야 합니다.
-
관리자는 DITA 맵의 등록 정보 페이지에서 사용할 수 있도록 시스템에 필요한 메타데이터를 추가합니다.
-
관리자는 DITA 맵 콘솔에 표시되도록 메타데이터 목록에 사용자 지정 메타데이터를 추가합니다.
-
Publisher로 DITA 맵으로 사용자 지정 메타데이터를 구성 및 추가하고 필요한 출력을 생성합니다.
시스템에 필요한 메타데이터를 추가하려면 다음 단계를 수행하십시오.
-
관리자로 Adobe Experience Manager에 로그인합니다.
-
맨 위에 있는 Adobe Experience Manager 링크를 클릭하고 도구 를 선택합니다.
-
도구 목록에서 Assets 을(를) 선택합니다.
-
메타데이터 스키마 타일을 클릭합니다.
[메타데이터 스키마 Forms] 페이지가 표시됩니다.
-
목록에서 기본 양식을 선택하십시오.
note note NOTE DITA 맵의 등록 정보 페이지에 표시되는 등록 정보는 이 양식에서 가져온 것입니다. -
편집 을 클릭합니다.
-
게시된 출력에 사용할 사용자 지정 메타데이터를 추가합니다. 예를 들어 다음 단계를 사용하여 대상 메타데이터를 추가합니다.
-
양식 작성 구성 요소 목록에서 한 줄 텍스트 구성 요소를 양식으로 끌어서 놓습니다.
-
필드의 설정 을(를) 열려면 새 필드를 선택하십시오.
-
필드 레이블 에 메타데이터 이름(대상)을 입력합니다.
-
속성에 매핑 설정에서 을(를) 지정합니다./jcr:content/metadata/<메타데이터의 이름>. 이 예제에서는 를 로 설정합니다./jcr:content/metadata/audience.
다음 단계를 사용하여 필요한 모든 메타데이터 매개 변수를 추가합니다.
-
-
저장 을 클릭합니다.
이제 모든 DITA 맵에 대한 속성 페이지에 새 매개변수가 표시됩니다.
그런 다음 DITA 맵 콘솔에서 사용자 지정 메타데이터를 사용할 수 있도록 해야 합니다. DITA 맵 대시 보드에서 사용자 정의 메타데이터를 사용할 수 있도록 하려면 다음 단계를 수행하십시오.
-
패키지 관리자를 사용하여 Cloud Manager의 Git 저장소의 다음 위치에 있는 metadataList 파일에 액세스합니다.
/libs/fmdita/config/metadataList
note note NOTE metadataList 파일에는 맵 대시보드에 있는 DITA 맵의 속성 드롭다운 목록에 표시되는 속성 목록이 포함되어 있습니다. 기본적으로 이 파일에는 doctstate, dc:language, dc:description, dc:title 등 네 가지 속성이 나열됩니다. -
메타데이터 스키마 Forms 페이지에서 추가한 사용자 지정 메타데이터를 추가합니다. 이 예제에서는 기본 목록의 끝에 대상 매개 변수를 추가합니다.
이제 사용자 지정 메타데이터가 DITA 맵 콘솔의 속성 드롭다운 목록에 표시됩니다.
마지막으로 게시자는 게시된 출력에 사용자 지정 메타데이터를 포함해야 합니다. 출력을 생성하는 동안 사용자 지정 메타데이터를 처리하려면 다음 단계를 수행하십시오.
-
Assets UI에서 게시하려는 DITA 맵으로 이동합니다.
-
DITA 맵 파일을 선택하고 해당 특성 페이지를 엽니다.
-
속성 페이지에서 사용자 지정 메타데이터의 값을 지정합니다. 이 예제에서는 대상 매개 변수에 대해 External 값을 지정했습니다.
-
저장 및 닫기 를 클릭합니다.
-
DITA 맵 파일을 클릭하여 DITA 맵 콘솔을 엽니다.
-
출력 사전 설정 탭에서 출력을 생성하는 데 사용할 출력 사전 설정을 선택합니다.
-
편집 을 클릭합니다.
-
속성 드롭다운 목록에서 게시 프로세스에 전달할 속성을 선택합니다.
선택한 속성/메타데이터는 게시 프로세스에 전달되고 최종 출력에서 사용할 수 있습니다.
처리를 위해 DITA-OT로 전달되는 메타데이터의 유효성 검사
DITA-OT에 전달된 메타데이터 값의 유효성을 검사하기 위해 클라우드 지원 jar를 사용하는 로컬 환경을 사용할 수 있습니다. 클라우드에서 로컬 파일 시스템에 액세스할 수 없으므로 메타데이터 파일의 유효성을 검사하는 유일한 방법은 cloud ready jar를 통해서입니다.
-
파일 이름: metadata.xml
-
파일 위치: crx-quickstart/profiles/ditamaps/<ditamap-1234>
metadata.xml에 액세스하려면 다음을 수행하십시오.
- AEM 인스턴스가 실행 중인 서버 위치에 로그인합니다.
- crx-quickstart/profiles/ditamaps/<새로 만든 디렉터리 이름>/metadata.xml으로 마이그레이션합니다.
-
샘플 파일 형식:
metadata.xml
code language-xml <?xml version="1.0" encoding="UTF-8" standalone="no"?> <root> <Path id="/absolutePath/sampleMap.ditamap"> <metadata> <meta isArray="false" key="dc:description">This is a file</meta> <meta isArray="false" key="dc:title">Myfile</meta> <meta isArray="true" key="multivalueText">One;Two;Three</meta> </metadata> </Path> <Path id="/absolutePath/sampleTopic.dita"> <metadata> <meta isArray="false" key="dc:description">description for the accountability</meta> <meta isArray="false" key="dc:title">accountability title</meta> <meta isArray="true" key="multivalueText">value1</meta> </metadata> </Path> </root>
-
isArray: 메타데이터가 다중 값 (Array)인지 여부를 정의하는 부울 속성. 값은 세미콜론으로 구분됩니다.
-
경로 ID: 임시 디렉터리에 저장된 파일의 절대 경로입니다.
AEM 구성 요소를 사용하여 DITA 요소 매핑 사용자 정의 id1679J600HEL
AEM Guides의 DITA 요소는 해당 AEM 구성 요소에 매핑됩니다. AEM Guides은 게시 및 검토와 같은 워크플로에서 이 매핑을 사용하여 DITA 요소를 해당 AEM 구성 요소로 변환합니다. 패키지 관리자를 사용하여 액세스할 수 있는 elementmapping.xml
파일에 매핑이 정의되어 있습니다.
libs
노드에서 사용할 수 있는 기본 구성 파일의 사용자 지정을 만들지 마십시오. apps
노드에서 libs
노드의 오버레이를 만들고 apps
노드에서만 필요한 파일을 업데이트해야 합니다.미리 정의된 DITA 요소 매핑을 사용하거나 DITA 요소를 사용자 정의 AEM 구성 요소에 매핑할 수 있습니다. 사용자 지정 AEM 구성 요소를 사용하려면 elementmapping.xml
파일의 구조를 이해해야 합니다.
elementmapping.xml 구조
elementmapping.xml
구조에 대한 높은 수준의 개요가 아래에 설명되어 있습니다.
-
모든 DITA 요소는 먼저 요소 이름을 기반으로 해당 컴포넌트 매핑을 검색합니다. 예:
code language-xml <ditaelement> <name>**substeps**</name> <class>- topic/ol task/substeps</class> <componentpath>dita/components/ditaolist</componentpath> <type>COMPOSITE</type> <target>para</target> </ditaelement>
위의 예에서 모든
substeps
DITA 요소는dita/components/ditaolist
구성 요소를 사용하여 렌더링됩니다. -
DITA 요소가 이름을 기반으로 일치하는 항목을 찾지 못하면
class
을(를) 기반으로 일치하는 항목을 찾습니다. 예:code language-xml <ditaelement> <name>topic</name> <class>**- topic/topic**</class> <componentpath>fmdita/components/dita/topic</componentpath> <type>COMPOSITE</type> <target>para</target> <attributemap> <attribute from="id" to="id" /> </attributemap> </ditaelement>
위의 예에서
task
요소에 대해 정의된 매핑이 없으면task
이(가)topic
구성 요소에서 상속되므로task
요소가 위 구성 요소에 매핑됩니다. -
요소에 해당 구성 요소 매핑이 있는 경우 자식 요소의 추가 처리는
type
에 의해 결정됩니다. 예:code language-xml <ditaelement> <name>title</name> <class>- topic/title</class> <componentpath>foundation/components/title</componentpath> <type>**STANDALONE**</type> <target>para</target> <textprop>jcr:title</textprop> </ditaelement>
type
은(는) 다음 값을 사용합니다.-
COMPOSITE: 자식 요소 에 대해서도 요소 대 구성 요소 매핑이 계속됩니다.
-
STANDALONE: 현재 요소의 자식 요소가 더 이상 매핑되지 않습니다.
위의 예에서
<title>
요소에 자식 요소가 있으면 다른 구성 요소에 매핑되지 않습니다.<title>
요소의 구성 요소는<title>
요소 내의 모든 자식 요소를 렌더링합니다. -
-
단일 DITA 요소에 매핑된 컴포넌트가 여러 개 있는 경우 요소에 가장 잘 맞는 컴포넌트가 선택됩니다. 최상의 일치 구성 요소를 선택하기 위해 DITA 요소의 도메인 및 구조 특수화가 고려됩니다.
도메인 특수화를 사용하는 DITA 요소가 있고 구성 요소가 도메인 특수화를 위해 매핑되는 경우 해당 구성 요소에 높은 우선 순위가 지정됩니다.
마찬가지로, 구조 특수화가 있는 DITA 요소가 있고 구성 요소가 구조 특수화에 대해 매핑되면 해당 구성 요소에 높은 우선순위가 지정됩니다.
-
요소 매핑에서
<attributemap>
을(를) 사용하여 특성 값을 해당 노드 속성에 매핑할 수 있습니다. -
textprop
은(는) DITA 요소의 텍스트 콘텐츠를 노드 속성으로 직렬화하는 데 사용할 수 있습니다. 또한 요소 태그에서 여러 번 사용하여 게시된 계층의 여러 위치에서 텍스트 콘텐츠를 직렬화할 수 있습니다. 대상 속성의 위치와 이름을 사용자 지정할 수도 있습니다. 예:code language-xml <ditaelement> <name>title</name> <componentpath>foundation/components/title</componentpath> <type>STANDALONE</type> <target>para</target> <textprop>**jcr:title**</textprop> </ditaelement>
위의 요소 매핑은
<title>
요소의 텍스트 콘텐츠가 출력 노드에서 이름이jcr:title
인 속성의 값으로 저장되도록 지정합니다. -
xmlprop
은(는) 특정 요소의 전체 XML을 노드 속성으로 serialize하는 데 사용할 수 있습니다. 그런 다음 구성 요소가 이 노드 속성을 읽고 사용자 지정 렌더링을 수행할 수 있습니다. 예:code language-xml <ditaelement> <name>svg-container</name> <class>+ topic/foreign svg-d/svg-container</class> <componentpath>fmdita/components/dita/svg</componentpath> <type>STANDALONE</type> <target>para</target> <xmlprop>**data**</xmlprop> </ditaelement>
위의 요소 매핑은 요소
<svg-container>
에 대한 전체 XML 태그를 출력 노드에 이름이data
인 속성의 값으로 저장하도록 지정합니다. -
출력 생성 프로세스에서 경로 확인을 처리하는 특수 속성 매핑이 있습니다. 예:
code language-xml <attributemap> <attribute from="href" to="fileReference" ispath="true" rel="source" /> <attribute from="height" to="height" /> <attribute from="width" to="width" /> </attributemap>
위의
attributemap
에 대해 DITA 요소의href
특성이fileReference
노드 속성에 매핑됩니다. 이제ispath
이(가)true
(으)로 설정되어 있으므로 출력 생성 프로세스에서 이 경로를 확인한 다음fileReference
노드 속성에 설정합니다.이 해결 방법은 특성 매핑의
rel
특성 값을 기반으로 결정됩니다.-
rel=source
이면 현재 처리 중인 DITA 원본 파일과 관련하여href
의 값이 확인됩니다.href
의 값이 확인되어fileReference
속성의 값에 배치됩니다. -
rel=target
이면href
의 값이 루트 게시 위치에 따라 확인됩니다.href
의 값이 확인되어fileReference
속성의 값에 배치됩니다.
경로 특성에서 전처리 또는 확인을 수행하지 않으려면
ispath
특성을 지정할 필요가 없습니다. 값이 그대로 복사되며 컴포넌트가 필요한 해상도를 수행할 수 있습니다. -
DITA 요소 스키마
다음은 elementmapping.xml
파일의 DITA 요소 스키마의 예입니다.
<ditaelement>
<name>element_name</name>
<class>element_class</class>
<componentpath>fmdita/components/dita/component_name</componentpath>
<type>COMPOSITE|STANDALONE</type>
<attributeprop>propname_a</attributeprop>
<textprop>propname_t</textprop>
<xmlprop>propname_x</xmlprop>
<xpath>xpath expression string</xpath>
<target>head|para</target>
<wrapelement>div</wrapelement>
<wrapclass>class_name</wrapclass>
<attributemap>
<attribute from="attrname" to="propname" ispath="true|false" rel="source|target" />
</attributemap>
<skip>true|false</skip>
</ditaelement>
다음 표에서는 DITA 요소 스키마의 요소에 대해 설명합니다.
<ditaelement>
<class>
예를 들어 DITA 주제의 클래스 특성은
입니다.
- topic/topic
<componentpath>
<type>
- COMPOSITE: 하위 요소와
- 독립 실행형: 하위 요소의 처리를 건너뜁니다.
<attributeprop>
<note type="Caution">
이고 이 요소에 대해 매핑된 구성 요소에 <attributeprop>attr_t</ attributeprop>
이(가) 있으면 노드의 특성 및 값이 해당 AEM 노드 ( attr_t->type="caution"
)의 attr_t
속성으로 serialize됩니다.<textprop>propname_t</textprop>
getTextContent()
출력을 propname_t.
에 의해 정의된 속성에 저장 참고: 최적화된 속성입니다.
<xmlprop>propname_x </xmlprop>
propname_x.<br>
에 의해 정의된 속성에 저장합니다. 참고: 최적화된 속성입니다.<xpath>
<target>
가능한 값:
- head: head 노드 아래
- text: 단락 노드 아래
<wrapelement>
<wrapclass>
wrapclass.
에 대한 요소 값<attributemap>
<attribute>
노드가 포함된 컨테이너 노드입니다.추가 참고 사항
-
기본 요소 매핑을 재정의하려면 기본
elementmapping.xml
파일에서 변경하지 않는 것이 좋습니다. 새 매핑 XML 파일을 만들고 다른 위치(일반적으로 사용자가 만드는 사용자 정의 앱 폴더 내)에 파일을 배치해야 합니다. -
elementmapping.xml
파일에 fmdita/components/dita/wrapper 구성 요소를 참조하는 매핑 항목이 많습니다. 래퍼는 사이트 노드의 속성을 사용하여 비교적 간단한 DITA 구문을 렌더링하여 관련 HTML을 생성하는 일반 구성 요소입니다.wrapelement
속성을 사용하여 바깥쪽 태그를 생성하고 자식 렌더링을 해당 구성 요소에 위임합니다. 이 기능은 컨테이너 구성 요소만 사용하려는 경우에 유용합니다.div
또는p
과(와) 같은 특정 컨테이너 태그를 렌더링하는 새 구성 요소를 만드는 대신 래퍼 구성 요소를wrapelement
및wrapclass
속성과 함께 사용하여 동일한 효과를 얻을 수 있습니다. -
문자열 JCR 속성에는 대량의 텍스트를 저장하지 않는 것이 좋습니다. 출력 생성에서 최적화된 속성 유형 계산은 큰 텍스트 콘텐츠가 문자열 유형으로 저장되지 않도록 합니다. 대신 특정 임계값보다 큰 콘텐츠를 저장해야 하는 경우 속성 유형이 바이너리로 변경됩니다. 기본적으로 이 임계값은 512바이트로 구성되지만 구성 관리자 (com.adobe.fmdita.config.ConfigManager)에서 이진 임계값으로 저장 설정을 변경하여 변경할 수 있습니다.
-
일부 (전체가 아님)의 요소 매핑을 재정의하려는 경우 전체
elementmapping.xml
파일을 복제하지 않아도 됩니다. 새 XML 매핑 파일을 만들고 재정의하는 요소만 정의해야 합니다. -
사용자 지정 위치에서 XML 파일을 만든 후
com.adobe.fmdita.config.ConfigManager
번들의Override Element Mapping
설정을 업데이트합니다.
DITA 맵 콘솔 사용자 정의 id188HC08M0CZ
AEM Guides은 DITA 맵 콘솔의 기능을 확장할 수 있는 유연성을 제공합니다. 예를 들어 AEM Guides에서 사용할 수 있는 보고서와 다른 보고서 세트가 있는 경우 그러한 보고서를 맵 콘솔에 추가할 수 있습니다. 맵 콘솔을 사용자 정의하려면 필요한 기능을 수행하는 코드가 포함된 AEM 클라이언트 라이브러리 (또는 ClientLib)를 만들어야 합니다.
AEM Guides은 맵 콘솔을 사용자 지정할 apps.fmdita.dashboard-extn
범주를 제공합니다. 맵 콘솔이 로드될 때마다 apps.fmdita.dashboard-extn
범주에서 만든 기능이 실행되고 로드됩니다.
출력 생성 중 이미지 렌디션 처리 id177BF0G0VY4
AEM에는 자산을 처리하는 기본 워크플로우 및 미디어 핸들 세트가 포함되어 있습니다. AEM에는 가장 일반적인 MIME 유형에 대한 에셋 처리를 처리하는 미리 정의된 워크플로가 있습니다. 일반적으로 업로드하는 모든 이미지에 대해 AEM은 이진 형식으로 동일한 렌디션을 여러 개 만듭니다. 이러한 렌디션은 크기가 다르고 해상도가 다르며 워터마크가 추가되거나 다른 특성이 변경될 수 있습니다. AEM에서 자산을 처리하는 방법에 대한 자세한 내용은 AEM 설명서에서 미디어 처리기 및 워크플로를 사용하여 Assets 처리를 참조하십시오.
AEM Guides을 사용하면 문서에 대한 출력을 생성할 때 사용할 이미지 렌디션을 구성할 수 있습니다. 예를 들어 기본 이미지 표현물 중 하나를 선택하거나 표현물을 만들어 이를 사용하여 문서를 게시할 수 있습니다. 문서를 게시하기 위한 이미지 렌디션 매핑은 /libs/fmdita/config/ **renditionmap.xml**
파일에 저장됩니다. renditionmap.xml
파일의 스니펫은 다음과 같습니다.
apps
폴더에 renditionmap.xml
파일의 복사본을 만드는 것이 좋습니다.<renditionmap>
<mapelement>
<mimetype>image/png</mimetype>
<rendition output="AEMSITE">cq5dam.web.1280.1280.jpeg</rendition>
<rendition output="PDF">original</rendition>
<rendition output="HTML5">cq5dam.web.1280.1280.jpeg</rendition>
<rendition output="EPUB">cq5dam.web.1280.1280.jpeg</rendition>
<rendition output="CUSTOM">cq5dam.web.1280.1280.jpeg</rendition>
</mapelement>
...
</renditionmap>
mimetype
요소는 파일 형식의 MIME 형식을 지정합니다. rendition output
요소는 지정된 출력을 게시하는 데 사용해야 하는 출력 형식 및 렌디션의 이름 (예: cq5dam.web.1280.1280.jpeg
)을 지정합니다. AEMSITE, PDF, HTML5, EPUB 및 사용자 지정 등 지원되는 모든 출력 형식에 사용할 이미지 렌디션을 지정할 수 있습니다.
지정된 렌디션이 없으면 AEM Guides 게시 프로세스는 먼저 지정된 이미지의 웹 렌디션을 찾습니다. 웹 렌디션도 찾을 수 없는 경우에는 이미지의 원본 렌디션이 사용됩니다.
출력 기록에 대한 자동 삭제 기간 구성 id19AAI070V8Q
출력을 생성하면 출력 로그와 함께 출력이 생성됩니다. 큰 DITA 맵의 경우 이러한 로그는 저장소에서 많은 공간을 사용할 수 있습니다. 기본적으로 로그는 저장소의 다음 위치에 저장됩니다.
/var/dxml/metadata/outputHistory
일정 기간 동안 모든 로그 파일의 전체 크기가 GB로 증가할 수 있습니다. AEM Guides을 사용하면 이러한 로그 파일을 저장소에 보관하도록 기간을 구성할 수 있습니다. 지정된 기간이 지나면 출력 생성 기록과 함께 로그가 저장소에서 삭제됩니다.
기록 지우기 기능을 구성하면 저장소의 모든 DITA 맵에 대한 출력 생성에 영향을 미칩니다. DITA 맵의 출력 탭에서 기록은 지정된 일 수와 설정에 지정된 시간에 삭제됩니다.
구성 파일을 만들려면 구성 재정의의 지침을 사용하십시오. 출력 기록 및 로그를 제거할 날짜와 시간을 설정하려면 구성 파일에 다음 (property) 세부 정보를 입력하십시오.
com.adobe.fmdita.config.ConfigManager
output.history.purgeperiod
기본값: 5
output.history.purgetime
기본값: 0:00 (또는 12:00 자정)
최근에 생성된 출력 목록 제한 변경 id1679JH0H0O2
DITA 맵의 출력 탭에 표시되는 생성된 최대 출력 수를 변경할 수 있습니다.
구성 파일을 만들려면 구성 재정의의 지침을 사용하십시오. 구성 파일에서 다음 (property) 세부 정보를 입력하여 목록에 표시할 출력 수를 변경합니다.
com.adobe.fmdita.config.ConfigManager
output.historylimit
기본값: 25