文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

SpringBoot2异常处理与web原生组件注入的方法

2023-06-29 14:48

关注

这篇文章主要介绍“SpringBoot2异常处理与web原生组件注入的方法”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“SpringBoot2异常处理与web原生组件注入的方法”文章能帮助大家解决问题。

1 异常处理

  默认情况下,SpringBoot会提供/error处理所有的错误请求并返回相应的信息,对于浏览器客户端来说会返回一个包含时间戳、状态码、错误信息、携带的自定义异常信息、发生错误的路径等信息的错误Whitelabel页面,对于机器客户端(postman等)会返回一个包含以上内容的JSON数据

1.1 异常处理之错误页面

  要想替代之前浏览器客户端返回的错误Whitelabel页面,需要将自定义的html页面放在静态资源static等的error文件夹下或者模板引擎templates的error文件夹下,这样的话出现错误时SpringBoot发送/error请求就会自动解析这些页面进行渲染。页面解析规则:先将状态码的值与error文件夹下的页面名进行精确匹配,如果精确匹配不到的话就按照4xx、5xx这样的方式进行模糊匹配,要是还匹配不到的话就返回Whitelabel页面

SpringBoot2异常处理与web原生组件注入的方法

1.2 异常处理之精确捕获

  要是说错误页面是按照状态码进行页面处理的话,精确捕获就是通过异常类进行捕获,捕获之后再进行一系列的自定义操作。具体步骤就是:创建一个异常处理器类,并在类上加@ControllerAdvice注解表明是一个异常处理器并向容器中注册该组件,@ExceptionHandler注解对参数中的异常类进行精准捕获,并在方法体定义具体的处理操作。

@Slf4j@ControllerAdvicepublic class GlobalExceptionHandler {    @ExceptionHandler({ArithmeticException.class, NullPointerException.class})    public String handleArithException(Exception e) {        log.info("系统捕获到异常信息:{}", e);        return "login";    }}

1.3 异常处理之自定义异常

  有时候我们需要在程序中自定义一些运行时异常,这些异常并不会像那些异常一样产生异常状态码,甚至在未定义之前都不算是异常且不会影响程序的正常运行。这时就需要我们自定义异常的产生逻辑,并自定义异常类创建有参无参构造器,在类上加@ResponseStatus注解,使用注解参数定义异常响应码和异常信息

@ResponseStatus(value = HttpStatus.FORBIDDEN, reason = "用户数量太多")public class UserTooManyException extends RuntimeException{    public UserTooManyException() {    }    public UserTooManyException(String message) {        super(message);    }}

异常产生逻辑:

// 判断用户数量抛出用户数量过多的自定义异常if (users.size() > 3) {    throw new UserTooManyException();}

1.4 异常处理之框架底层异常

  除了exception类中定义的异常外,spring框架底层也定义了一些异常,这些异常由DefaultHandlerExceptionResolver来处理

2 web原生组件的注入

2.1 servlet组件

  servlet组件需要自定义创建一个servlet类继承HttpServlet,并使用@WebServlet注解的urlPatterns属性声明拦截的请求,再通过主程序类上使用@ServletComponentScan(basePackages = “…”)注解将该组件扫描注册到容器中。

// 声明拦截的请求@WebServlet(urlPatterns = "/my")public class MyServlet extends HttpServlet {    @Override    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {        resp.getWriter().write("385695");    }}

2.2 filter组件

  filter组件需要自定义创建一个filter类实现Filter接口,并使用@WebFilter注解的urlPatterns属性声明过滤的请求

@Slf4j@WebFilter(urlPatterns = {"/css/*", "/images/*"})public class MyFilter implements Filter {    @Override    public void init(FilterConfig filterConfig) throws ServletException {        log.info("MyFilter初始化……");    }    @Override    public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {        log.info("MyFilter方法开始工作了……");        filterChain.doFilter(servletRequest, servletResponse);    }    @Override    public void destroy() {        log.info("MyFilter销毁了……");    }}

2.3 listener组件

  listener组件需要自定义创建一个listener类实现ServletContextListener 接口,并使用@WebListener注解

@Slf4j@WebListenerpublic class MyServletContextListener implements ServletContextListener {    @Override    public void contextInitialized(ServletContextEvent sce) {        log.info("MyServletContextListener监听到项目初始化完成……");    }    @Override    public void contextDestroyed(ServletContextEvent sce) {        log.info("MyServletContextListener监听到项目已经销毁……");    }}

除了使用注解进行注册之外,还可以使用配置类的方式将以上三种组件注册到容器中去

@Configurationpublic class MyRegistConfig {    @Bean    public ServletRegistrationBean MyServlet() {        MyServlet myServlet = new MyServlet();        return new ServletRegistrationBean(myServlet, "/my", "/my02");    }    @Bean    public FilterRegistrationBean myFilter() {        MyFilter myFilter = new MyFilter();        FilterRegistrationBean filterRegistrationBean = new FilterRegistrationBean(myFilter);        filterRegistrationBean.setUrlPatterns(Arrays.asList("/my", "/my02"));        return filterRegistrationBean;    }    @Bean    public ServletListenerRegistrationBean myListener() {        MyServletContextListener listener = new MyServletContextListener();        return new ServletListenerRegistrationBean(listener);    }}

  通过servlet组件声明的/my请求并不会经过spring的拦截器拦截处理,而是直接交由tomcat服务器进行处理:现在有这么两个组件拦截到我们发送的/my请求,一个是spring的组件DispatcherServlet通过/路径拦截到,一个是tomcat的自定义MyServlet组件通过/my路径拦截到。tomcat服务器对请求有这么一个处理规则,当多个servlet组件都能处理到同一个请求的时候,使用匹配度最高的组件进行处理,也就是说处理请求的是tomcat的MyServlet组件。

关于“SpringBoot2异常处理与web原生组件注入的方法”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注编程网行业资讯频道,小编每天都会为大家更新不同的知识点。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