Spring Cloud Spring Boot mybatis分布式微服务云架构(十一)Web应用的统一异常处理...

我们在做Web应用的时候,请求处理过程中发生错误是非常常见的情况。Spring Boot提供了一个默认的映射:/error,当处理中抛出异常之后,会转到该请求中处理,并且该请求有一个全局的错误页面用来展示异常内容。

选择一个之前实现过的Web应用(Chapter3-1-2)为基础,启动该应用,访问一个不存在的URL,或是修改处理内容,直接抛出异常,如:

@RequestMapping("/hello")
public String hello() throws Exception {
    throw new Exception("发生错误");
}

此时,可以看到类似下面的报错页面,该页面就是Spring Boot提供的默认error映射页面。

alt=默认的错误页面alt=默认的错误页面

统一异常处理

虽然,Spring Boot中实现了默认的error映射,但是在实际应用中,上面你的错误页面对用户来说并不够友好,我们通常需要去实现我们自己的异常提示。

下面我们以之前的Web应用例子为基础(Chapter3-1-2),进行统一异常处理的改造。

  • 创建全局异常处理类:通过使用@ControllerAdvice定义统一的异常处理类,而不是在每个Controller中逐个定义。@ExceptionHandler用来定义函数针对的异常类型,最后将Exception对象和请求URL映射到error.html
    @ControllerAdvice
    class GlobalExceptionHandler {
    
        public static final String DEFAULT_ERROR_VIEW = "error";
    
        @ExceptionHandler(value = Exception.class)
        public ModelAndView defaultErrorHandler(HttpServletRequest req, Exception e) throws Exception {
            ModelAndView mav = new ModelAndView();
            mav.addObject("exception", e);
            mav.addObject("url", req.getRequestURL());
            mav.setViewName(DEFAULT_ERROR_VIEW);
            return mav;
        }
    
    }
    

     

  • 实现error.html页面展示:在templates目录下创建error.html,将请求的URL和Exception对象的message输出。
    <!DOCTYPE html>
    <html>
    <head lang="en">
        <meta charset="UTF-8" />
        <title>统一异常处理</title>
    </head>
    <body>
        <h1>Error Handler</h1>
        <div th:text="${url}"></div>
        <div th:text="${exception.message}"></div>
    </body>
    </html>

    启动该应用,访问:http://localhost:8080/hello,可以看到如下错误提示页面。

    alt=自定义的错误页面alt=自定义的错误页面

    通过实现上述内容之后,我们只需要在Controller中抛出Exception,当然我们可能会有多种不同的Exception。然后在@ControllerAdvice类中,根据抛出的具体Exception类型匹配@ExceptionHandler中配置的异常类型来匹配错误映射和处理。

  • 源码来源

转载于:https://my.oschina.net/u/3776687/blog/1626751

参考资源链接:[天机学堂Spring Cloud Alibaba与Vue实战课程精粹](https://wenku.csdn.net/doc/hjrvx5g8ik?utm_source=wenku_answer2doc_content) 要实现一个基于Spring Cloud Alibaba与Vue.js的分布式微服务架构项目,你需要了解分布式系统的设计原则、微服务的划分、服务间的通信机制以及前后端分离的实践。《天机学堂Spring Cloud Alibaba与Vue实战课程精粹》这本书将为你提供必要的知识和工具。具体来说,你可以按照以下步骤进行设计和实现: 1. 微服务架构设计:首先需要确定业务领域的边界,划分出独立的服务。比如,用户服务、订单服务、产品服务等。每个服务都应该有一个明确的业务职责。 2. 服务注册与发现:使用Nacos作为服务注册中心,管理微服务的注册与发现。每个微服务启动时,向Nacos注册自己的信息(服务名、IP地址、端口等),服务消费者则可以通过Nacos发现服务提供者。 3. 负载均衡:在服务消费者端,可以使用Spring Cloud LoadBalancer或Ribbon实现客户端负载均衡,调用服务提供者。 4. 服务配置管理:Nacos也提供配置管理功能,可以集中管理各个微服务的配置文件,实现配置的动态更新。 5. API网关:使用Spring Cloud Gateway作为API网关,统一处理外部请求。网关可以实现路由、过滤器、限流等功能。 6. 分布式事务管理:利用Seata实现分布式事务,保证跨服务的事务一致性。 7. 前后端分离:前端使用Vue.js构建单页面应用(SPA),与后端微服务通过HTTP/2进行通信,前端通过API网关调用后端服务。 8. 数据库设计与操作:合理设计数据库表结构,利用MyBatis或JPA等ORM框架实现数据的持久化操作。 9. 缓存与消息队列:利用Redis实现数据缓存和会话共享,使用RocketMQ进行消息驱动,实现服务间的消息通信。 10. 安全性与监控:使用Spring Security实现服务的安全控制,通过Spring Boot Admin或Prometheus+Grafana进行服务监控。 以上每一步都需要详细的技术实现方案,而《天机学堂Spring Cloud Alibaba与Vue实战课程精粹》将为你提供详尽的课程视频,从实战的角度帮助你一步步构建出完整的分布式微服务架构项目。 参考资源链接:[天机学堂Spring Cloud Alibaba与Vue实战课程精粹](https://wenku.csdn.net/doc/hjrvx5g8ik?utm_source=wenku_answer2doc_content)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值