Wol*_*ack 5 c# asp.net-core-mvc
是否有可能我们可以访问dbcontext以在自定义的基于策略的授权中获取我的表数据和会话?任何人都可以帮助如何实现它?
services.AddAuthorization(options =>
{
options.AddPolicy("CheckAuthorize",
policy => policy.Requirements.Add(new CheckAuthorize()));
});
services.AddSingleton<IAuthorizationHandler, CheckAuthorize>();
public class CheckAuthorize : AuthorizationHandler<CheckAuthorize>, IAuthorizationRequirement
{
protected override Task HandleRequirementAsync(AuthorizationHandlerContext context, CheckAuthorize requirement)
{
if () //check session to verify user is logged in or not
{
//redirect to login page
}
else
{
if ()//access dbcontext get data from database table to validate user access
{
//redirect to access denied page
}
}
throw new NotImplementedException();
}
}
Run Code Online (Sandbox Code Playgroud)
blo*_*art 11
政策可以使用DI
因此,假设您的数据库上下文在DI中,您可以执行类似的操作
public class CheckAuthorizeHandler : AuthorizationHandler<CheckAuthorizeRequirement>
{
MyContext _context;
public CheckAuthorizeHandler(MyContext context)
{
_context = context;
}
protected override Task HandleRequirementAsync(
AuthorizationHandlerContext context,
MyRequirement requirement)
{
// Do something with _context
// Check if the requirement is fulfilled.
return Task.CompletedTask;
}
}
Run Code Online (Sandbox Code Playgroud)
请注意,当你这样做时,你必须使你的要求成为一个单独的课程,你做不到CheckAuthorize : AuthorizationHandler<CheckAuthorize>, IAuthorizationRequirement,所以你必须做
public CheckAuthorizeRequirement : IAuthorizationRequirement
{
}
Run Code Online (Sandbox Code Playgroud)
最后,您需要在DI系统中注册您的处理程序
services.AddTransient<IAuthorizationHandler, CheckAuthorizeHandler>();
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
2202 次 |
| 最近记录: |