覆蓋
- 主題:
- 開發
建立對象:
- 開發人員
Adobe Experience Manager (AEM) (以及之前的CQ)一直使用覆蓋原則來讓您延伸及自訂主控台和其他功能(例如,頁面製作)。
覆蓋是許多內容中使用的辭彙。 在此情境中(擴充AEM),覆蓋是指採用預先定義的功能,並將您自己的定義強加於此功能(以自訂標準功能)。
在標準執行個體中,預先定義的功能儲存在/libs
下,建議在/apps
分支下定義您的覆蓋(自訂)。 AEM使用搜尋路徑來尋找資源,先搜尋/apps
分支,然後搜尋/libs
分支(可以設定搜尋路徑)。 此機制表示您的覆蓋(以及其中定義的自訂)有優先權。
自AEM 6.0起,覆蓋的實作與使用方式已發生變更:
-
AEM 6.0及更高版本 — 適用於Granite相關覆蓋圖(亦即觸控式UI)
-
方法
-
在
/apps
下重新建構適當的/libs
結構。這不需要1:1的復本,Sling Resource Merger用於互動參照所需的原始定義。 Sling Resource Merger提供的服務可存取及合併具有不同(差異)機制的資源。
-
在
/apps
底下,進行任何變更。
-
-
優點
- 對
/libs
下的變更更健全。 - 僅重新定義必要的專案。
- 對
-
-
AEM 6.0之前的非Granite覆蓋圖和覆蓋圖
-
方法
-
將內容從
/libs
複製到/apps
複製整個子分支,包括屬性。
-
在
/apps
底下,進行任何變更。
-
-
缺點
- 雖然您的變更不會在
/libs
下發生變更時遺失,但您可能必須重新建立/apps
下覆蓋圖中所發生的特定變更。
- 雖然您的變更不會在
-
重疊是許多變更的建議方法,例如設定您的主控台或在側面板中的資產瀏覽器中建立您的選取類別 (用於編寫頁面)。 其需求為:
-
不要 在
/libs
分支 中進行變更
您所做的任何變更都可能會遺失,因為每當您:- 在您的執行個體上升級
- 套用hotfix
- 安裝功能套件
-
這些功能可將您的變更集中在一個位置;如有需要,讓您更輕鬆地追蹤、移轉、備份或偵錯變更。
設定搜尋路徑
對於覆蓋圖,傳送的資源是擷取的資源和屬性的彙總,取決於可定義的搜尋路徑:
-
Apache Sling Resource Resolver Factory 的資源 解析器搜尋路徑 定義於OSGi設定。
- 搜尋路徑的由上而下的順序表示其各自的優先順序。
- 在標準安裝中,主要預設值為
/apps
,/libs
— 因此/apps
的內容優先順序高於/libs
的內容(亦即 覆蓋)。
-
兩位服務使用者需要有JCR:READ存取權才能存取儲存指令碼的位置。 這些使用者是: components-search-service (由com.day.cq.wcm.coreto使用)和sling-scripting (由org.apache.sling.servlets.resolver使用來尋找servlet)。
-
下列設定也必須根據您放置指令碼的位置(此範例中位於/etc、/libs或/apps下)進行設定。
PID = org.apache.sling.jcr.resource.internal.JcrResourceResolverFactoryImpl resource.resolver.searchpath=["/etc","/apps","/libs"] resource.resolver.vanitypath.whitelist=["/etc/","/apps/","/libs/","/content/"]
-
最後,也必須設定Servlet Resolver (在此範例中,亦要新增/etc)
PID = org.apache.sling.servlets.resolver.SlingServletResolver servletresolver.paths=["/bin/","/libs/","/apps/","/etc/","/system/","/index.servlet","/login.servlet","/services/"]
使用範例
以下情形會說明部分範例: