AEMでは、画像、.js、.css ファイルを含む完全な Web ページとしてページを書き出すことができます。
書き出しを設定したら、次の代わりに html
と export.zip
URL 内に、html 形式でレンダリングされたページと参照元のアセットを含む zip ファイルのダウンロードが含まれています。 ページ内のすべてのパス(画像へのパスなど)は、zip ファイルに含まれるファイルまたはサーバー上のリソースを指すように書き換えられます。
次の手順では、ページを書き出す方法を説明し、サイトに書き出し設定テンプレートが存在すると仮定します。 設定テンプレートは、ページの書き出し方法を定義し、サイトに固有のものです。 設定テンプレートを作成するには、 サイト用のページエクスポーター設定の作成 」セクションに入力します。
ページをエクスポートするには:
ブラウザーで、ページを開きます。 次に例を示します。
http://localhost:4502/content/geometrixx/en/products/triangle.html
ページプロパティダイアログを開き、「 詳細 タブをクリックし、 書き出し フィールドセット。
虫めがねアイコンをクリックし、設定テンプレートを選択します。 を選択します。 geometrixx テンプレートに含まれます。Geometrixxサイトのデフォルトのテンプレートです。 「OK」をクリックします。
クリック OK をクリックして、ページプロパティダイアログを閉じます。
次を置き換えてページをリクエスト html
と export.zip
」と入力します。
をダウンロードします。 <page-name>.export.zip
ファイルをファイルシステムに保存します。
ファイルシステムで、ファイルを解凍します。
<page-name>.html
) は、以下で利用できます。 <unzip-dir>/<page-path>
<unzip-dir>/etc
の一部 <unzip-dir>/<page-path>
.ページの HTML ファイル(<unzip-dir>/<page-path>.html
)をブラウザーで開き、レンダリングを確認します。
ページエクスポーターは、コンテンツ同期フレームワークに基づいています。ページのプロパティダイアログで使用できる設定は、設定テンプレートです。 ページに必要な依存関係をすべて定義します。 ページの書き出しがトリガーされると、設定テンプレートが使用され、ページパスとデザインパスの両方が設定に動的に適用されます。 その後、標準のコンテンツ同期機能を使用して、zip ファイルが作成されます。
AEMには、次のようないくつかのテンプレートが埋め込まれます。
デフォルトは /etc/contentsync/templates/default
. このテンプレート:
専用の Geometrixx サイト、 /etc/contentsync/templates/geometrixx
. このテンプレートは、新しいテンプレートを作成する例として使用できます。
ページエクスポーター設定テンプレートを作成するには:
CRXDE Lite で、/etc/contentsync/templates
の下にノードを作成します。
mysite
. ページエクスポーターテンプレートを選択すると、この名前がページプロパティのダイアログボックスに表示されます。nt:unstructured
テンプレートノード(ここでは mysite
)の下に、次で説明する設定ノードを使用してノード構造を作成します。
設定テンプレートは、ノード構造で構成されます。 各ノードには、zip ファイルの作成プロセスで特定のアクションを定義する type
プロパティが含まれています。type プロパティの詳細については、コンテンツ同期フレームワークページの設定タイプの概要の節を参照してください。
書き出し設定テンプレートを作成するには、次のノードを使用できます。
ページノード ページノードは、ページの html を zip ファイルにコピーするために使用されます。 次のような特徴があります。
/etc/contentsync/templates/<sitename>
にあります。page
.nt:unstructured
page
ノードには以下のプロパティがあります。
値 pages
が設定された type
プロパティ。
path
プロパティはありません。現在のページパスが設定に動的にコピーされます。
その他のプロパティについては、コンテンツ同期フレームワークの設定タイプの概要の節で説明します。
書き換えノード rewrite ノードは、書き出されたページでリンクを書き換える方法を定義します。 書き換えられたリンクは、zip ファイルに含まれるファイルまたはサーバー上のリソースを指す場合があります。
詳しくは、コンテンツ同期ページを参照してください。 rewrite
ノード。
デザインノード デザインノードは、書き出したページに使用するデザインをコピーするために使用されます。 次のような特徴があります。
/etc/contentsync/templates/<sitename>
にあります。design
.nt:unstructured
.design
ノードには次のプロパティがあります。
値 copy
に設定された type
プロパティ。
path
プロパティはありません。現在のページパスが設定に動的にコピーされます。
汎用ノード 汎用ノードは、clientlibs .jsや.css ファイルなどのリソースを zip ファイルにコピーするために使用します。 次のような特徴があります。
/etc/contentsync/templates/<sitename>
にあります。nt:unstructured
.type
プロパティおよび任意 type
コンテンツ同期フレームワークの「設定タイプの概要」節で定義される関連プロパティ。例えば、次の設定ノードでは、geometrixx clientlibs .js ファイルを zip ファイルにコピーします。
"geometrixx.clientlibs.js": {
"extension": "js",
"type": "clientlib",
"path": "/etc/designs/geometrixx/clientlibs",
"jcr:primaryType": "nt:unstructured"
}
この Geometrixx ページ書き出し設定テンプレートで、ページの書き出しを設定する方法を確認できます。 テンプレートのノード構造を json 形式でブラウザーに表示するには、次の URL を要求します。
http://localhost:4502/etc/contentsync/templates/geometrixx.-1.json
カスタム設定の実装
ノード構造でご存じのように、 Geometrixx ページ書き出し設定テンプレートに logo
ノード type
プロパティを image
. これは、画像のロゴを zip ファイルにコピーするために作成された特別な設定タイプです。 特定の要件を満たすには、カスタム type
プロパティ:その場合は、コンテンツ同期ページのカスタム更新ハンドラーの実装の節を参照してください。
プログラムによってページを書き出すには、 PageExporter OSGi サービス。 このサービスを使用すると、次のことができます。
export
セレクターおよび zip
拡張子にバインドされているサーブレットは PageExporter サービスを使用します。
Zip ファイルのダウンロードで問題が発生した場合は、リポジトリで /var/contentsync
ノードを削除して、エクスポートリクエストを再度送信できます。