异常过滤器

本文介绍ASP.NET MVC中的异常过滤器,实现方式为继承HandleErrorAttribute类,并重写OnException方法来处理异常。此外,还介绍了如何自定义异常过滤器及全局异常过滤器的配置。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

异常过滤器

1.实现了IExceptionFilter接口

2.执行时间

当action方法或action result抛出异常时执行

3.并不是直接实现IExceptionFilter接口

默认实现HandleErrorAttribute类,HandleErrorAttribute类实现了IExceptionFilter接口与FilterAttribute抽象方法

4.异常发生时执行的方法

public virtual void OnException(ExceptionContext filterContext);
//在HandleErrorAttribute类中
//自定义异常过滤器时需重写继承HandleErrorAttribute类后的此方法

5.自定义异常过滤器

   public class MyExceptionFilterAttribute:HandleErrorAttribute//实现接口
    {
        public override void OnException(ExceptionContext filterContext)//重新方法
        {
            base.OnException(filterContext);

          HttpContext.Current.Response.Redirect("/ExceptionController/ExceptionAction");           //跳转到错误提示页面   

        }
    }

6.全局异常过滤器

1.不用添加标签,对全体都起作用

2.在App_Start文件夹下的FilterConfig.cs中注册

3.优先级最低

4.Global.axal文件中需加上

FilterConfig.RegisterGlobalFilters(GlobalFilters.Filters);

示例

  public class FilterConfig
    {
        public static void RegisterGlobalFilters(GlobalFilterCollection filters)
        {
            filters.Add(new MyExceptionFilterAttribute());
            //每添加一条全局过滤器,增加一行上一行代码
        }
    }
### 创建和使用异常过滤器 在 NestJS 中,异常过滤器用于捕获并处理抛出的异常。通过定义自定义异常过滤器可以集中管理应用程序中的错误响应逻辑。 #### 定义自定义异常过滤器 为了创建一个新的异常过滤器,需继承 `ExceptionFilter` 接口,并实现其唯一的抽象方法——`catch(exception, host)` 方法: ```typescript import { ExceptionFilter, Catch, ArgumentsHost, HttpException } from '@nestjs/common'; import { Request, Response } from 'express'; @Catch(HttpException) export class HttpExceptionFilter implements ExceptionFilter { catch(exception: HttpException, host: ArgumentsHost) { const ctx = host.switchToHttp(); const response = ctx.getResponse<Response>(); const request = ctx.getRequest<Request>(); const status = exception.getStatus(); response.status(status).json({ statusCode: status, timestamp: new Date().toISOString(), path: request.url, }); } } ``` 此代码片段展示了如何构建一个 HTTP 异常处理器[^1]。 #### 应用异常过滤器 一旦定义好了异常过滤器,则可以通过多种方式将其应用于不同的上下文中: - **局部应用**:可以在特定路由处理器中注册该过滤器,仅影响单个端点的行为。 ```typescript @Controller('cats') export class CatsController { @Post() @UseFilters(new HttpExceptionFilter()) create(@Body() createCatDto: CreateCatDto) {} } ``` 上述例子说明了怎样在一个 POST 请求下指定使用 `HttpExceptionFilter` 来拦截可能发生的HTTP级别的异常状况。 - **全局范围内的应用**:如果希望在整个项目范围内生效的话,可在主模块文件内设置全局性的异常过滤器配置。 ```typescript async function bootstrap() { const app = await NestFactory.create(AppModule); app.useGlobalFilters(new AllExceptionsFilter()); await app.listen(3000); } bootstrap(); ``` 这里演示的是将名为 `AllExceptionsFilter` 的过滤器设为整个项目的默认异常处理器的方式[^2]。 需要注意的是,在存在多个异常过滤器的情况下,它们会按照声明顺序依次尝试匹配所发生的具体异常类型;因此排列位置对于最终效果有着直接影响[^3]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值