ASP.NET Core로 인증 및 Id 마이그레이션Migrate Authentication and Identity to ASP.NET Core

작성자: Steve SmithBy Steve Smith

이전 문서에서에서는 ASP.NET MVC 프로젝트에서 ASP.NET Core MVC 구성을 마이그레이션할합니다.In the previous article, we migrated configuration from an ASP.NET MVC project to ASP.NET Core MVC. 이 문서에서는 등록, 로그인 및 사용자 관리 기능을 마이그레이션할 했습니다.In this article, we migrate the registration, login, and user management features.

Id 및 멤버 자격을 구성 합니다.Configure Identity and Membership

ASP.NET MVC에서 인증 및 id 기능에는 ASP.NET Identity를 사용 하 여 구성 됩니다 Startup.Auth.csIdentityConfig.cs에 있는 App_Start 폴더입니다.In ASP.NET MVC, authentication and identity features are configured using ASP.NET Identity in Startup.Auth.cs and IdentityConfig.cs, located in the App_Start folder. ASP.NET Core MVC에서 이러한 기능에 구성 된 Startup.cs합니다.In ASP.NET Core MVC, these features are configured in Startup.cs.

설치는 Microsoft.AspNetCore.Identity.EntityFrameworkCoreMicrosoft.AspNetCore.Authentication.Cookies NuGet 패키지 합니다.Install the Microsoft.AspNetCore.Identity.EntityFrameworkCore and Microsoft.AspNetCore.Authentication.Cookies NuGet packages.

그런 다음을 열고 Startup.cs 하 고 업데이트는 Startup.ConfigureServices Entity Framework 및 Id 서비스를 사용 하는 메서드:Then, open Startup.cs and update the Startup.ConfigureServices method to use Entity Framework and Identity services:

public void ConfigureServices(IServiceCollection services)
{
    // Add EF services to the services container.
    services.AddDbContext<ApplicationDbContext>(options =>
        options.UseSqlServer(Configuration.GetConnectionString("DefaultConnection")));

    services.AddIdentity<ApplicationUser, IdentityRole>()
        .AddEntityFrameworkStores<ApplicationDbContext>()
        .AddDefaultTokenProviders();

     services.AddMvc();
}

이 시점에서 ASP.NET MVC 프로젝트에서 사용한 아직 하지 않은 위의 코드에서 참조 하는 형식은 두 가지가: ApplicationDbContextApplicationUser합니다.At this point, there are two types referenced in the above code that we haven't yet migrated from the ASP.NET MVC project: ApplicationDbContext and ApplicationUser. 모델 폴더에서 ASP.NET Core 프로젝트를 하 고 이러한 형식에 해당를 두 개의 클래스를 추가 합니다.Create a new Models folder in the ASP.NET Core project, and add two classes to it corresponding to these types. ASP.NET MVC에서 이러한 클래스의 버전을 찾이 됩니다 /Models/IdentityModels.cs, 있지만 명확 하 게 되므로 마이그레이션된 프로젝트에서 클래스 마다 파일 하나를 사용 하는 것입니다.You will find the ASP.NET MVC versions of these classes in /Models/IdentityModels.cs, but we will use one file per class in the migrated project since that's more clear.

ApplicationUser.cs:ApplicationUser.cs:

using Microsoft.AspNetCore.Identity.EntityFrameworkCore;

namespace NewMvcProject.Models
{
  public class ApplicationUser : IdentityUser
  {
  }
}

ApplicationDbContext.cs:ApplicationDbContext.cs:

using Microsoft.AspNetCore.Identity.EntityFramework;
using Microsoft.Data.Entity;

namespace NewMvcProject.Models
{
    public class ApplicationDbContext : IdentityDbContext<ApplicationUser>
    {
        public ApplicationDbContext(DbContextOptions<ApplicationDbContext> options)
            : base(options)
        {
        }

        protected override void OnModelCreating(ModelBuilder builder)
        {
            base.OnModelCreating(builder);
            // Customize the ASP.NET Identity model and override the defaults if needed.
            // For example, you can rename the ASP.NET Identity table names and more.
            // Add your customizations after calling base.OnModelCreating(builder);
        }
    }
}

