Přihlášení uživatelů v ukázkové React jednostránkové aplikaci (SPA)
Tato příručka používá ukázkovou React jednostránkovou aplikaci (SPA), která ukazuje, jak přidat ověřování do spa. Toto spa umožňuje uživatelům přihlásit se a odhlásit se pomocí vašeho Microsoft Entra ID pro tenanta zákazníka. Ukázka používá ke zpracování ověřování knihovnu Microsoft Authentication Library for JavaScript (MSAL.js).
Požadavky
- I když je možné použít jakékoli integrované vývojové prostředí, které podporuje React aplikace, pro tuto příručku se používá Visual Studio Code. Můžete si ho stáhnout ze stránky Stažené soubory .
- Node.js.
- Microsoft Entra ID tenanta zákazníka. Pokud ještě nemáte, zaregistrujte si bezplatnou zkušební verzi.
Registrace SPA v Centru pro správu Microsoft Entra
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.
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 SPA .
- Jako identifikátory URI pro přesměrování zadejte
http://localhost:3000/auth/redirect
- Vyberte Konfigurovat a uložte změny.
- Na stránce Konfigurace platformy v nové jednostránkové aplikaci , která se zobrazila, vyberte Přidat identifikátor URI a pak zadejte
http://localhost:3000/
- Vyberte Uložit , uložte změny a ujistěte se, že jsou uvedené oba identifikátory URI.
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í spa 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ázky SPA
Pokud chcete získat ukázkové spa, můžete zvolit jednu z následujících možností:
Naklonujte úložiště pomocí Gitu:
git clone https://github.com/Azure-Samples/ms-identity-ciam-javascript-tutorial.git
Pokud se rozhodnete stáhnout .zip
soubor, extrahujte soubor ukázkové aplikace do složky, kde je celková délka cesty 260 nebo méně znaků.
Instalace závislostí projektu
Otevřete okno terminálu v kořenovém adresáři ukázkového projektu a zadáním následujícího fragmentu kódu přejděte do složky projektu:
cd 1-Authentication\1-sign-in-react\SPA
Nainstalujte závislosti projektu:
npm install
Konfigurace ukázkového SPA
- Otevřete SPA\src\authConfig.js a nahraďte následující hodnotami získanými z Centra pro správu Microsoft Entra.
clientId
– Identifikátor aplikace, označovaný také jako klient. NahraďteEnter_the_Application_Id_Here
hodnotou ID aplikace (klienta), která byla zaznamenána dříve na stránce přehledu registrované aplikace.authority
– Instance zprostředkovatele identity a cílová skupina přihlašování pro aplikaci. NahraďteEnter_the_Tenant_Name_Here
názvem vašeho Microsoft Entra ID tenanta zákazníka.- ID tenanta je identifikátor tenanta, ve kterém je aplikace zaregistrovaná.
_Enter_the_Tenant_Info_Here
Nahraďte hodnotou ID adresáře (tenanta), která byla zaznamenána dříve na stránce přehledu registrované aplikace.
- Soubor uložte.
Spuštění projektu a přihlášení
Byly přidány všechny požadované fragmenty kódu, takže aplikaci teď můžete volat a testovat ve webovém prohlížeči.
Otevřete nový terminál tak, že vyberete Terminál>Nový terminál.
Spuštěním následujícího příkazu spusťte webový server.
cd 1-Authentication\1-sign-in-react\SPA npm start
Otevřete webový prohlížeč a přejděte na adresu
http://localhost:3000/
.Přihlaste se pomocí účtu zaregistrovaného v tenantovi Microsoft Entra pro zákazníky.
Po přihlášení se zobrazí zobrazované jméno vedle tlačítka Odhlásit se .