zoukankan      html  css  js  c++  java
  • authorize(权限验证)

    Startup 中 ConfigureServices 插入

    services.AddAuthentication(options =>
                {
                    options.DefaultAuthenticateScheme = "MyCookieAuthenticationScheme";
                    options.DefaultChallengeScheme = "MyCookieAuthenticationScheme";
                    options.DefaultSignInScheme = "MyCookieAuthenticationScheme";
    
                })
                .AddCookie("MyCookieAuthenticationScheme", options =>
                {
                    options.AccessDeniedPath ="/Home";
                    options.LoginPath = "/Home";
                });
    

    Configure 中增加

    app.UseAuthentication();

    控制器中使用

    public JsonResult LoginCheck(string username, string password)
            {
                var user = _***.***(username, password); //检测用户是否正确
                
                if (user.code == 0)
                {
                    var claims = new List<Claim>()
                    {
                        new Claim(ClaimTypes.Sid,Convert.ToString(user.data.id)),
                        new Claim(ClaimTypes.Name,user.data.username),                    
                        //new Claim(ClaimTypes.Role,user.data.usergroup)
                    };
    
                    string groupstr = user.data.usergroup; //通过后台调用权限属性
                    string[] GroupSplit = groupstr.Split(',');
    
                    if (GroupSplit != null)
                    {
                        for (int i = 0; i < GroupSplit.Length; i++)
                        {
                            claims.Add(new Claim(ClaimTypes.Role, GroupSplit[i]));
                        }
                    }
                    var identity = new ClaimsIdentity(claims, "Login");
                    var userPrincipal = new ClaimsPrincipal(identity);
                    HttpContext.SignInAsync("MyCookieAuthenticationScheme", userPrincipal, new AuthenticationProperties
                    {
                        ExpiresUtc = DateTime.UtcNow.AddMinutes(20),
                        IsPersistent = false,
                        AllowRefresh = false
                    });
    
                }
                return Json(new { code = user.code, msg = user.result, data = user.data });
            }

    获取结果

    var userId = User.FindFirst(ClaimTypes.Sid).Value;
                var userName = User.Identity.Name;
                var rolelist = User.FindAll(ClaimTypes.Role);
                HttpContext.Response.WriteAsync($"测试结果  {userId}---{userName}--{rolelist}");

    退出登录

    public async Task<IActionResult> Logout()
            {
                await HttpContext.SignOutAsync("MyCookieAuthenticationScheme");
                return RedirectToAction("Index", "Home");
    
            }
    

      

  • 相关阅读:
    当程序员的那些狗日日子
    程序员常犯的几个错误
    我没有帮你的义务,却有拒绝你的权力
    并发 并行 同步 异步 多线程的区别
    cookie的存取
    sqlserver 处理百万级以上的数据处理与优化
    为什么 jmeter 分布式测试,一定要设置 java.rmi.server.hostname
    详细解析 nginx uri 如何匹配 location 规则
    mysql innodb 从 ibd 文件恢复表数据
    mysql 从 frm 文件恢复 table 表结构的3种方法
  • 原文地址:https://www.cnblogs.com/almmm/p/11533154.html
Copyright © 2011-2022 走看看