发布时间:2022-04-03 18:05:18来源:本站阅读(819)
.NET一直有自带Authorize验证,在FRAMEWORK时就一直使用,方便好用。
下面说下在.NET CORE中的使用,使用COOKIES验证
首先看下program的代码
builder.Services.AddAuthentication(CookieAuthenticationDefaults.AuthenticationScheme).AddCookie(o =>
{
    o.LoginPath = new PathString("/Home/Admin");
    o.LogoutPath = new PathString("/Home/Admin");
    o.AccessDeniedPath = new PathString("/Home/Admin");
    o.Cookie.HttpOnly = true;
    o.ExpireTimeSpan = new TimeSpan(8, 0, 0);
}); app.UseAuthentication();
app.UseAuthorization(); 然后看下登录的后台代码
var user = _admin.Value.Login(u, p);
var claims = new List { new Claim("adminUser", JsonSerializer.Serialize(user)) };
var claimsIdentity = new ClaimsIdentity(claims, CookieAuthenticationDefaults.AuthenticationScheme);
var adminUser = new ClaimsPrincipal(claimsIdentity);
HttpContext.SignInAsync(CookieAuthenticationDefaults.AuthenticationScheme, adminUser).Wait();  最后在要验证的 controller或action上面加下以下代码
[Authorize(AuthenticationSchemes= CookieAuthenticationDefaults.AuthenticationScheme)] OK,搞定
注意:Authorize 后面括号里的一定要加
关键字: Authorize
上一篇: lambda中使用SUM
下一篇: .NET6 WEB API使用JWT
 1100
 1618
 1359
 1511
 1369
 1708
 1623
 1148
 1451
 1466
 10241
 6279
 5820
 5393
 4890
 4589
 3804
 3627
 3627
 3543