Přihlášení uživatelů k ukázkové webové aplikaci ASP.NET v Microsoft Entra ID pro tenanta zákazníka
Tento návod používá ukázkovou ASP.NET webové aplikace k zobrazení základů moderního ověřování pomocí knihovny Microsoft Authentication Library for .NET a Microsoft Identity Web pro ASP.NET pro zpracování ověřování.
V tomto článku zaregistrujete webovou aplikaci v Centru pro správu Microsoft Entra a vytvoříte tok přihlášení a odhlášení uživatele. Přidružíte svoji webovou aplikaci k toku uživatele, stáhnete a aktualizujete ukázkovou ASP.NET webovou aplikaci pomocí vlastního ID Microsoft Entra pro podrobnosti tenanta zákazníků. Nakonec spustíte a otestujete ukázkovou webovou aplikaci.
Požadavky
- I když je možné použít jakékoli integrované vývojové prostředí, které podporuje ASP.NET aplikace, visual Studio Code se používá pro tuto příručku. Můžete si ho stáhnout ze stránky Stažené soubory .
- .NET 7.0 SDK.
- Microsoft Entra ID tenanta zákazníka. Pokud ještě nemáte, zaregistrujte si bezplatnou zkušební verzi.
Registrace webové aplikace
Pokud chcete aplikaci povolit přihlašování uživatelů pomocí Microsoft Entra, musí být Microsoft Entra ID pro zákazníky informováno o aplikaci, kterou vytvoříte. Registrace aplikace vytvoří vztah důvěryhodnosti mezi aplikací a Microsoft Entra. Když zaregistrujete aplikaci, externí ID vygeneruje jedinečný identifikátor označovaný jako ID aplikace (klienta), což je hodnota, která se používá k identifikaci vaší aplikace při vytváření žádostí o ověření.
Následující kroky ukazují, jak zaregistrovat aplikaci v Centru pro správu Microsoft Entra:
Přihlaste se k Centru pro správu Microsoft Entra alespoň jako vývojář aplikací.
Pokud máte přístup k více tenantům, přepněte na tenanta zákazníka pomocí filtru Adresáře a předplatná v horní nabídce.
Přejděte naAplikace>identit>Registrace aplikací.
Vyberte + Nová registrace.
Na stránce Zaregistrovat aplikaci , která se zobrazí;
- Zadejte smysluplný název aplikace, který se zobrazí uživatelům aplikace, například ciam-client-app.
- V části Podporované typy účtů vyberte Účty pouze v tomto organizačním adresáři.
Vyberte Zaregistrovat.
Po úspěšné registraci se zobrazí podokno Přehled aplikace. Poznamenejte si ID aplikace (klienta), které se má použít ve zdrojovém kódu aplikace.
Definování platformy a adres URL
Pokud chcete zadat typ aplikace pro registraci aplikace, postupujte takto:
- V části Spravovat vyberte Ověřování.
- Na stránce Konfigurace platformy vyberte Přidat platformu a pak vyberte Možnost Web .
- Jako identifikátory URI pro přesměrování zadejte
https://localhost:7274/signin-oidc
. - V části Adresa URL pro odhlášení z front-channel zadejte
https://localhost:7274/signout-callback-oidc
pro odhlášení. - Vyberte Konfigurovat a uložte změny.
Přidání tajného klíče klienta aplikace
Vytvořte tajný klíč klienta pro zaregistrovanou aplikaci. Aplikace používá tajný klíč klienta k prokázání své identity při žádosti o tokeny.
- Na stránce Registrace aplikací vyberte aplikaci, kterou jste vytvořili (například ciam-client-app), a otevřete tak její stránku Přehled.
- V části Spravovat vyberte Tajné kódy certifikátů&.
- Vyberte Nový tajný klíč klienta.
- Do pole Popis zadejte popis tajného klíče klienta (například tajný klíč klienta aplikace CIAM).
- V části Konec platnosti vyberte dobu platnosti tajného kódu (podle pravidel zabezpečení vaší organizace) a pak vyberte Přidat.
- Zaznamenejte hodnotu tajného klíče. Tuto hodnotu použijete pro konfiguraci v pozdějším kroku.
Poznámka
Po přechodu ze stránky Certifikáty a tajné kódy se hodnota tajného kódu znovu nezobrazí a v žádném případě se nedá načíst, proto ji nezapomeňte zaznamenat.
V případě zvýšeného zabezpečení zvažte použití certifikátů místo tajných klíčů klienta.
Udělení oprávnění rozhraní API
Na stránce Registrace aplikací vyberte aplikaci, kterou jste vytvořili (například ciam-client-app), a otevřete tak její stránku Přehled.
V části Spravovat vyberte Oprávnění rozhraní API.
V části Nakonfigurovaná oprávnění vyberte Přidat oprávnění.
Vyberte kartu Rozhraní MICROSOFT API .
V části Běžně používaná rozhraní MICROSOFT API vyberte Microsoft Graph.
Vyberte možnost Delegovaná oprávnění .
V části Vybrat oprávnění vyhledejte a vyberte oprávnění openid i offline_access .
Vyberte tlačítko Přidat oprávnění .
V tuto chvíli jste oprávnění přiřadili správně. Vzhledem k tomu, že tenant je tenant zákazníka, nemůžou s těmito oprávněními souhlasit samotní uživatelé příjemce. Jako správce musíte udělit souhlas s těmito oprávněními jménem všech uživatelů v tenantovi:
- Vyberte Udělit souhlas správce pro <název> vašeho tenanta a pak vyberte Ano.
- Vyberte Aktualizovat a pak ověřte, že se v části Stav pro <oba obory zobrazuje v části Stav udělené pro váš název> tenanta.
Vytvoření toku uživatele
Pomocí těchto kroků vytvořte tok uživatele, který může zákazník použít k přihlášení nebo registraci aplikace.
Přihlaste se k Centru pro správu Microsoft Entra alespoň jako správce toku uživatelů s externím ID.
Pokud máte přístup k více tenantům, přepněte na tenanta zákazníka pomocí filtru Adresáře a předplatná v horní nabídce.
Přejděte naToky uživatelůidentit>externích> identit.
Vyberte + Nový tok uživatele.
Na stránce Vytvořit :
Zadejte Název toku uživatele, například SignInSignUpSample.
V seznamu Zprostředkovatelé identit vyberte účty Email. Tento zprostředkovatel identity umožňuje uživatelům přihlásit se nebo se zaregistrovat pomocí jejich e-mailové adresy.
V části Email účty můžete vybrat jednu ze dvou možností. V tomto kurzu vyberte Email s heslem.
Email s heslem: Umožňuje novým uživatelům zaregistrovat se a přihlásit se pomocí e-mailové adresy jako přihlašovacího jména a hesla jako přihlašovacích údajů prvního faktoru.
Email jednorázové heslo: Umožňuje novým uživatelům zaregistrovat se a přihlásit se pomocí e-mailové adresy jako přihlašovacího jména a jednorázového e-mailového hesla jako jejich prvního faktoru přihlašovacích údajů.
Poznámka
Email jednorázové heslo musí být povolené na úrovni tenanta (Všichni zprostředkovatelé> identity Email jednorázové heslo), aby tato možnost byla dostupná na úrovni toku uživatele.
V části Atributy uživatele zvolte atributy, které chcete od uživatele při registraci shromáždit. Když vyberete Zobrazit více, můžete zvolit atributy a deklarace identity pro zemi/oblast, zobrazované jméno a PSČ. Vyberte OK. (Uživatelům se zobrazí výzva k zadání atributů pouze při první registraci.)
Vyberte Vytvořit. Nový tok uživatele se zobrazí v seznamu Toky uživatelů . V případě potřeby stránku aktualizujte.
Pokud chcete povolit samoobslužné resetování hesla, použijte postup v článku Povolení samoobslužného resetování hesla .
Přidružení webové aplikace k toku uživatele
I když k toku uživatele může být přidruženo mnoho aplikací, jedna aplikace může být přidružena pouze k jednomu toku uživatele. Tok uživatele umožňuje konfiguraci uživatelského prostředí pro konkrétní aplikace. Můžete například nakonfigurovat tok uživatele, který vyžaduje, aby se uživatelé přihlásili nebo se zaregistrovali pomocí telefonního čísla nebo e-mailové adresy.
V nabídce bočního panelu vyberte Identita.
Vyberte Externí identity a pak Toky uživatelů.
Na stránce Toky uživatelů vyberte název toku uživatele , který jste vytvořili dříve, například SignInSignUpSample.
V části Použít vyberte Aplikace.
Vyberte Přidat aplikaci.
Vyberte aplikaci ze seznamu, například ciam-client-app , nebo ji vyhledejte pomocí vyhledávacího pole a pak ji vyberte.
Zvolte Vybrat.
Klonování nebo stažení ukázkové webové aplikace
Pokud chcete získat ukázkový kód webové aplikace, můžete provést některou z následujících úloh:
Stáhněte si soubor .zip. Extrahujte soubor ukázkové aplikace do složky, kde je celková délka cesty 260 nebo méně znaků.
Spuštěním následujícího příkazu naklonujte ukázkovou webovou aplikaci z GitHubu:
git clone https://github.com/Azure-Samples/ms-identity-ciam-dotnet-tutorial.git
Konfigurace aplikace
Přejděte do kořenové složky ukázky, kterou jste stáhli, a do adresáře, který obsahuje ASP.NET ukázkovou aplikaci:
cd 1-Authentication\1-sign-in-aspnet-core-mvc
Otevřete soubor appsettings.json.
V části Autorita vyhledejte
Enter_the_Tenant_Subdomain_Here
a nahraďte ji subdoménou vašeho tenanta. Pokud je caseyjensen@onmicrosoft.comnapříklad primární doména vašeho tenanta , měli byste zadat hodnotu casyjensen.Enter_the_Application_Id_Here
Najděte hodnotu a nahraďte ji ID aplikace (ID klienta) aplikace, kterou jste zaregistrovali v Centru pro správu Microsoft Entra.Nahraďte
Enter_the_Client_Secret_Here
hodnotou tajného klíče klienta, kterou jste nastavili v části Přidat tajný klíč klienta aplikace.
Spuštění ukázky kódu
V prostředí nebo příkazovém řádku spusťte následující příkazy:
dotnet run
Otevřete webový prohlížeč a přejděte na
https://localhost:7274
.Přihlaste se pomocí účtu zaregistrovaného v tenantovi zákazníka.
Po přihlášení se zobrazí zobrazované jméno vedle tlačítka Odhlásit se , jak je znázorněno na následujícím snímku obrazovky.
Pokud se chcete z aplikace odhlásit, vyberte tlačítko Odhlásit se .