リソースマッピング resource-mapping

リソースマッピングは、AEM のリダイレクト、バニティ URL および仮想ホストを定義するために使用します。

例えば、これらのマッピングを使用すると次のことが可能です。

  • すべてのリクエストに /content というプレフィックスを付けて、web サイトの訪問者に内部構造が表示されないようにする。
  • Web サイトの /content/en/gateway ページへのリクエストがすべて https://gbiv.com/ にリダイレクトされるように、リダイレクトを定義する。

HTTP マッピングの一例として、localhost:4503 に対するすべてのリクエストに /content というプレフィックスを指定します。このようなマッピングを使用すると、Web サイトの訪問者に対して内部構造を非表示にすることができます。例えば、次のページの場合は、

localhost:4503/content/we-retail/en/products.html

以下を使用してアクセスします。

localhost:4503/we-retail/en/products.html

マッピングによって、/we-retail/en/products.html/content という接頭辞が自動的に追加されます。

CAUTION
バニティー URL は regex パターンをサポートしません。
NOTE
詳しくは、Sling のドキュメントと「Mappings for Resource Resolution」と「Resources」を参照してください。

マッピングの定義の表示 viewing-mapping-definitions

このマッピングは 2 つのリストを形成し、JCR リソースリゾルバーは一致を見つけるために(トップダウンで)評価します。

これらのリストは、Felix コンソールの JCR ResourceResolver オプション(例:https://<*host*>:<*port*>/system/console/jcrresolver)で(設定情報と一緒に)確認できます。

  • Configuration
    Apache Sling Resource Resolver 用に定義された)現在の設定を表示します。

  • 設定テスト
    URL またはリソースパスを入力できます。「解決」または「マップ」をクリックして、システムによるエントリの変換方法を確認します。

  • Resolver Map Entries
    URL をリソースにマップするために ResourceResolver.resolve メソッドが使用するエントリのリストです。

  • Mapping Map Entries
    リソースパスを URL にマップするために ResourceResolver.map メソッドが使用するエントリのリストです。

2 つのリストには、アプリケーションでデフォルトとして定義されたエントリなど、様々なエントリが表示されます。これらのエントリは、多くの場合、ユーザーの URL を簡素化することを目的としています。

リストでは、パターン(リクエストに適合する正規表現)と​ リプレースメント(適用するリダイレクトを定義)がペアになっています。

例えば、次のパターン

パターン ^[^/]+/[^/]+/welcome$

以下をトリガーします。

リプレースメント /libs/cq/core/content/welcome.html.

次のリクエストをリダイレクトするには、

https://localhost:4503/welcome ``

次に対して

https://localhost:4503/libs/cq/core/content/welcome.html

新しいマッピング定義がリポジトリ内に作成されます。

NOTE
正規表現の定義方法について説明したリソースが多数あります。例えば、https://www.regular-expressions.info/ です。

AEM でのマッピング定義の作成 creating-mapping-definitions-in-aem

AEM の標準インストールには、次のフォルダーがあります。

/etc/map/http

このフォルダーは、HTTP プロトコル用のマッピングを定義する場合に使用する構造です。マッピングするその他のプロトコル用に別のフォルダー(sling:Folder)を /etc/map の下に作成できます。

/content への内部リダイレクトの設定 configuring-an-internal-redirect-to-content

https://localhost:4503/ に対するリクエストに /content というプレフィックスを指定するマッピングを作成するには:

  1. CRXDE を使用して /etc/map/http に移動します。

  2. ノードの作成:

    • タイプsling:Mapping
      これは目的のマッピング用のノードタイプですが、必須ではありません。

    • 名前 localhost_any

  3. すべて保存」をクリックします。

  4. このノードに次のプロパティを追加します。

    • 名前 sling:match

      • String

      • localhost.4503/

    • 名前 sling:internalRedirect

      • String

      • /content/

  5. すべて保存」をクリックします。

このマッピングは、
localhost:4503/geometrixx/en/products.html
のようなリクエストを、
localhost:4503/content/geometrixx/en/products.html
がリクエストされたかのように処理します。

NOTE
使用可能な sling のプロパティとその設定方法について詳しくは、Sling のドキュメントのリソースを参照してください。
例えば、文字列補間は、環境変数から環境ごとに値を取得するマッピングを設定できるので、便利です。
NOTE
/etc/map.publish を使用して、パブリッシュ環境の設定を保持できます。これらの設定を複製して、パブリッシュ環境の Apache Sling Resource Resolver の​ マッピング場所 ​用に、新しい場所(/etc/map.publish)を設定する必要があります。
recommendation-more-help
fbcff2a9-b6fe-4574-b04a-21e75df764ab