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中实现登录和锁定功能。您可以根据自己的需求进行修改和扩展。

相关内容

热门资讯

发现一款"多乐游戏修... 发现一款"多乐游戏修改器"开挂(脚本)辅助脚本有挂解惑-存在挂教程您好:多乐游戏修改器这款游戏可以开...
实测教程"乐酷辅助图... 乐酷辅助图片 无需打开直接搜索微信:136704302本司针对手游进行,选择我们的四大理由: 1、软...
玩家必备教程"余音游... 【亲,余音游戏决战十三水 这款游戏可以开挂的,确实是有挂的,很多玩家在这款余音游戏决战十三水中打牌都...
透视教学"新圣游脚本... 您好:这款新圣游脚本下载游戏是可以开挂的,确实是有挂的,很多玩家在这款新圣游脚本下载游戏中打牌都会发...
透视私人局"阿拉斗牌... 透视私人局"阿拉斗牌脚本"开挂(安装)辅助安装有挂讲解-解密教程您好:阿拉斗牌脚本这款游戏可以开挂,...
重大发现"胡易决胜麻... 重大发现"胡易决胜麻架辅助"开挂(透视)辅助透视有挂神器-分享教程;亲,胡易决胜麻架辅助这款游戏原来...
透视app"四川途游... 透视app"四川途游小程序辅助软件"开挂(脚本)辅助脚本有挂详情-系统教程 【无需打开直接搜索加薇1...
透视软件"微信小程序... 您好:这款微信小程序雀神挂件怎么安装游戏是可以开挂的,确实是有挂的,很多玩家在这款微信小程序雀神挂件...
终于知道"hhpok... hhpoker有透视功能吗是一款专注玩家量身打造的游戏记牌类型软件,在hhpoker有透视功能吗这款...
必备攻略"丽水都莱辅... 必备攻略"丽水都莱辅助器"开挂(插件)辅助插件有挂攻略-系统教程;亲,丽水都莱辅助器这款游戏原来确实...