如何解决如何为UnauthorizedAccessException创建过滤器
我想为UnauthorizedAccessException创建过滤器,我不知道为什么它在我的主过滤器中不起作用 首先,我在ApiExceptionFilter:ExceptionFilterAttribute中尝试了这个,但是在这里不起作用
private void HandleUnauthorizedAccessException(ExceptionContext context)
{
var exception = context.Exception as UnauthorizedAccessException;
var details = new ProblemDetails
{
Status = StatusCodes.Status401Unauthorized,Title = "nauthorized exception",Detail = exception.Message
};
context.Result = new ObjectResult(details)
{
StatusCode = StatusCodes.Status401Unauthorized
};
context.ExceptionHandled = true;
}
我的所有其他例外情况都在这里代替
在那之后,我尝试在这里得到,但再次失败:
public class HttpResponseExceptionFilter : IActionFilter,IOrderedFilter
{
public int Order { get; set; } = int.MaxValue - 10;
public void OnActionExecuting(ActionExecutingContext context) { }
public void OnActionExecuted(ActionExecutedContext context)
{
if (context.Exception is HttpResponseException exception)
{
context.Result = new ObjectResult(exception.Value)
{
StatusCode = exception.Status,};
context.ExceptionHandled = true;
}
}
}
我不知道为什么只有在请求发送到api后才无法处理此异常:(
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。