問題
ABP 預設會使用自己的驗證,如果要使用 Azure AD 驗證登入的話,
可以依 How to Use the Azure Active Directory Authentication for MVC / Razor Page Applications ,
來啟用 Azure AD OpenIdConnect 驗證登入,以下就一步步地來實作它
實作
1.註冊 App
到Portal Azure的Microsoft Entra ID中,
選點 Menu Manage -> App registrations 功能,點選「+ New registration」來註冊 App,
data:image/s3,"s3://crabby-images/756c8/756c8e2f1782076c95e4eb4dd815aa6864d25b12" alt="New registration"
輸入 App 的名稱,選擇 account type(如果是公司內用請選擇Single tenant),
Redirect URI (optional)請選擇Web及輸入 Abp 網站的 URL,並加上signin-oidc(例如https://localhost:44392/signin-oidc
),然後按下Register Button。
2.產生 Client Secrets
在已建立好的 App 中,選點 Menu Manage-> Certificates & secrets
點選Client secrets,按下「+ New client secret」,輸入 Description,選擇過期時間,再按下Add
data:image/s3,"s3://crabby-images/51f65/51f65723cbeb1e56cf495cd97f7afe6bb0d76ff3" alt="New client secret"
3.Copy client secret 的值
將 client secret 的值 Copy 存下來,如下圖
data:image/s3,"s3://crabby-images/6f165/6f1650ca85ab7429bfb11dcb4c8296fc7fbf667a" alt="Copy client secret"
4.Copy Directory (tenant) ID 及 Application (client) ID
點選 Menu Overview ,將 Directory (tenant) ID 及 Application (client) ID Copy 存下來
選選Endpoints可以知道要驗證的 URL,
如果是 Single Tenant ,OAuth 的 endpoint 會是 https://login.microsoftonline.com/{你的TenantId}/oauth2/v2.0
,如果是多租戶,原本的 TenantId 則改為 common
data:image/s3,"s3://crabby-images/ab1d8/ab1d8b295f70aefd75824a3cdd1b61cd444661ea" alt="App Endpoints"
5.在appsettings.json
中加入 Azure AD 的 App 設定值,
在How to Use the Azure Active Directory Authentication for MVC / Razor Page Applications的ResponseType是使用CodeIdToken
,這裡我們改用code
1 | "AzureAd": { |
6.在 Web 專案的Module檔案中的ConfigureAuthentication
Method 中設定啟用 Azure AD 驗證
在 Web 專案加入Microsoft.AspNetCore.Authentication.OpenIdConnect
套件,並修改ConfigureAuthentication
Method
ConfigureAuthentication Method,因為需要取得appsettings.json
中的設定值,所以要多一個IConfiguration configuration
的參數
1 | private void ConfigureAuthentication(ServiceConfigurationContext context, IConfiguration configuration) |
7.執行程式進行測試
在登入頁面中,點下Azure Active Directory OpenIdButton,
就會導到 Azure AD 進行登入驗證,如下圖
data:image/s3,"s3://crabby-images/92d3e/92d3e4e8303232d56fc6abb84551e625ff6fa74a" alt="Login"
data:image/s3,"s3://crabby-images/bb1fd/bb1fd8e5f73bbe8a30e4e3cdea69f08ddbab3b21" alt="Azure AD 登入"
Azure AD 登入驗證後,會回到 Abp 程式,進行註冊來將 User 新增到資料庫之中,如下圖
data:image/s3,"s3://crabby-images/e3497/e3497feb1e57e77dedec2b354edea2ed59332664" alt="註冊"
回到首頁後,就可以看到使用者已登入到系統,如下圖
data:image/s3,"s3://crabby-images/7f518/7f51805952526d7c51e558058b2fdcf29f896d18" alt="首頁"
參考資源
How to Use the Azure Active Directory Authentication for MVC / Razor Page Applications