SAML 2.0驗證 saml-2-0-authentication

瞭解如何為您選擇的SAML 2.0相容的IDP設定及驗證一般使用者(而非AEM作者)。

AEM的SAMLas a Cloud Service為何?

SAML 2.0與AEM Publish (或Preview)整合,可讓AEM型網頁體驗的一般使用者向非AdobeIDP (身分提供者)進行驗證,並以已命名的授權使用者身分存取AEM。

AEM 作者
AEM 發佈
SAML 2.0支援
瞭解使用AEM的SAML 2.0流程

AEM Publish SAML整合的典型流程如下:

  1. 使用者向AEM Publish提出要求,表示需要驗證。

    • 使用者請求受CUG/ACL保護的資源。
    • 使用者請求受驗證需求約束的資源。
    • 使用者依循指向AEM登入端點的連結(即 /system/sling/login)以明確要求登入動作。
  2. AEM會向IDP發出AuthnRequest,要求IDP啟動驗證程式。

  3. 使用者向IDP進行驗證。

    • IDP會提示使用者輸入認證。
    • 使用者已透過IDP驗證,無需再提供認證。
  4. IDP會產生包含使用者資料的SAML宣告,並使用IDP的私人憑證加以簽署。

  5. IDP透過HTTPPOST,透過使用者的網頁瀏覽器,將SAML宣告傳送至AEM Publish。

  6. AEM Publish會收到SAML判斷提示,並使用IDP公開憑證驗證SAML判斷提示的完整性和真實性。

  7. AEM Publish會根據SAML 2.0 OSGi設定和SAML宣告的內容來管理AEM使用者記錄。

    • 建立使用者
    • 同步使用者屬性
    • 更新AEM使用者群組成員資格
  8. AEM發佈設定AEM login-token HTTP回應上的Cookie,用於向AEM Publish驗證後續請求。

  9. AEM發佈會將使用者重新導向至AEM發佈上的URL,如所指定 saml_request_path Cookie。

設定逐步說明

此影片逐步解說如何設定SAML 2.0與AEMas a Cloud Service發佈服務整合,以及使用Okta做為IDP。

先決條件

設定SAML 2.0驗證時,需要下列專案:

  • 部署管理員對Cloud Manager的存取權
  • AEM管理員對AEMas a Cloud Service環境的存取權
  • IDP的管理員存取權
  • 選擇性地存取用來加密SAML裝載的公開/私人金鑰組

SAML 2.0僅支援向AEM發佈或預覽驗證使用。 若要管理使用和IDP的AEM Author驗證, 將IDP與Adobe IMS整合.

在AEM上安裝IDP公開憑證

IDP的公開憑證會新增至AEM全域信任存放區,並用來驗證IDP傳送的SAML宣告是否有效。

SAML宣告簽署流程

SAML 2.0 - IDP SAML宣告簽署

  1. 使用者向IDP進行驗證。
  2. IDP會產生包含使用者資料的SAML宣告。
  3. IDP會使用IDP的私人憑證來簽署SAML宣告。
  4. IDP會向AEM發佈的SAML端點起始使用者端HTTPPOST(.../saml_login)包含簽署的SAML宣告。
  5. AEM Publish會收到包含已簽署SAML宣告的HTTPPOST,可以使用IDP公開憑證來驗證簽章。

將IDP公開憑證新增至全域信任存放區

  1. 取得 公開憑證 IDP中的檔案。 此憑證可讓AEM驗證IDP提供給AEM的SAML判斷提示。

    憑證為PEM格式,應類似於:

    code language-none
    -----BEGIN CERTIFICATE-----
    MIIC4jCBAcoCCQC33wnybT5QZDANBgkqhkiG9w0BAQsFADAyMQswCQYDVQQGEwJV
    ...
    m0eo2USlSRTVl7QHRTuiuSThHpLKQQ==
    -----END CERTIFICATE-----
    
  2. 以AEM管理員身分登入AEM Author。

  3. 瀏覽至 「工具>安全性>信任存放區」.

  4. 建立或開啟全域信任存放區。 如果建立全域信任存放區,請將密碼存放於安全的地方。

  5. 展開 從CER檔案新增憑證.

  6. 選取 選取憑證檔案,並上傳IDP提供的憑證檔案。

  7. 離開 將憑證對應到使用者 空白。

  8. 選取 提交.

  9. 新新增的憑證會出現在 從CRT檔案新增憑證 區段。

  10. 記下 別名,此值用於 SAML 2.0驗證處理常式OSGi設定.

  11. 選取「儲存並關閉」。

