コンテンツのアーキテクチャ

David's Model に準拠

David's Model は何年も前に David Nuescheler によって作成されたものですが、その考え方は今でも当てはまります。Davidのモデルの主な特徴は次のとおりです。

  • データが最初に来て、後で構造化します。 たぶん。
  • コンテンツ階層は手動で設計し、成り行き任せにしない。
  • ワークスペースはclone()merge()update()用です。
  • 同じ名前の兄弟に注意する。
  • 参照は害が多いと考えられる。
  • ファイルはあくまでもファイル。
  • 身分証明書は悪い。

Davidのモデルは、Jackrabbit wikiのhttps://wiki.apache.org/jackrabbit/DavidsModelにあります。

すべてがコンテンツである

あらゆるデータの格納には、データベースなど別個のサードパーティデータソースを利用するのではなく、リポジトリを使用する必要があります。このことは、作成済みコンテンツ、バイナリデータ(画像など)、コード、設定などに当てはまります。このようにすると、1 つの API セットを使用してすべてのコンテンツを管理でき、レプリケーションによってこのコンテンツのプロモーションを管理できます。また、バックアップやログの単一ソースを得ることができます。

「コンテンツモデルが第一」というデザインの原則の使用

新機能をビルドするときには、常に JCR コンテンツ構造の設計から始め、次にデフォルトの Sling サーブレットを使用したコンテンツの読み込みおよび書き込みに進みます。これにより、お使いの実装が既製のアクセス制御メカニズムと適切に動作することを確認でき、不要なCRUDスタイルのサーブレットを生成しないようにできます。

RESTful に準拠

サーブレットをパスではなく resourceType に基づいて定義する必要があります。これにより、JCRアクセス制御の使用、REST原則の遵守、リクエストで提供されるリソースとリソースリゾルバーの使用が可能になります。 また、クライアント側からURLを変更する必要なく、サーバー側でURLをレンダリングするスクリプトを変更できます。また、セキュリティを強化するために、サーバー側の実装の詳細をクライアント側から非表示にできます。

新しいノードタイプの定義を回避

ノードタイプはインフラストラクチャレイヤー内の下位レベルで機能し、ほとんどの要件は nt:unstructured、oak:Unstructured、sling:Folder または cq:Page のノードタイプに割り当てられた sling:resourceType を使用することで満たすことができます。ノードタイプはリポジトリ内のスキーマと同じで、ノードタイプの変更は最終的には非常に高コストになる可能性があります。

JCR の命名規則に準拠

命名規則に準拠することにより、コードベースの一貫性が高まるので、不具合の発生率を低下させ、システムで作業する開発者の生産性を高めることができます。開発AEMでは、Adobeが次の規則を使用します。

  • ノード名

    • すべて小文字
    • 単語間の区切りにハイフンを使用
  • プロパティ名

    • キャメルケース、小文字で開始
  • コンポーネント(JSP/HTML)

    • すべて小文字
    • 単語間の区切りにハイフンを使用

このページ

Adobe Summit Banner

A virtual event April 27-28.

Expand your skills and get inspired.

Register for free
Adobe Summit Banner

A virtual event April 27-28.

Expand your skills and get inspired.

Register for free
Adobe Maker Awards Banner

Time to shine!

Apply now for the 2021 Adobe Experience Maker Awards.

Apply now
Adobe Maker Awards Banner

Time to shine!

Apply now for the 2021 Adobe Experience Maker Awards.

Apply now