netcore 下的policy授权自定义返回结果

目前一直在用policy做权限校验,但是好像组里需要将返回结果统一,之前用的都是直接继承AuthorizationHandler然后调用context.Fail(),但是这样会导致没办法自定义返回结果比如{code:403,msg:'未授权',data:null},

也百度了下https://q.cnblogs.com/q/120091/ 这里也说了3.0后就改掉了之前可以通过result来返回,但是现在不行了,之后又查了下资料无果,今天心血来潮直接用httpcontext来返回结果可以了。。。。。

直接上代码吧

    public class ApiUrlPermissionHandler : AuthorizationHandler<ApiUrlPermissionRequirement>
    {
        private readonly IHttpContextAccessor _accessor;
        private readonly ILogger<ApiUrlPermissionHandler> _logger;
        private readonly IPermissionWatchDog _permissionWatchDog;

        public ApiUrlPermissionHandler(IHttpContextAccessor accessor,ILogger<ApiUrlPermissionHandler> logger, IPermissionWatchDog permissionWatchDog)
        {
            this._accessor = accessor;
            this._logger = logger;
            this._permissionWatchDog = permissionWatchDog;
        }
        protected override async Task HandleRequirementAsync(AuthorizationHandlerContext context, ApiUrlPermissionRequirement requirement)
        {
            var httpContext = _accessor.HttpContext;

            var isAuthenticated = context.User.Identity.IsAuthenticated;
            if (isAuthenticated)
            {
                var uid = httpContext.User.Claims.FirstOrDefault(s => s.Type == "uid")?.Value;
                if (uid.IsNullOrWhiteSpace())
                {
                    context.Fail();
                    return;
                }
                //判断是否有权限
                var questUrl = httpContext.Request.Path.Value.ToLower();
                if (!await _permissionWatchDog.PassApiPermAsync(uid, questUrl))
                {
                    context.Fail();
                    return;
                }
                context.Succeed(requirement);
            }
            else
            {
                httpContext.Response.ContentType =  "application/json; charset=UTF-8";
                await httpContext.Response.WriteAsync(JsonConvert.SerializeObject(new { a="123",b="435"}));
                await httpContext.Response.Body.FlushAsync();
                //context.Fail();
            }
        }
    }

  有不对或者更好的方法希望园友提供指出谢谢

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值