Självstudie: Lägga till inloggning i ett program
I föregående självstudie skapades ett ASP.NET Core-projekt och konfigurerades för autentisering. Den här självstudien installerar de paket som krävs och lägger till kod som implementerar autentisering i inloggnings- och utloggningsmiljön.
I den här självstudien:
- Identifiera och installera De NuGet-paket som behövs för autentisering
- Implementera autentisering i koden
- Lägg till inloggnings- och utloggningsfunktionerna
Förutsättningar
- Slutförande av förutsättningarna och stegen i Självstudie: Förbereda ett program för autentisering.
Installera identitetspaket
Identitetsrelaterade NuGet-paket måste installeras i projektet för att autentisering av användare ska kunna aktiveras.
- På den översta menyn i Visual Studio väljer du Verktyg > NuGet Package Manager > Hantera NuGet-paket för lösning.
- Med fliken Bläddra markerad söker du efter och väljer Microsoft.Identity.Web.UI. Markera kryssrutan Projekt och välj sedan Installera.
- Upprepa detta för Microsoft.Identity.Web.Diagnostics och Microsoft.Identity.Web.DownstreamApi.
Implementera autentisering och hämta token
Öppna Program.cs och ersätt hela filinnehållet med följande kodfragment:
// <ms_docref_import_types> using Microsoft.AspNetCore.Authorization; using Microsoft.AspNetCore.Mvc.Authorization; using Microsoft.Identity.Web; using Microsoft.Identity.Web.UI; // </ms_docref_import_types> // <ms_docref_add_msal> WebApplicationBuilder builder = WebApplication.CreateBuilder(args); IEnumerable<string>? initialScopes = builder.Configuration.GetSection("DownstreamApi:Scopes").Get<IEnumerable<string>>(); builder.Services.AddMicrosoftIdentityWebAppAuthentication(builder.Configuration, "AzureAd") .EnableTokenAcquisitionToCallDownstreamApi(initialScopes) .AddDownstreamApi("DownstreamApi", builder.Configuration.GetSection("DownstreamApi")) .AddInMemoryTokenCaches(); // </ms_docref_add_msal> // <ms_docref_add_default_controller_for_sign-in-out> builder.Services.AddRazorPages().AddMvcOptions(options => { var policy = new AuthorizationPolicyBuilder() .RequireAuthenticatedUser() .Build(); options.Filters.Add(new AuthorizeFilter(policy)); }).AddMicrosoftIdentityUI(); // </ms_docref_add_default_controller_for_sign-in-out> // <ms_docref_enable_authz_capabilities> WebApplication app = builder.Build(); app.UseAuthentication(); app.UseAuthorization(); // </ms_docref_enable_authz_capabilities> app.UseHttpsRedirection(); app.UseStaticFiles(); app.UseRouting(); app.MapRazorPages(); app.MapControllers(); app.Run();
Lägg till inloggnings- och utloggningsupplevelsen
När du har installerat NuGet-paketen och lagt till nödvändig kod för autentisering lägger du till inloggnings- och utloggningsfunktionerna.
Skapa filen _LoginPartial.cshtml
- Expandera Sidor, högerklicka på Delad och välj sedan Lägg till > Razor-sida.
- Välj Razor-sida – Tom och välj sedan Lägg till.
- Ange _LoginPartial.cshtml som namn och välj sedan Lägg till.
Redigera filen _LoginPartial.cshtml
Öppna _LoginPartial.cshtml och lägg till följande kod för att lägga till inloggnings- och utloggningsupplevelsen:
@using System.Security.Principal <ul class="navbar-nav"> @if (User.Identity?.IsAuthenticated == true) { <li class="nav-item"> <span class="navbar-text text-dark">Hello @User.Identity?.Name!</span> </li> <li class="nav-item"> <a class="nav-link text-dark" asp-area="MicrosoftIdentity" asp-controller="Account" asp-action="SignOut">Sign out</a> </li> } else { <li class="nav-item"> <a class="nav-link text-dark" asp-area="MicrosoftIdentity" asp-controller="Account" asp-action="SignIn">Sign in</a> </li> } </ul>
Öppna _Layout.cshtml och lägg till en referens som
_LoginPartial
skapades i föregående steg. Den här enkla linjen ska placeras mellan</ul>
och</div>
:</ul> <partial name="_LoginPartial" /> </div>