c# – 如何从authrizationhandler .net核心获取params

前端之家收集整理的这篇文章主要介绍了c# – 如何从authrizationhandler .net核心获取params前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在使用授权处理程序将自定义授权放在.net核心的控制器中.如何从控制器获取参数并将其用于授权处理程序.

在旧的.net中,我可以像这样从Httpcontext请求参数中获取参数

  1. var eventId = filterContext.RequestContext.HttpContext.Request.Params["id"];

我不知道如何在.net核心中实现它

  1. enter code here
  2.  
  3. public class HasAdminRoleFromAnySiteRequirement : AuthorizationHandler<HasAdminRoleFromAnySiteRequirement>,IAuthorizationRequirement
  4. {
  5.  
  6. public HasAdminRoleFromAnySiteRequirement()
  7. {
  8.  
  9. }
  10. protected override Task HandleRequirementAsync(AuthorizationHandlerContext context,HasAdminRoleFromAnySiteRequirement requirement)
  11. {
  12.  
  13. //need to call get param from controller to used in the validation
  14. // something like this
  15. //var eventId = filterContext.RequestContext.HttpContext.Request.Params["id"];
  16. // I tried the suggestion below but I can't get the parameter from routedata
  17. // var mvcContext = context.Resource as Microsoft.AspNetCore.Mvc.Filters.AuthorizationFilterContext;
  18.  
  19. return Task.FromResult(0);
  20. }
  21. }

解决方法

在处理程序中,您可以执行以下操作
  1. var mvcContext = context.Resource as
  2. Microsoft.AspNetCore.Mvc.Filters.AuthorizationFilterContext;
  3.  
  4. if (mvcContext != null)
  5. {
  6. // Examine MVC specific things like routing data.
  7. }

如果需要参数值,则在绑定发生之前运行授权属性块.相反,你会转移到控制器内的强制调用.这基本上是resource based authorization,你的参数是一个资源.

您可以将授权服务注入您的控制器;

  1. public class DocumentController : Controller
  2. {
  3. IAuthorizationService _authorizationService;
  4.  
  5. public DocumentController(IAuthorizationService authorizationService)
  6. {
  7. _authorizationService = authorizationService;
  8. }
  9. }

然后稍微改写你的处理程序;

  1. public class DocumentAuthorizationHandler : AuthorizationHandler<MyRequirement,Document>
  2. {
  3. public override Task HandleRequirementAsync(AuthorizationHandlerContext context,MyRequirement requirement,Document resource)
  4. {
  5. // Validate the requirement against the resource and identity.
  6.  
  7. return Task.CompletedTask;
  8. }
  9. }

您可以看到此处理程序获取文档,这可以是您喜欢的任何内容,无论是ID的整数,还是某种类型的视图模型.

然后,您可以在HandleRequirementAsync()方法中访问它.

最后,一旦绑定发生,你就可以从你的控制器中调用它;

  1. if (await authorizationService.AuthorizeAsync(
  2. User,document,yourRequirement))
  3. {
  4. }

猜你在找的C#相关文章