ContextHub是儲存、操控和呈現內容資料的架構。 如需ContextHub的詳細資訊,請參閱開發人員檔案。 ContextHub會取代觸控式UI中的用戶端內容。
設定ContextHub工具列以控制它是否出現在「預覽」模式中、建立ContextHub存放區,以及使用觸控最佳化UI新增UI模組。
依預設,AEM安裝中會啟用ContextHub。 您可以停用ContextHub,以防止其載入js/css及初始化。 停用ContextHub有兩個選項:
編輯ContextHub的設定並核取選項停用ContextHub
或
/libs/settings/cloudsettings
下的屬性disabled
設定為true由於AEM 6.4中的存放庫重新調整, ContextHub設定的位置已從變 /etc/cloudsettings
更為:
/libs/settings/cloudsettings
/conf/global/settings/cloudsettings
/conf/<tenant>/settings/cloudsettings
設定AdobeGranite ContextHub OSGi服務,以在您的頁面上顯示或隱藏ContextHub UI。 此服務的PID為com.adobe.granite.contexthub.impl.ContextHubImpl.
要配置服務,可以使用Web控制台或在儲存庫🔗中使用JCR節點:
com.adobe.granite.contexthub.show_ui
屬性設 true
為。若要隱藏UI,請將屬性設為false
。顯示ContextHub UI時,它只會顯示在AEM製作例項的頁面上。 UI不會出現在發佈執行個體的頁面上。
設定以「預覽」模式顯示於ContextHub工具列的UI模式和模組:
UI模式會以一系列圖示的形式顯示在工具列左側。 選取後,UI模式的模組會顯示在右側。
圖示是Coral UI圖示資料庫中的參考。
新增UI模式以將相關的ContextHub模組分組。 建立UI模式時,您會提供顯示在ContextHub工具列中的標題和圖示。
在Experience Manager邊欄中,按一下或點選「工具>網站>內容中樞」。
按一下或點選預設的「設定容器」。
按一下或點選「Context Hub Configuration」。
按一下或點選「建立」按鈕,然後按一下或點選「內容中樞UI模式」。
提供下列屬性的值:
coral-Icon--user
按一下或點選「儲存」。
將ContextHub UI模組新增至UI模式,使其顯示在ContextHub工具列中以預覽頁面內容。 新增UI模組時,您會建立已向ContextHub註冊的模組類型例項。 若要新增UI模組,您必須知道相關模組類型的名稱。
AEM提供基本UI模組類型以及數種範例UI模組類型,您可以依據這些類型來建立UI模組。 下表提供每個項目的簡短說明。 如需有關開發自訂UI模組的資訊,請參閱建立ContextHub UI模組。
UI模組屬性包含詳細設定,您可在此提供模組特定屬性的值。 您提供JSON格式的詳細設定。 表格中的「模組類型」欄提供每個UI模組類型所需JSON程式碼的相關資訊連結。
模組類型 | 說明 | 存放 |
---|---|---|
contexthub.base | 一般UI模組類型 | 在UI模組屬性中設定 |
contexthub.browserinfo | 顯示瀏覽器的相關資訊 | surferinfo |
contexthub.datetime | 顯示日期和時間資訊 | 日期時間 |
contexthub.device | 顯示客戶端設備 | 模擬器 |
contexthub.location | 顯示用戶端的經緯度,以及地圖上的位置。 可讓您變更位置。 | 地理位置 |
contexthub.screen-orientation | 顯示裝置的螢幕方向(橫向或直向) | 模擬器 |
contexthub.tagcloud | 顯示頁面標籤的統計資料 | tagcloud |
granite.profile | 顯示當前用戶的配置檔案資訊,包括可授權的ID、displayName和familyName。 您可以更改displayName和familyName的值。 | 側面像 |
在Experience Manager邊欄中,按一下或點選「工具>網站> ContextHub」。
按一下或點選「設定容器」,以新增UI模組。
按一下或輸入您要新增UI模組的ContextHub設定。
按一下或點選您要新增UI模組的UI模式。
按一下或點選「建立」按鈕,然後按一下或點選「 ContextHub UI模組(一般)」。
提供下列屬性的值:
(選用)若要覆寫預設的存放區設定,請輸入JSON物件以設定UI模組。
按一下或點選「儲存」。
建立Context Hub存放區以保留使用者資料並視需要存取資料。 ContextHub存放區是根據已註冊的存放區候選項。 建立商店時,需要註冊商店候選商店的storeType值。 (請參閱建立自訂商店候選項。)
配置儲存時,「詳細配置」屬性允許您為儲存特定屬性提供值。 值以儲存init
函式的config
參數為基礎。 因此,您是否需要提供此值和值的格式取決於儲存區。
Detail Configuration屬性的值是JSON格式的config
物件。
AEM提供下列範例存放區候選項,供您建立存放區。
商店類型 | 說明 |
---|---|
aem.segmentation | 儲存已解析和未解析的ContextHub區段。 自動從ContextHub SegmentManager中擷取區段 |
aem.resolvedsegments | 儲存目前解析的區段。 監聽ContextHub SegmentManager服務以自動更新儲存 |
contexthub.geolocation | 儲存瀏覽器位置的經緯度。 |
contexthub.datetime | 儲存瀏覽器位置的目前日期、時間和季數 |
granite.emulators | 定義多個設備的屬性和功能,並檢測當前客戶端設備 |
contexthub.generic-jsonp | 從JSONP服務擷取和儲存資料 |
granite.profile | 儲存目前使用者的設定檔資料 |
contexthub.surferinfo | 儲存用戶端的相關資訊,例如裝置資訊、瀏覽器類型和視窗方向 |
contexthub.tagcloud | 儲存頁面標籤和標籤計數 |
在Experience Manager邊欄中,按一下或點選「工具>網站> ContextHub」。
按一下或點選預設設定容器。
按一下或點選「Contexthub設定」
若要新增商店,請按一下或點選「建立」圖示,然後按一下或點選「 ContexHub商店設定」。
提供基本配置屬性的值,然後按一下或點選「下一步」:
(選用)若要覆寫預設的存放區設定,請在「詳細設定(JSON)」方塊中輸入JSON物件。
按一下或點選「儲存」。
此範例說明如何設定儲存區,以及在UI模組中顯示資料。 在此示例中,jsontest.com站點的MD5服務用作儲存的資料源。 服務會傳回指定字串的MD5雜湊代碼(JSON格式)。
已設定contexthub.generic-jsonp儲存,以便儲存服務呼叫https://md5.jsontest.com/?text=%22text%20to%20md5%22
的資料。 服務會傳回下列顯示在UI模組中的資料:
{
"md5": "919a56ab62b6d5e1219fe1d95248a2c5",
"original": "\"text to md5\""
}
contexthub.generic-jsonp範例存放區候選項可讓您從傳回JSON資料的JSONP服務或網站服務擷取資料。 對於此儲存候選項,請使用儲存配置提供有關要使用的JSONP服務的詳細資訊。
ContextHub.Store.JSONPStore
Javascript類的init函式定義了初始化此儲存候選項的config
對象。 config
物件包含service
物件,其中包含JSONP服務的詳細資訊。 若要設定存放區,請以JSON格式提供service
物件,作為Detail Configuration屬性的值。
要從jsontest.com站點的MD5服務中保存資料,請使用以下屬性中的建立ContextHub儲存區🔗過程:
配置標題: md5
商店類型: contexthub.generic-jsonp
必要: 選取
啟用: 選取
詳細資料組態 (JSON):
{
"service": {
"jsonp": false,
"timeout": 1000,
"ttl": 1800000,
"secure": false,
"host": "md5.jsontest.com",
"port": 80,
"params":{
"text":"text to md5"
}
}
}
將UI模組新增至ContextHub工具列,以顯示儲存在範例md5商店中的資料。 在此範例中,contexthub.base模組用於產生下列UI模組:
使用新增UI模組中的程式,將UI模組新增至現有UI模式,例如範例Perona UI模式。 對於UI模組,請使用下列屬性值:
UI模組標題: MD5
模組類型: contexthub.base
詳細資料組態 (JSON):
{
"icon": "coral-Icon--data",
"title": "MD5 Converstion",
"storeMapping": { "md5": "md5" },
"template": "<p> {{md5.original}}</p>;
<p>{{md5.md5}}</p>"
}
ContextHub的除錯模式可啟用,以允許疑難排解。 偵錯模式可透過ContextHub設定或透過CRXDE啟用。
編輯ContextHub的設定並核取選項Debug
使用CRXDE Lite將屬性debug
設為true,位於:
/conf/global/settings/cloudsettings
或/conf/<tenant>/settings/cloudsettings
若ContextHub設定仍位於其舊有路徑下,則設定debug property
的位置為/libs/settings/cloudsettings/legacy/contexthub
。
靜默模式隱藏所有調試資訊。 與可針對每個ContextHub配置獨立設定的一般除錯選項不同,靜默模式是全局設定,在ContextHub配置級別上取代任何調試設定。
這對您的發佈執行個體很實用,因為您完全不需要任何除錯資訊。 因為這是全域設定,所以會透過OSGi啟用。
http://<host>:<port>/system/console/configMgr
開啟Adobe Experience Manager Web控制台配置執行升級至AEM時,會備份ContextHub配置並將其儲存在安全位置。 在升級期間,會安裝預設的ContextHub設定,取代現有設定。 必須進行備份,才能保留您所做的任何更改或添加。
ContextHub配置儲存在名為contexthub
的資料夾中,位於以下節點下:
/conf/global/settings/cloudsettings
/conf/<tenant>/settings/cloudsettings
升級後,備份儲存在名為contexthub
的節點下的資料夾中:
/conf/global/settings/cloudsettings/default-pre-upgrade_yyyymmdd_xxxxxxx
或
/conf/<tenant>/settings/cloudsettings/default-pre-upgrade_yyyymmdd_xxxxxxx
節點名稱的yyyymmdd
部分是執行升級的日期。
若要恢復ContextHub配置,請使用CRXDE Lite將代表您的儲存、UI模式和UI模組的節點從default-pre-upgrade_yyyymmdd_xxxxxx
節點下方複製到以下位置:
/conf/global/settings/cloudsettings
或/conf/<tenant>/settings/cloudsettings