ASP.NET Core MVC 시작 웹 프로젝트에 사용자가의 많은 사용자 지정이 포함 되어 있지 않습니다 또는 ApplicationDbContext합니다.The ASP.NET Core MVC Starter Web project doesn't include much customization of users, or the ApplicationDbContext. 실제 앱으로 마이그레이션할 경우도 마이그레이션해야 할 모든 사용자 지정 속성 및 응용 프로그램의 사용자의 메서드 및 DbContext 클래스 뿐만 아니라 앱은 사용 하 여 다른 모델 클래스입니다.When migrating a real app, you also need to migrate all of the custom properties and methods of your app's user and DbContext classes, as well as any other Model classes your app utilizes. 예를 들어 경우 프로그램 DbContextDbSet<Album>를 마이그레이션해야 하는 Album 클래스입니다.For example, if your DbContext has a DbSet<Album>, you need to migrate the Album class.

현재 위치에서 이러한 파일에는 Startup.cs 업데이트 하 여 컴파일할 파일을 만들 수 있습니다는 using 문:With these files in place, the Startup.cs file can be made to compile by updating its using statements:

using Microsoft.AspNetCore.Builder;
using Microsoft.AspNetCore.Identity;
using Microsoft.AspNetCore.Hosting;
using Microsoft.EntityFrameworkCore;
using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.DependencyInjection;

이제이 앱을 인증 및 Id 서비스를 지원 하도록 준비 합니다.Our app is now ready to support authentication and Identity services. 사용자에 게 이러한 기능을 갖추고 하기만 합니다.It just needs to have these features exposed to users.

등록 및 로그인 논리 마이그레이션Migrate registration and login logic

응용 프로그램에 대해 구성 하는 Id 서비스 및 Entity Framework 및 SQL Server를 사용 하 여 구성 하는 데이터 액세스를 사용 하 여 준비가 응용 프로그램에 등록 및 로그인에 대 한 지원을 추가 합니다.With Identity services configured for the app and data access configured using Entity Framework and SQL Server, we're ready to add support for registration and login to the app. 이전에 설명한 대로 마이그레이션 프로세스의 앞부분에 나오는 에 대 한 참조를 주석 우리 _LoginPartial_Layout.cshtml합니다.Recall that earlier in the migration process we commented out a reference to _LoginPartial in _Layout.cshtml. 이제 해당 코드를 반환 합니다. 주석 처리를 제거, 로그인 기능을 지 원하는 데 필요한 컨트롤러를 추가 하는 시간입니다.Now it's time to return to that code, uncomment it, and add in the necessary controllers and views to support login functionality.

주석 처리 제거는 @Html.Partial_Layout.cshtml:Uncomment the @Html.Partial line in _Layout.cshtml:

      <li>@Html.ActionLink("Contact", "Contact", "Home")</li>
    </ul>
    @*@Html.Partial("_LoginPartial")*@
  </div>
</div>

이제 라는 새로운 Razor 뷰 추가 _LoginPartial뷰/공유 폴더:Now, add a new Razor view called _LoginPartial to the Views/Shared folder:

업데이트 _LoginPartial.cshtml 를 다음 코드로 (모든 내용을 바꾸기):Update _LoginPartial.cshtml with the following code (replace all of its contents):

@inject SignInManager<ApplicationUser> SignInManager
@inject UserManager<ApplicationUser> UserManager

@if (SignInManager.IsSignedIn(User))
{
    <form asp-area="" asp-controller="Account" asp-action="Logout" method="post" id="logoutForm" class="navbar-right">
        <ul class="nav navbar-nav navbar-right">
            <li>
                <a asp-area="" asp-controller="Manage" asp-action="Index" title="Manage">Hello @UserManager.GetUserName(User)!</a>
            </li>
            <li>
                <button type="submit" class="btn btn-link navbar-btn navbar-link">Log out</button>
            </li>
        </ul>
    </form>
}
else
{
    <ul class="nav navbar-nav navbar-right">
        <li><a asp-area="" asp-controller="Account" asp-action="Register">Register</a></li>
        <li><a asp-area="" asp-controller="Account" asp-action="Login">Log in</a></li>
    </ul>
}

이 시점에서 브라우저에서 사이트를 새로 고칠 수 있습니다.At this point, you should be able to refresh the site in your browser.

요약Summary

ASP.NET Core에서는 ASP.NET Id 기능을 변경 합니다.ASP.NET Core introduces changes to the ASP.NET Identity features. 이 문서에서 ASP.NET Core를 ASP.NET Identity의 인증 및 사용자 관리 기능을 마이그레이션하는 방법에 알아보았습니다.In this article, you have seen how to migrate the authentication and user management features of ASP.NET Identity to ASP.NET Core.