ASP.NET Core身份验证的登录和锁定
创始人
2024-09-15 23:01:02
0

以下是一个使用ASP.NET Core身份验证实现登录和锁定功能的代码示例:

  1. 在Startup.cs文件中配置身份验证服务:
public void ConfigureServices(IServiceCollection services)
{
    services.AddDbContext(options =>
        options.UseSqlServer(Configuration.GetConnectionString("DefaultConnection")));
    
    services.AddIdentity()
        .AddEntityFrameworkStores()
        .AddDefaultTokenProviders();
    
    services.Configure(options =>
    {
        // 配置密码设置
        options.Password.RequireDigit = true;
        options.Password.RequiredLength = 8;
        options.Password.RequireNonAlphanumeric = false;
        options.Password.RequireUppercase = true;
        options.Password.RequireLowercase = false;
        
        // 配置用户锁定设置
        options.Lockout.DefaultLockoutTimeSpan = TimeSpan.FromMinutes(30);
        options.Lockout.MaxFailedAccessAttempts = 5;
        options.Lockout.AllowedForNewUsers = true;
    });

    services.ConfigureApplicationCookie(options =>
    {
        options.LoginPath = "/Account/Login";
        options.LogoutPath = "/Account/Logout";
        options.AccessDeniedPath = "/Account/AccessDenied";
    });

    // 添加授权策略
    services.AddAuthorization(options =>
    {
        options.AddPolicy("RequireAdminRole", policy => policy.RequireRole("Admin"));
        options.AddPolicy("RequireUserRole", policy => policy.RequireRole("User"));
    });

    services.AddControllersWithViews();
}
  1. 在AccountController.cs文件中实现登录和锁定功能:
public class AccountController : Controller
{
    private readonly SignInManager _signInManager;
    private readonly UserManager _userManager;

    public AccountController(
        SignInManager signInManager,
        UserManager userManager)
    {
        _signInManager = signInManager;
        _userManager = userManager;
    }

    [HttpGet]
    public IActionResult Login()
    {
        return View();
    }

    [HttpPost]
    public async Task Login(LoginViewModel model, string returnUrl = null)
    {
        if (ModelState.IsValid)
        {
            var result = await _signInManager.PasswordSignInAsync(model.Email, model.Password, model.RememberMe, lockoutOnFailure: false);
            
            if (result.Succeeded)
            {
                return RedirectToAction("Index", "Home");
            }
            
            if (result.IsLockedOut)
            {
                // 用户被锁定,显示错误消息
                ModelState.AddModelError(string.Empty, "账户被锁定,请稍后再试!");
                return View(model);
            }
            
            ModelState.AddModelError(string.Empty, "无效的登录尝试!");
            return View(model);
        }
        
        return View(model);
    }

    [HttpPost]
    public async Task Logout()
    {
        await _signInManager.SignOutAsync();
        return RedirectToAction("Index", "Home");
    }
}
  1. 在AccountController.cs文件中实现锁定用户功能:
public class AccountController : Controller
{
    // ...

    [HttpPost]
    [ValidateAntiForgeryToken]
    public async Task LockUser(string userId)
    {
        var user = await _userManager.FindByIdAsync(userId);
        
        if (user != null)
        {
            await _userManager.SetLockoutEndDateAsync(user, DateTimeOffset.UtcNow.AddYears(100));
            // 或使用以下代码立即锁定用户
            // await _userManager.SetLockoutEnabledAsync(user, true);
            // await _userManager.SetLockoutEndDateAsync(user, DateTimeOffset.MaxValue);
        }
        
        return RedirectToAction("Index", "Home");
    }

    [HttpPost]
    [ValidateAntiForgeryToken]
    public async Task UnlockUser(string userId)
    {
        var user = await _userManager.FindByIdAsync(userId);
        
        if (user != null)
        {
            await _userManager.SetLockoutEndDateAsync(user, null);
            // 或使用以下代码立即解锁用户
            // await _userManager.SetLockoutEnabledAsync(user, false);
        }
        
        return RedirectToAction("Index", "Home");
    }
}

以上代码示例演示了如何配置ASP.NET Core身份验证服务,并在AccountController中实现登录和锁定功能。您可以根据自己的需求进行修改和扩展。

相关内容

热门资讯

揭幕透视!pokemmo内置修... 揭幕透视!pokemmo内置修改器!确实真的是有辅助工具(详细教程)-哔哩哔哩1、进入到pokemm...
分享透视!epoker有透视吗... 分享透视!epoker有透视吗!都是有辅助工具(的确有挂)-哔哩哔哩epoker有透视吗是不是有人用...
解谜透视!红龙poker辅助器... 解谜透视!红龙poker辅助器免费观看!竟然真的有辅助教程(有挂猫腻)-哔哩哔哩1、完成红龙poke...
详细透视!德州圈脚本!总是是有... 详细透视!德州圈脚本!总是是有辅助app(真实有挂)-哔哩哔哩1、金币登录送、破产送、升级送、活动送...
有挂透视!德州局脚本!一贯一直... 有挂透视!德州局脚本!一贯一直总是有辅助教程(存在有挂)-哔哩哔哩德州局脚本能透视中分为三种模型:德...
关于透视!pokemmo脚本最... 您好,pokemmo脚本最新版这款游戏可以开挂的,确实是有挂的,需要了解加去威信【485275054...
有挂透视!哈糖大菠萝破解器!一... 有挂透视!哈糖大菠萝破解器!一贯一直都是有辅助神器(有挂教学)-哔哩哔哩1、哈糖大菠萝破解器破解器简...
了解透视!拱趴大菠萝挂哪里!果... 了解透视!拱趴大菠萝挂哪里!果然一直都是有辅助攻略(有挂细节)-哔哩哔哩1、很好的工具软件,可以解锁...
必备透视!扑克之星辅助!切实是... 必备透视!扑克之星辅助!切实是有辅助软件(有挂解惑)-哔哩哔哩一、扑克之星辅助游戏安装教程牌型概率发...
必备透视!sohoo竞技联盟辅... 必备透视!sohoo竞技联盟辅助器!总是是有辅助攻略(存在有挂)-哔哩哔哩1)sohoo竞技联盟辅助...