在範例 WPF 傳統型應用程式中登入使用者
本指南使用範例 Windows Presentation Foundation (WPF) 應用程式來示範如何將驗證新增至 WPF 傳統型應用程式。 範例應用程式可讓使用者登入和登出。傳統型範例應用程式會使用適用於 .NET 的 Microsoft 驗證程式庫來處理驗證。
必要條件
- Visual Studio Code 或其他程式碼編輯器。
- .NET 7.0 或更新版本。
- 外部租用戶。 若要建立一個,請從下列方法中選擇:
- (建議)使用Microsoft Entra 外部 ID 擴充功能,直接在 Visual Studio Code 中設定外部租用戶使用者。
- 在 Microsoft Entra 系統管理中心建立新的外部租用戶。
註冊傳統型應用程式
若要讓應用程式能夠使用 Microsoft Entra 登入使用者,Microsoft Entra 外部 ID 必須知道您建立的應用程式。 應用程式註冊會在應用程式與 Microsoft Entra 之間建立信任關係。 註冊應用程式時,外部 ID 會產生稱為「應用程式 (用戶端) 識別碼」的唯一識別碼,這個值可在建立驗證要求時用來識別您的應用程式。
下列步驟顯示如何在 Microsoft Entra 系統管理中心內註冊您的應用程式:
至少以應用程式開發人員的身分登入 Microsoft Entra 系統管理中心。
如果您有權存取多個租用戶,請使用頂端功能表中的 [設定] 圖示 ,以從 [目錄 + 訂用帳戶] 功能表切換至您的外部租用戶。
瀏覽至 [身分識別] > [應用程式] > [應用程式註冊]。
選取 + 新增註冊。
在出現的 [註冊應用程式] 頁面中;
- 輸入要向應用程式使用者顯示的有意義應用程式「名稱」,例如 ciam-client-app。
- 在 [支援的帳戶類型] 底下,選取 [僅在此組織目錄中的帳戶]。
選取註冊。
應用程式的 [概觀] 窗格會在成功註冊時顯示。 記錄 [應用程式 (用戶端) 識別碼],以用於您的應用程式原始程式碼。
指定應用程式平台
若要在應用程式註冊中指定您的應用程式類型,請遵循下列步驟:
- 在 [管理] 底下,選取 [驗證]。
- 在 [平台設定] 頁面中,選取 [新增平台],然後選取 [行動應用程式與傳統型應用程式] 選項。
- 在 [自訂重新導向 URI] 下方的輸入欄位中,手動輸入
https://login.microsoftonline.com/common/oauth2/nativeclient
,然後選取 [設定]。 如果在選取方塊中選取此 URI,您可能會收到重新導向 URI 錯誤。
授與管理員同意
註冊應用程式之後,就會獲 指派User.Read 許可權。 不過,由於租使用者是外部租使用者,因此客戶使用者本身無法同意此許可權。 身為管理員的您必須代表租用戶中的所有使用者同意此權限:
從 [應用程式註冊] 頁面中,選取您建立的應用程式 (例如 ciam-client-app),以開啟其 [概觀] 頁面。
在 [管理] 之下選取 [API 權限]。
- 選取 [代表 <您的租用戶名稱> 授與管理員同意],然後選取 [是]。
- 選取 [重新整理],然後確認 [為租用戶名稱>授與] <出現在許可權的 [狀態] 底下。
建立使用者流程
請遵循下列步驟來建立客戶可用來登入或註冊應用程式的使用者流程。
至少以外部 ID 使用者流程管理員的身分登入 Microsoft Entra 系統管理中心。
如果您有權存取多個租用戶,請使用頂端功能表中的 [設定] 圖示 ,以從 [目錄 + 訂用帳戶] 功能表切換至您的外部租用戶。
瀏覽至 [身分識別] > [外部身分識別] > [使用者流程]。
選取 [+ 新增使用者流程]。
在 [建立] 頁面上:
輸入使用者流程的 [名稱],例如 SignInSignUpSample。
在 [識別提供者] 清單中,選取 [電子郵件帳戶]。 此識別提供者可讓使用者使用其電子郵件地址來登入或註冊。
在 [電子郵件帳戶] 下方,您可以選取兩個選項中的其中一個。 在本教學課程中,選取 [電子郵件和密碼]。
- 電子郵件和密碼:可讓新使用者使用電子郵件地址作為登入名稱,並使用密碼作為其第一個要素認證來註冊和登入。
- 電子郵件一次性密碼:可讓新使用者使用電子郵件地址作為登入名稱,並使用電子郵件一次性密碼作為其第一個要素認證來註冊和登入。 電子郵件一次性密碼必須在租用戶層級啟用 ([所有識別提供者] > [電子郵件一次性密碼]),此選項才能在使用者流程層級使用。
在 [使用者屬性] 下方,選擇您想要在註冊時向使用者收集的屬性。 選取 [顯示更多],即可選擇 [國家/地區]、[顯示名稱] 和 [郵遞區號] 的屬性和宣告。 選取 [確定]。 (只有在使用者第一次註冊時,才會提示使用者輸入屬性。)
選取 建立。 新的使用者流程會出現在 [使用者流程] 清單中。 如有需要,請重新整理頁面。
若要啟用自助式密碼重設,請使用啟用自助式密碼重設一文中的步驟。
將 WPF 應用程式與使用者流程產生關聯
若要讓客戶使用者在使用您的應用程式時看到註冊或登入體驗,您必須將您的應用程式與使用者流程關聯起來。 雖然許多應用程式可以與您的使用者流程產生關聯,但單一應用程式只能與一個使用者流程產生關聯。
在側邊欄功能表上,選取 [身分識別]。
選取 [外部身分識別],然後選取 [使用者流程]。
在 [使用者流程] 頁面中,選取您稍早建立的 [使用者流程名稱],例如 SignInSignUpSample。
在 [使用] 下方,選取 [應用程式]。
選取新增應用程式。
從清單中選取應用程式 (例如 ciam-client-app),或使用搜尋方塊來尋找應用程式並選取。
選擇選取。
將應用程式與使用者流程關聯後,您即可從 Microsoft Entra 系統管理中心使用您的應用程式模擬使用者的註冊或登入體驗,以測試您的使用者流程。 若要這麼做,請使用測試註冊和登入使用者流程中的步驟。
複製或下載範例 WPF 應用程式
若要取得範例應用程式,您可以從 GitHub 加以複製,或將其下載為 .zip 檔案。
若要複製範例,請開啟命令提示字元,並瀏覽至您想要建立專案的位置,然後輸入下列命令:
git clone https://github.com/Azure-Samples/ms-identity-ciam-dotnet-tutorial.git
下載 .zip 檔案 (英文)。 將其解壓縮到名稱長度少於 260 個字元的檔案路徑。
設定範例 WPF 應用程式
在 IDE (例如 Visual Studio 或 Visual Studio Code) 中開啟專案以設定程式碼。
在您的程式碼編輯器中,開啟 ms-identity-ciam-dotnet-tutorial>1-Authentication>5-sign-in-dotnet-wpf 資料夾中的 appsettings.json 檔案。
將
Enter_the_Application_Id_Here
取代為您稍早所註冊應用程式的應用程式 (用戶端) 識別碼。將
Enter_the_Tenant_Subdomain_Here
取代為目錄 (租用戶) 子網域。 例如,若主要網域是 contoso.onmicrosoft.com,請將Enter_the_Tenant_Subdomain_Here
取代為 contoso。 如果您沒有主要網域,請了解如何讀取租用戶詳細資料。
執行並測試範例 WPF 傳統型應用程式
開啟主控台視窗,並變更至包含 WPF 傳統型範例應用程式的目錄:
cd 1-Authentication\5-sign-in-dotnet-wpf
在您的終端機中,執行下列命令來執行應用程式:
dotnet run
啟動範例之後,您應該會看到含有 [登入] 按鈕的視窗。 選取 [登入] 按鈕。
在登入頁面上,輸入您的帳戶電子郵件地址。 如果您沒有帳戶,請選取 [沒有帳戶? 建立一個],以啟動註冊流程。 請遵循此流程來建立新的帳戶並登入。
登入之後,您會看到顯示成功登入的畫面,以及已擷取權杖中所儲存使用者帳戶的基本資訊。 基礎資訊會顯示在登入畫面的 [權杖資訊] 區段中
運作方式
公用用戶端應用程式的主要設定會在 App.xaml.cs 檔案內處理。 PublicClientApplication
會隨著儲存存取權杖的快取一起初始化。 應用程式會先檢查是否有可用來登入使用者的快取權杖。 如果沒有快取的權杖,系統會提示使用者提供認證並登入。 登出後,就會清除所有帳戶和所有對應存取權杖的快取。
相關內容
- 使用我們多部分的教學課程系列,從頭開始建置此 WPF 傳統型應用程式
- 啟用密碼重設。
- 自訂預設商標。
- 設定以 Google 登入 (部分機器翻譯)。