使用 Identity UI 作为库在 ASP.NET Core 2.1 中授权注册页面

cas*_*rou 5 razor asp.net-identity asp.net-core

我正在 .NET Core 2.1.3 中使用 ASP.NET Core Identity 开发 Razor Pages 项目。

我想知道是否可以使用身份授权“注册”页面作为预构建的 UI来授权“注册”页面,而无需将所有与身份相关的代码搭建起来。只有注册用户(最好基于角色)才能够注册新用户。

我尝试在Startup.cs-file 中添加以下内容,但都没有成功:

services.AddMvc()
.AddRazorPagesOptions(options =>
{
    options.Conventions.AuthorizeFolder("/Admin");
    // Trying to authorize the Register-page
    options.Conventions.AuthorizeAreaPage("Identity", "/Account/Register");
    options.Conventions.AuthorizeAreaPage("Identity", "/Pages/Account/Register");
    options.Conventions.AuthorizePage("/Identity/Account/Register");
    options.Conventions.AuthorizePage("/Account/Register");
    options.Conventions.AuthorizePage("/Identity/Pages/Account/Register");
    options.Conventions.AuthorizeFolder("/Identity/Pages/Account");
    options.Conventions.AuthorizeFolder("/Identity/Account");
    options.Conventions.AuthorizeFolder("/Account");
    options.Conventions.AuthorizeFolder("/Areas/Identity/Pages/Account");
    options.Conventions.AuthorizeFolder("/Areas/Identity/Pages");
    options.Conventions.AuthorizeFolder("/Areas/Identity");
    options.Conventions.AuthorizeFolder("/Areas");
})
.SetCompatibilityVersion(CompatibilityVersion.Version_2_1);
Run Code Online (Sandbox Code Playgroud)

或者,是否可以完全禁止注册新用户?

谢谢!

Ala*_*n T 4

以下内容对我有用,并使用基于角色的授权。我仍然需要搭建一些页面,但只需要更新那些页面。

脚手架登录和注册页面

我仅使用以下内容搭建登录和注册页面:

将身份支架植入具有授权的 Razor 项目中

这也很有帮助。有一个演示显示了上述内容:

使用 ASP.NET Core 2.1 进行 Web 开发的新增功能:Build 2018

Login.cshtml - 我注释掉了以下内容。

<p>
    <a asp-page="./Register" asp-route-returnUrl="@Model.ReturnUrl">Register as a new user</a>
</p>
Run Code Online (Sandbox Code Playgroud)

Register.cshtml.cs - 我删除了AllowAnonymous属性

[AllowAnonymous]
public class RegisterModel : PageModel
Run Code Online (Sandbox Code Playgroud)


Startup.cs - 配置服务

public void ConfigureServices(IServiceCollection services)
{
    services.Configure<CookiePolicyOptions>(options =>
    {
        // This lambda determines whether user consent for non-essential cookies is needed for a given request.
        options.CheckConsentNeeded = context => true;
        options.MinimumSameSitePolicy = SameSiteMode.None;
    });

    services.AddDbContext<ApplicationDbContext>(options =>
        options.UseSqlite(
            Configuration.GetConnectionString("DefaultConnection")));

    services.AddIdentity<IdentityUser, IdentityRole>(options =>{
        options.SignIn.RequireConfirmedEmail = true;
    })
        .AddDefaultUI()
        .AddDefaultTokenProviders()
        .AddEntityFrameworkStores<ApplicationDbContext>();

    // Register no-op EmailSender used by account confirmation and password reset during development
    // For more information on how to enable account confirmation and password reset please visit https://go.microsoft.com/fwlink/?LinkID=532713
    services.AddSingleton<Microsoft.AspNetCore.Identity.UI.Services.IEmailSender, EmailSender>();

    services.AddAuthorization(options =>
    {
        options.AddPolicy("RequireAdministratorRole",
            policy => policy.RequireRole("Admin"));
        options.DefaultPolicy = options.GetPolicy("RequireAdministratorRole");
    });

    services.AddMvc()
       .AddRazorPagesOptions(options =>
        {
            options.Conventions.AuthorizePage("/About", "RequireAdministratorRole");
            options.Conventions.AuthorizeAreaPage("Identity", "/Account/Register");
        })
        .SetCompatibilityVersion(CompatibilityVersion.Version_2_1);
}
Run Code Online (Sandbox Code Playgroud)