全域信任存放區在AEM Author上設定了IDP的公開憑證,但由於SAML僅用於AEM Publish,因此必須將全域信任存放區復寫到AEM Publish,才能在那裡存取IDP公開憑證。

將全域信任存放區復寫至AEM Publish

  1. 瀏覽至 「工具>部署>套件」.

  2. 建立套件

    • 封裝名稱: Global Trust Store
    • 版本: 1.0.0
    • 群組: com.your.company
  3. 編輯新的 全域信任存放區 封裝。

  4. 選取 篩選器 標籤,並為根路徑新增篩選器 /etc/truststore.

  5. 選取 完成 然後 儲存.

  6. 選取 建置 「 」的按鈕 全域信任存放區 封裝。

  7. 建置後,選取 更多 > 復寫 啟動全域信任存放區節點(/etc/truststore)至AEM Publish。

建立驗證服務金鑰存放區 authentication-service-keystore

需要建立驗證服務的金鑰存放區,當 SAML 2.0驗證處理常式OSGi設定屬性 handleLogout 設為 trueAuthnRequest簽署/SAML宣告加密 為必要項

  1. 以AEM管理員身分登入AEM Author,以上傳私密金鑰。

  2. 瀏覽至 「工具>安全性>使用者」,並選取 authentication-service 使用者,並選取 屬性 頂端動作列中的。

  3. 選取 金鑰存放區 標籤。

  4. 建立或開啟金鑰存放區。 如果建立金鑰存放區,請妥善儲存密碼。

  5. 選取「儲存並關閉」。

  6. 建立包含更新版本的套件 authentication-service 使用者。

    使用套件時,請使用下列臨時因應措施:

    1. 瀏覽至 「工具>部署>套件」.

    2. 建立套件

      • 封裝名稱: Authentication Service
      • 版本: 1.0.0
      • 群組: com.your.company
    3. 編輯新的 驗證服務金鑰存放區 封裝。

    4. 選取 篩選器 標籤,並為根路徑新增篩選器 /home/users/system/cq:services/internal/security/<AUTHENTICATION SERVICE UUID>/keystore.

      • <AUTHENTICATION SERVICE UUID> 可瀏覽至 「工具>安全性>使用者」,並選取 authentication-service 使用者。 UUID是URL的最後一部分。
    5. 選取 完成 然後 儲存.

    6. 選取 建置 「 」的按鈕 驗證服務金鑰存放區 封裝。

    7. 建置後,選取 更多 > 復寫 啟用驗證服務金鑰存放區以進行AEM發佈。

安裝AEM公開/私密金鑰組 install-aem-public-private-key-pair

安裝AEM公開/私密金鑰組為選用

AEM Publish可設定為簽署AuthnRequests (to IDP)及加密SAML宣告(to AEM)。 這是透過提供私密金鑰給AEM Publish並且比對公開金鑰給IDP來達成。

瞭解AuthnRequest簽署流程(選用)

AuthnRequest (起始登入程式的AEM Publish向IDP提出的請求)可由AEM Publish簽署。 為此,AEM Publish會使用私密金鑰對AuthnRequest簽名,讓IDP接著使用公開金鑰來驗證簽名。 這可向IDP保證AuthnRequest已啟動,並由AEM Publish請求,而非惡意的第三方。

SAML 2.0 - SP AuthnRequest簽署

  1. 使用者向AEM Publish發出HTTP請求,結果向IDP發出SAML驗證請求。
  2. AEM Publish會產生要傳送給IDP的SAML請求。
  3. AEM Publish使用AEM私密金鑰簽署SAML請求。
  4. AEM發佈會起始AuthnRequest,此HTTP使用者端重新導向至包含已簽署SAML請求的IDP。
  5. IDP會收到AuthnRequest,並使用AEM公開金鑰來驗證簽章,保證AEM Publish已起始AuthnRequest。
  6. AEM Publish接著會使用IDP公開憑證來驗證解密的SAML宣告的完整性和真實性。
