NetCore项目实战篇02---全局异常处理
在 .netcore中可以自定义自己的异常类型,步骤如下:
1、自定义自己的异常类型UserOperationException 并继承自Exception
public class UserOperationException:Exception { public UserOperationException() { } public UserOperationException(string message) : base(message) { } public UserOperationException(string message, Exception innerException) : base(message, innerException) { } }
2、自定义自己的全局异常过滤器GlobalExceptionFilter 实现接口 IExceptionFilter
public class GlobalExceptionFilter : IExceptionFilter { private readonly IHostingEnvironment _env; private readonly ILogger<GlobalExceptionFilter> _logger; public GlobalExceptionFilter(IHostingEnvironment env, ILogger<GlobalExceptionFilter> logger) { _env = env; _logger = logger; } public void OnException(ExceptionContext context) { var json = new JsonErrorResponse { Message = context.Exception.Message }; if (context.Exception.GetType() == typeof(UserOperationException)) { context.Result = new BadRequestObjectResult(json); }else { json.Message = "zhengweiProject中发生了未知的内部异常!"; if(_env.IsDevelopment()) { json.Message = context.Exception.StackTrace; } context.Result = new InternalServerErrorObjectResult(json); } _logger.LogError(context.Exception, context.Exception.Message); context.ExceptionHandled = true; } } public class InternalServerErrorObjectResult:ObjectResult { public InternalServerErrorObjectResult(object error):base(error) { StatusCode = StatusCodes.Status500InternalServerError; } }
3、在项目中使用,第一篇文章已说过,项目使用微服务webapi架构。新建控制器UserController.cs 在get方法中抛出异常,
在获取UserIdentity值时故意获取了数据库中没有的值
[Route("api/users")] public class UserController : BaseController { public UserContext _userContext; public UserController(UserContext userContext) { _userContext = userContext; } // GET api/values [Route("")] [HttpGet] public async Task<IActionResult> Get() { var user =_userContext.Users.SingleOrDefault(u=>u.Id == UserIdentity.UserId); if(user == null) { throw new UserOperationException("获取用户数据出错,用户ID:"+UserIdentity.UserId); } return Json(user); } // GET api/values/5 [HttpGet("{id}")] public string Get(int id) { return "value"; } // POST api/values [Route("")] [HttpPost] public void Post([FromBody]string value) { } // PUT api/values/5 [Route("")] [HttpPut("{id}")] public void Put(int id, [FromBody]string value) { } // DELETE api/values/5 [HttpDelete("{id}")] public void Delete(int id) { } }
4、运行项目后,postman访问API,结果如下:
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!