ASP.NET Core MVC 2.2登录无需外部登录提供程序
创始人
2024-09-15 06:30:34
0

在ASP.NET Core MVC 2.2中实现无需外部登录提供程序的登录可以通过以下步骤实现:

  1. 创建一个新的ASP.NET Core MVC 2.2项目。

  2. Startup.cs文件中,将ConfigureServices方法中的身份验证服务配置更改为以下代码:

public void ConfigureServices(IServiceCollection services)
{
    // 添加身份验证服务
    services.AddAuthentication(options =>
    {
        options.DefaultAuthenticateScheme = CookieAuthenticationDefaults.AuthenticationScheme;
        options.DefaultSignInScheme = CookieAuthenticationDefaults.AuthenticationScheme;
        options.DefaultChallengeScheme = CookieAuthenticationDefaults.AuthenticationScheme;
    })
    .AddCookie(options =>
    {
        options.LoginPath = new PathString("/Account/Login");
        options.LogoutPath = new PathString("/Account/Logout");
    });

    // 添加MVC服务
    services.AddMvc().SetCompatibilityVersion(CompatibilityVersion.Version_2_2);
}
  1. Configure方法中,将身份验证中间件添加到应用程序的管道中:
public void Configure(IApplicationBuilder app, IHostingEnvironment env)
{
    // ...

    // 使用身份验证中间件
    app.UseAuthentication();

    // ...
}
  1. 创建一个名为AccountController的控制器,并添加以下动作方法:
public class AccountController : Controller
{
    [HttpGet]
    public IActionResult Login(string returnUrl = null)
    {
        // 如果已经登录,重定向到指定的URL
        if (User.Identity.IsAuthenticated)
        {
            return RedirectToAction("Index", "Home");
        }

        ViewData["ReturnUrl"] = returnUrl;
        return View();
    }

    [HttpPost]
    public async Task Login(LoginViewModel model, string returnUrl = null)
    {
        if (ModelState.IsValid)
        {
            // 在此验证用户名和密码

            // 创建用户声明
            var claims = new List
            {
                new Claim(ClaimTypes.Name, model.Username)
            };

            // 创建用户身份标识
            var claimsIdentity = new ClaimsIdentity(claims, CookieAuthenticationDefaults.AuthenticationScheme);

            // 创建身份验证属性
            var authProperties = new AuthenticationProperties
            {
                IsPersistent = true,
                ExpiresUtc = DateTimeOffset.UtcNow.AddMinutes(20)
            };

            // 进行登录
            await HttpContext.SignInAsync(CookieAuthenticationDefaults.AuthenticationScheme, new ClaimsPrincipal(claimsIdentity), authProperties);

            // 重定向到指定的URL
            return RedirectToAction("Index", "Home");
        }

        // 验证失败,返回登录视图
        ViewData["ReturnUrl"] = returnUrl;
        return View(model);
    }

    [HttpPost]
    public async Task Logout()
    {
        // 执行注销
        await HttpContext.SignOutAsync(CookieAuthenticationDefaults.AuthenticationScheme);

        // 重定向到登录页面
        return RedirectToAction("Login", "Account");
    }
}
  1. 创建一个名为LoginViewModel的视图模型类,并添加以下属性:
public class LoginViewModel
{
    [Required]
    public string Username { get; set; }

    [Required]
    [DataType(DataType.Password)]
    public string Password { get; set; }
}
  1. 创建一个名为Login.cshtml的登录视图,并编写以下代码:
@model LoginViewModel

Login

@if (!string.IsNullOrEmpty(ViewData["ReturnUrl"] as string)) {

You must be logged in to access this page.

}

通过以上步骤,您可以在ASP.NET Core MVC 2.2中实现无需外部登录提供程序的登录功能。当用户通过登录视图输入正确的用户名和密码后,系统将创建一个身份验证Cookie,并将用户重定向到主页。在其他需要身份验证的控制器或操作方法中,您可以使用User.Identity.IsAuthenticated属性来检查用户是否已经登录。

相关内容

热门资讯

开挂辅助!乐胡脚本,WePOk... 开挂辅助!乐胡脚本,WePOker有没有透视方法(透视)开挂辅助安装(有挂头条);大家肯定在之前乐胡...
辅助开挂!卡五星辅助神器,we... 辅助开挂!卡五星辅助神器,wepoker私人局可以透视(透视)开挂辅助安装(有挂规律);卡五星辅助神...
辅助开挂!欢乐情怀怎么开挂,拱... 辅助开挂!欢乐情怀怎么开挂,拱趴大菠萝十三水辅助(透视)开挂辅助插件(有挂解密);1、完成欢乐情怀怎...
辅助开挂!盛世透视辅助工具,w... 辅助开挂!盛世透视辅助工具,wepoker透视脚本免费下载(透视)开挂辅助工具(有挂实锤);盛世透视...
辅助开挂!新518互游脚本,h... 辅助开挂!新518互游脚本,hhpoker软件安装包(透视)开挂辅助软件(的确有挂);相信小伙伴都知...
开挂辅助!四川熊猫辅助官网,哈... 开挂辅助!四川熊猫辅助官网,哈糖大菠萝能开挂吗(透视)开挂辅助工具(有挂方法);致您一封信;亲爱四川...
辅助开挂!钱塘十三水透视,po... 辅助开挂!钱塘十三水透视,pokemmo手机版脚本免费(透视)开挂辅助神器(发现有挂);钱塘十三水透...
开挂辅助!哈局八张模拟器,we... 开挂辅助!哈局八张模拟器,wepoker开辅助能查到吗(透视)开挂辅助神器(有挂透明挂);一、哈局八...
辅助开挂!哈灵脚本修改器,德州... 辅助开挂!哈灵脚本修改器,德州透视脚本(透视)开挂辅助平台(有挂存在);亲,有的,ai轻松简单,又可...
开挂辅助!东阳四副牌辅助,hh... 开挂辅助!东阳四副牌辅助,hhpoker可以控制牌吗(透视)开挂辅助平台(揭秘有挂);东阳四副牌辅助...