瞭解SAML宣告加密流程(選擇性)

IDP與AEM Publish之間的所有HTTP通訊都應透過HTTPS,因此預設情況下是安全的。 不過,如有需要,SAML宣告可以加密,以備在HTTPS提供之保密性以外需要額外機密性的情況。 為此,IDP會使用私密金鑰加密SAML宣告資料,而AEM Publish會使用私密金鑰解密SAML宣告。

SAML 2.0 - SP SAML宣告加密

  1. 使用者向IDP進行驗證。
  2. IDP會產生包含使用者資料的SAML宣告,並使用IDP的私人憑證加以簽署。
  3. 然後IDP使用AEM公開金鑰加密SAML宣告,這需要AEM私密金鑰來解密。
  4. 加密的SAML宣告會透過使用者的網頁瀏覽器傳送至AEM Publish。
  5. AEM Publish會收到SAML宣告,並使用AEM私密金鑰將其解密。
  6. IDP會提示使用者進行驗證。

AuthnRequest簽署和SAML判斷提示加密都是選擇性的,但是兩者都是啟用的,使用 SAML 2.0驗證處理常式OSGi設定屬性 useEncryption,這表示兩者皆不可使用,或兩者皆不可使用。

AEM驗證服務金鑰存放區

  1. 取得用來簽署AuthnRequest以及加密SAML宣告的公開金鑰、私密金鑰(DER格式為PKCS#8)及憑證鏈結檔案(這有可能是公開金鑰)。 這些金鑰通常由IT組織的安全團隊提供。

    • 可使用產生自我簽署金鑰組 openssl
    code language-none
    $ openssl req -x509 -sha256 -days 365 -newkey rsa:4096 -keyout aem-private.key -out aem-public.crt
    
    # Provide a password (keep in safe place), and other requested certificate information
    
    # Convert the keys to AEM's required format
    $ openssl rsa -in aem-private.key -outform der -out aem-private.der
    $ openssl pkcs8 -topk8 -inform der -nocrypt -in aem-private.der -outform der -out aem-private-pkcs8.der
    
  2. 將公開金鑰上傳至IDP。

    • 使用 openssl 方法上,公開金鑰為 aem-public.crt 檔案。
  3. 以AEM管理員身分登入AEM Author,以上傳私密金鑰。

  4. 瀏覽至 「工具>安全性>信任存放區」,並選取 authentication-service 使用者,並選取 屬性 頂端動作列中的。

  5. 瀏覽至 「工具>安全性>使用者」,並選取 authentication-service 使用者,並選取 屬性 頂端動作列中的。

  6. 選取 金鑰存放區 標籤。

  7. 建立或開啟金鑰存放區。 如果建立金鑰存放區,請妥善儲存密碼。

  8. 選取 從DER檔案新增私密金鑰,並將私密金鑰和鏈結檔案新增至AEM:

    • 別名:提供有意義的名稱,通常是IDP的名稱。
    • 私密金鑰檔案:上傳私密金鑰檔案(DER格式的PKCS#8)。
      • 使用 openssl 方法,這是 aem-private-pkcs8.der 檔案
    • 選取憑證鏈結檔案:上傳隨附的鏈結檔案(可能是公開金鑰)。
      • 使用 openssl 方法,這是 aem-public.crt 檔案
    • 選取 提交
  9. 新新增的憑證會出現在 從CRT檔案新增憑證 區段。

  10. 選取「儲存並關閉」。

  11. 建立包含更新版本的套件 authentication-service 使用者。

    使用套件時,請使用下列臨時因應措施:

    1. 瀏覽至 「工具>部署>套件」.

    2. 建立套件

      • 封裝名稱: Authentication Service
      • 版本: 1.0.0
      • 群組: com.your.company
    3. 編輯新的 驗證服務金鑰存放區 封裝。

    4. 選取 篩選器 標籤,並為根路徑新增篩選器 /home/users/system/cq:services/internal/security/<AUTHENTICATION SERVICE UUID>/keystore.

      • <AUTHENTICATION SERVICE UUID> 可瀏覽至 「工具>安全性>使用者」,並選取 authentication-service 使用者。 UUID是URL的最後一部分。
    5. 選取 完成 然後 儲存.

    6. 選取 建置 「 」的按鈕 驗證服務金鑰存放區 封裝。

    7. 建置後,選取 更多 > 復寫 啟用驗證服務金鑰存放區以進行AEM發佈。

設定SAML 2.0驗證處理常式 configure-saml-2-0-authentication-handler

AEM SAML設定是透過 AdobeGranite SAML 2.0驗證處理常式 OSGi設定。
此設定是OSGi工廠設定,表示單一AEMas a Cloud Service發佈服務可能有多個SAML設定,涵蓋存放庫的分散資源樹狀結構;這對於多網站AEM部署很有用。

SAML 2.0驗證處理常式OSGi設定字彙表

AdobeGranite SAML 2.0驗證處理常式OSGi設定 configure-saml-2-0-authentication-handler-osgi-configuration

table 0-row-6 1-row-6 2-row-6 3-row-6 4-row-6 5-row-6 6-row-6 7-row-6 8-row-6 9-row-6 10-row-6 11-row-6 12-row-6 13-row-6 14-row-6 15-row-6 16-row-6 17-row-6 18-row-6 19-row-6 20-row-6 21-row-6 22-row-6 23-row-6 24-row-6 25-row-6 26-row-6 27-row-6 3-align-center 4-align-center 10-align-center 11-align-center 17-align-center 18-align-center 24-align-center 25-align-center 31-align-center 32-align-center 38-align-center 39-align-center 45-align-center 46-align-center 52-align-center 53-align-center 59-align-center 60-align-center 66-align-center 67-align-center 73-align-center 74-align-center 80-align-center 81-align-center 87-align-center 88-align-center 94-align-center 95-align-center 101-align-center 102-align-center 108-align-center 109-align-center 115-align-center 116-align-center 122-align-center 123-align-center 129-align-center 130-align-center 136-align-center 137-align-center 143-align-center 144-align-center 150-align-center 151-align-center 157-align-center 158-align-center 164-align-center 165-align-center 171-align-center 172-align-center 178-align-center 179-align-center 185-align-center 186-align-center 192-align-center 193-align-center
OSGi屬性 必填 值格式 預設值 說明
路徑 path 字串陣列 / 此驗證處理常式使用的AEM路徑。
IDP URL idpUrl 字串 IDP URL:傳送SAML驗證請求。
IDP憑證別名 idpCertAlias 字串 在AEM全域信任存放區中找到的IDP憑證別名
IDP HTTP重新導向 idpHttpRedirect 布林值 false 指出是否有HTTP重新導向至IDP URL,而非傳送AuthnRequest。 將設為 true 用於IDP啟動的驗證。
IDP識別碼 idpIdentifier 字串 唯一IDP ID可確保AEM使用者和群組的唯一性。 如果為空, serviceProviderEntityId 會改用。
判斷提示消費者服務URL assertionConsumerServiceURL 字串 AssertionConsumerServiceURL AuthnRequest中的URL屬性,指定 <Response> 訊息必須傳送到AEM。
SP實體ID serviceProviderEntityId 字串 向IDP唯一識別AEM;通常是AEM主機名稱。
SP加密 useEncryption 布林值 true 指示IDP是否加密SAML宣告。 需要 spPrivateKeyAliaskeyStorePassword 即將設定。
SP私密金鑰別名 spPrivateKeyAlias 字串 中私密金鑰的別名 authentication-service 使用者的金鑰存放區。 下列情況必填 useEncryption 設為 true.
SP金鑰庫密碼 keyStorePassword 字串 'authentication-service'使用者金鑰存放區的密碼。 下列情況必填 useEncryption 設為 true.
預設重新導向 defaultRedirectUrl 字串 / 成功驗證後的預設重新導向URL。 可以是AEM主機的相對值(例如 /content/wknd/us/en/html)。
使用者ID屬性 userIDAttribute 字串 uid 包含AEM使用者之使用者ID的SAML宣告屬性名稱。 留空將使用 Subject:NameId.
自動建立AEM使用者 createUser 布林值 true 表示是否會在成功驗證時建立AEM使用者。
AEM使用者中間路徑 userIntermediatePath 字串 建立AEM使用者時,此值會作為中繼路徑(例如, /home/users/<userIntermediatePath>/jane@wknd.com)。 需要 createUser 將設為 true.
AEM使用者屬性 synchronizeAttributes 字串陣列 要儲存在AEM使用者上的SAML屬性對應清單,格式為 [ "saml-attribute-name=path/relative/to/user/node" ] (例如, [ "firstName=profile/givenName" ])。 請參閱 原生AEM屬性的完整清單.
將使用者新增至AEM群組 addGroupMemberships 布林值 true 表示在成功驗證後,AEM使用者是否自動新增到AEM使用者群組。
AEM群組成員資格屬性 groupMembershipAttribute 字串 groupMembership SAML宣告屬性的名稱,其中包含使用者應新增至的AEM使用者群組清單。 需要 addGroupMemberships 將設為 true.
預設AEM群組 defaultGroups 字串陣列 已驗證身分的AEM使用者群組清單會一律新增至(例如 [ "wknd-user" ])。 需要 addGroupMemberships 將設為 true.
NameIDPolicy格式 nameIdFormat 字串 urn:oasis:names:tc:SAML:2.0:nameid-format:transient 要在AuthnRequest訊息中傳送的NameIDPolicy格式引數值。
儲存SAML回應 storeSAMLResponse 布林值 false 顯示 samlResponse 值儲存在AEM上 cq:User 節點。
處理登出 handleLogout 布林值 false 指出此SAML驗證處理常式是否處理登出要求。 需要 logoutUrl 即將設定。
登出URL logoutUrl 字串 IDP的URL,將SAML登出請求傳送至此處。 下列情況必填 handleLogout 設為 true.
時鐘公差 clockTolerance 整數 60 驗證SAML宣告時,IDP和AEM (SP)時鐘扭曲容許度。
摘要方法 digestMethod 字串 http://www.w3.org/2001/04/xmlenc#sha256 IDP在簽署SAML訊息時使用的摘要演演算法。
簽章方法 signatureMethod 字串 http://www.w3.org/2001/04/xmldsig-more#rsa-sha256 IDP在簽署SAML訊息時使用的簽章演演算法。
身分同步型別 identitySyncType defaultidp default 不要變更 from AEMas a Cloud Service的預設。
服務排名 service.ranking 整數 5002 排名較高的組態較偏好相同組態 path.

AEM使用者屬性 aem-user-attributes

AEM會使用以下使用者屬性,這些屬性可透過 synchronizeAttributes AdobeGranite SAML 2.0驗證處理常式OSGi設定中的屬性。 任何IDP屬性都可以同步至任何AEM使用者屬性,但是對應至AEM使用屬性屬性(如下所列)可讓AEM自然地使用這些屬性。

table 0-row-2 1-row-2 2-row-2 3-row-2 4-row-2 5-row-2 6-row-2 7-row-2 8-row-2 9-row-2 10-row-2 11-row-2
使用者屬性 相對屬性路徑,從 rep:User 節點
標題(如 Mrs) profile/title
名字(即名字) profile/givenName
姓氏 profile/familyName
職稱 profile/jobTitle
電子郵件地址 profile/email
街道地址 profile/street
城市 profile/city
郵遞區號 profile/postalCode
國家/地區 profile/country
電話號碼 profile/phoneNumber
關於我 profile/aboutMe
  1. 在專案中建立OSGi設定檔案: /ui.config/src/main/content/jcr_root/wknd-examples/osgiconfig/config.publish/com.adobe.granite.auth.saml.SamlAuthenticationHandler~saml.cfg.json 並在IDE中開啟。

    • 變更 /wknd-examples/ 至您的 /<project name>/
    • 之後的識別碼 ~ 在檔案名稱中應唯一識別此設定,因此可以是IDP的名稱,例如 ...~okta.cfg.json. 值應為英數字元和連字型大小。
  2. 將下列JSON貼入 com.adobe.granite.auth.saml.SamlAuthenticationHandler~...cfg.json 檔案並更新 wknd 視需要提供參考。

    code language-json
    {
        "path": [ "/content/wknd", "/content/dam/wknd" ],
        "idpCertAlias": "$[env:SAML_IDP_CERT_ALIAS;default=certalias___1652125559800]",
        "idpIdentifier": "$[env:SAML_IDP_ID;default=http://www.okta.com/exk4z55r44Jz9C6am5d7]",
        "idpUrl": "$[env:SAML_IDP_URL;default=https://dev-5511372.okta.com/app/dev-5511372_aemasacloudservice_1/exk4z55r44Jz9C6am5d7/sso/saml]",
        "serviceProviderEntityId": "$[env:SAML_AEM_ID;default=https://publish-p123-e456.adobeaemcloud.com]",
        "useEncryption": false,
        "createUser": true,
        "userIntermediatePath": "wknd/idp",
        "synchronizeAttributes":[
            "firstName=profile/givenName"
        ],
        "addGroupMemberships": true,
        "defaultGroups": [
            "wknd-users"
        ]
    }
    
  3. 依專案要求更新值。 請參閱 SAML 2.0驗證處理常式OSGi設定字彙表 以上為設定屬性說明

  4. 值可能會隨著發行週期不同步變更,或類似環境型別/服務層之間的值不同時,建議使用OSGi環境變數和秘密,但並非必要。 預設值可使用 $[env:..;default=the-default-value]" 語法如上所示。

每個環境的OSGi設定(config.publish.devconfig.publish.stage、和 config.publish.prod),如果SAML設定在不同環境之間不同,則可以使用特定屬性來定義。

使用加密

時間 加密AuthnRequest和SAML宣告,則需要下列屬性: useEncryptionspPrivateKeyAlias、和 keyStorePassword. 此 keyStorePassword 包含密碼,因此值不得儲存在OSGi設定檔案中,而是使用插入 密碼設定值

可選擇更新OSGi設定以使用加密
  1. 開啟 /ui.config/src/main/content/jcr_root/wknd-examples/osgiconfig/config.publish/com.adobe.granite.auth.saml.SamlAuthenticationHandler~saml.cfg.json 在您的IDE中。

  2. 新增三個屬性 useEncryptionspPrivateKeyAlias、和 keyStorePassword 如下所示。

    code language-json
    {
    "path": [ "/content/wknd", "/content/dam/wknd" ],
    "idpCertAlias": "$[env:SAML_IDP_CERT_ALIAS;default=certalias___1234567890]",
    "idpIdentifier": "$[env:SAML_IDP_ID;default=http://www.okta.com/abcdef1235678]",
    "idpUrl": "$[env:SAML_IDP_URL;default=https://dev-5511372.okta.com/app/dev-123567890_aemasacloudservice_1/abcdef1235678/sso/saml]",
    "serviceProviderEntityId": "$[env:SAML_AEM_ID;default=https://publish-p123-e456.adobeaemcloud.com]",
    "useEncryption": true,
    "spPrivateKeyAlias": "$[env:SAML_AEM_KEYSTORE_ALIAS;default=aem-saml-encryption]",
    "keyStorePassword": "$[secret:SAML_AEM_KEYSTORE_PASSWORD]",
    "createUser": true,
    "userIntermediatePath": "wknd/idp"
    "synchronizeAttributes":[
        "firstName=profile/givenName"
    ],
    "addGroupMemberships": true,
    "defaultGroups": [
        "wknd-users"
    ]
    }
    
  3. 加密所需的三個OSGi設定屬性是:

  • useEncryption 設為 true
  • spPrivateKeyAlias 包含SAML整合所用私密金鑰的金鑰存放區專案別名。
  • keyStorePassword 包含 OSGi密碼設定變數 包含 authentication-service 使用者金鑰存放區的密碼。

設定反向連結篩選器

在SAML驗證程式期間,IDP會向AEM Publish的使用者端起始使用者端HTTPPOST .../saml_login 端點。 如果IDP和AEM Publish存在於不同來源,AEM Publish的 反向連結篩選器 是透過OSGi設定來設定,以允許來自IDP來源的HTTP POST。

  1. 建立(或編輯)您專案中的OSGi設定檔案,位於 /ui.config/src/main/content/jcr_root/wknd-examples/osgiconfig/config.publish/org.apache.sling.security.impl.ReferrerFilter.cfg.json.

    • 變更 /wknd-examples/ 至您的 /<project name>/
  2. 確保 allow.empty 值設定為 true,則 allow.hosts (或者如果您願意, allow.hosts.regexp)包含IDP的來源,以及 filter.methods 包含 POST. OSGi設定應該類似於:

    code language-json
    {
        "allow.empty": true,
        "allow.hosts.regexp": [ ],
        "allow.hosts": [
            "$[env:SAML_IDP_REFERRER;default=dev-123567890.okta.com]"
        ],
        "filter.methods": [
            "POST",
        ],
        "exclude.agents.regexp": [ ]
    }
    

AEM Publish支援單一反向連結篩選設定,因此請將SAML設定需求與任何現有設定合併。

每個環境的OSGi設定(config.publish.devconfig.publish.stage、和 config.publish.prod)可使用特定屬性定義,如果 allow.hosts (或 allow.hosts.regex)因環境而異。

設定跨原始資源共用(CORS)

在SAML驗證程式期間,IDP會向AEM Publish的使用者端起始使用者端HTTPPOST .../saml_login 端點。 如果IDP和AEM Publish存在於不同的主機/網域中,則AEM Publish的 CRoss-Origin資源共用(CORS) 必須設定為允許來自IDP主機/網域的HTTP POST。

此HTTPPOST請求的 Origin 標題的值通常與AEM發佈主機不同,因此需要CORS設定。

在本機AEM SDK上測試SAML驗證時(localhost:4503),則IDP可設定 Origin 頁首至 null. 如果是,請新增 "null"alloworigin 清單。

  1. 在專案中建立OSGi設定檔案: /ui.config/src/main/content/jcr_root/wknd-examples/osgiconfig/config.publish/com.adobe.granite.cors.impl.CORSPolicyImpl~saml.cfg.json

    • 變更 /wknd-examples/ 至您的專案名稱
    • 之後的識別碼 ~ 在檔案名稱中應唯一識別此設定,因此可以是IDP的名稱,例如 ...CORSPolicyImpl~okta.cfg.json. 值應為英數字元和連字型大小。
  2. 將下列JSON貼入 com.adobe.granite.cors.impl.CORSPolicyImpl~...cfg.json 檔案。

{
    "alloworigin": [
        "$[env:SAML_IDP_ORIGIN;default=https://dev-1234567890.okta.com]",
        "null"
    ],
    "allowedpaths": [
        ".*/saml_login"
    ],
    "supportedmethods": [
        "POST"
    ]
}

每個環境的OSGi設定(config.publish.devconfig.publish.stage、和 config.publish.prod)可使用特定屬性定義,如果 alloworiginallowedpaths 因環境而異。

設定AEM Dispatcher以允許SAML HTTP POST

在成功驗證IDP之後,IDP將會協調HTTPPOST以傳回AEM登入頁面 /saml_login 端點(設定於IDP)。 此HTTPPOST至 /saml_login Dispatcher預設會加以封鎖,因此必須使用下列Dispatcher規則明確允許:

  1. 開啟 dispatcher/src/conf.dispatcher.d/filters/filters.any 在您的IDE中。
  2. 在檔案底部新增允許規則,將HTTP POST新增至結尾為 /saml_login.
...

# Allow SAML HTTP POST to ../saml_login end points
/0190 { /type "allow" /method "POST" /url "*/saml_login" }

如果已設定Apache Webserver上的URL重寫(dispatcher/src/conf.d/rewrites/rewrite.rules),確定向 .../saml_login 不會意外損壞端點。

啟用資料同步並封裝Token

一旦SAML驗證流程在AEM Publish中建立使用者,AEM使用者節點即可在整個AEM Publish服務層級中進行驗證。
此需要 資料同步封裝的Token 將由AEM Publish服務的Adobe支援啟用。

傳送請求給Adobe客戶支援(透過 AdminConsole >支援)要求:

方案X和環境Y的AEM Publish服務已啟用資料同步和封裝權杖。

部署SAML設定

OSGi設定必須提交到Git並使用Cloud Manager部署到AEMas a Cloud Service。

$ git remote -v
adobe   https://git.cloudmanager.adobe.com/myOrg/myCloudManagerGit/ (fetch)
adobe   https://git.cloudmanager.adobe.com/myOrg/myCloudManagerGit/ (push)
$ git add .
$ git commit -m "SAML 2.0 configurations"
$ git push adobe saml-auth:develop

部署目標Cloud Manager Git分支(在此範例中, develop),使用完整棧疊部署管道。

recommendation-more-help
4859a77c-7971-4ac9-8f5c-4260823c6f69