設定Cookie使用方式 configuring-cookie-usage

AEM提供的服務可讓您設定和控制Cookie在網頁中的使用方式:

  • 可設定的伺服器端服務會維護可用的Cookie清單。
  • JavaScript API可讓您的JavaScript程式碼確認可以使用Cookie。

使用此功能可確保您的頁面符合使用者對Cookie使用方式的同意。

設定允許的Cookie configuring-allowed-cookies

設定AdobeGranite選擇退出服務,指定如何在您的網頁上使用Cookie。 下表說明您可以設定的特性。

若要設定服務,您可以使用 網頁主控台將OSGi設定新增到存放庫. 下表說明任一方法所需的特性。 若為OSGi設定,服務PID為 com.adobe.granite.optout.

屬性名稱(Web主控台)
OSGi屬性名稱
說明
選擇退出Cookie
optout.cookies
Cookie的名稱,當顯示在使用者的裝置上時,表示使用者尚未同意使用Cookie。
選擇退出HTTP標題
optout.headers
表示使用者尚未同意使用Cookie的HTTP標頭名稱(如果存在)。
白名單Cookie
optout.whitelist.cookies
對網站運作而言不可或缺的Cookie清單,且可在未經使用者同意的情況下使用。

使用使用者端JavaScript來呼叫AdobeGranite選擇退出服務,以確認您可以使用Cookie。 使用Granite.OptOutUtil JavaScript物件來執行下列任何工作:

  • 取得Cookie名稱清單,該清單指出使用者不同意將Cookie用於追蹤目的。
  • 取得可用的Cookie清單。
  • 判斷網頁瀏覽器是否包含Cookie,指出使用者不同意使用Cookie進行追蹤。
  • 決定是否可使用特定Cookie。

granite.utils 使用者端資料庫資料夾 提供Granite.OptOutUtil物件。 將下列程式碼新增至您的頁面標題JSP,加入JavaScript程式庫的連結:

<ui:includeClientLib categories="granite.utils" />

例如,下列JavaScript函式會先決定是否允許使用COOKIE_NAME Cookie,再寫入至其中:

function writeCookie(value){
   if (!Granite.OptOutUtil.maySetCookie("COOKIE_NAME"))
      return;
   if (value) {
      value = encodeURIComponent(value);
      document.cookie = "COOKIE_NAME=" + value;
   }
}

Granite.OptOutUtil JavaScript物件 the-granite-optoututil-javascript-object

Granite.OptOutUtil可讓您判斷是否允許使用Cookie。

getCookieNames()函式 getcookienames-function

Cookie的名稱,當出現時,表示使用者未同意使用Cookie。

參數

無。

傳回

Cookie名稱陣列。

getWhitelistCookieNames()函式 getwhitelistcookienames-function

不論使用者同意為何,都可使用的Cookie名稱。

參數

無。

傳回

Cookie名稱陣列。

isOptedOut()函式 isoptedout-function

判斷使用者的瀏覽器是否包含未表示同意使用Cookie的任何Cookie。

參數

無。

傳回

布林值 true 如果找到表示不同意的Cookie,且值為 false 如果沒有Cookie表示不同意。

maySetCookie(cookieName)函式 maysetcookie-cookiename-function

決定特定Cookie是否可用於使用者的瀏覽器。 此函式等同於使用 isOptedOut 函式,可判斷指定的Cookie是否包含在要 getWhitelistCookieNames 函式傳回。

參數

  • cookieName:字串。 Cookie的名稱。

傳回

布林值 true 如果 cookieName 可使用,或的值 false 如果 cookieName 無法使用。

recommendation-more-help
19ffd973-7af2-44d0-84b5-d547b0dffee2