SpringBoot2异常处理与web原生组件注入的方法(springboot2,web,开发技术)

时间:2024-05-03 14:28:23 作者 : 石家庄SEO 分类 : 开发技术
  • TAG :

    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@ControllerAdvicepublicclassGlobalExceptionHandler{@ExceptionHandler({ArithmeticException.class,NullPointerException.class})publicStringhandleArithException(Exceptione){log.info("系统捕获到异常信息:{}",e);return"login";}}

    1.3 异常处理之自定义异常

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

    @ResponseStatus(value=HttpStatus.FORBIDDEN,reason="用户数量太多")publicclassUserTooManyExceptionextendsRuntimeException{publicUserTooManyException(){}publicUserTooManyException(Stringmessage){super(message);}}

    异常产生逻辑:

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

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

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

    2 web原生组件的注入

    2.1 servlet组件

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

    //声明拦截的请求@WebServlet(urlPatterns="/my")publicclassMyServletextendsHttpServlet{@OverrideprotectedvoiddoGet(HttpServletRequestreq,HttpServletResponseresp)throwsServletException,IOException{resp.getWriter().write("385695");}}

    2.2 filter组件

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

    @Slf4j@WebFilter(urlPatterns={"/css/*","/images/*"})publicclassMyFilterimplementsFilter{@Overridepublicvoidinit(FilterConfigfilterConfig)throwsServletException{log.info("MyFilter初始化……");}@OverridepublicvoiddoFilter(ServletRequestservletRequest,ServletResponseservletResponse,FilterChainfilterChain)throwsIOException,ServletException{log.info("MyFilter方法开始工作了……");filterChain.doFilter(servletRequest,servletResponse);}@Overridepublicvoiddestroy(){log.info("MyFilter销毁了……");}}

    2.3 listener组件

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

    @Slf4j@WebListenerpublicclassMyServletContextListenerimplementsServletContextListener{@OverridepublicvoidcontextInitialized(ServletContextEventsce){log.info("MyServletContextListener监听到项目初始化完成……");}@OverridepublicvoidcontextDestroyed(ServletContextEventsce){log.info("MyServletContextListener监听到项目已经销毁……");}}

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

    @ConfigurationpublicclassMyRegistConfig{@BeanpublicServletRegistrationBeanMyServlet(){MyServletmyServlet=newMyServlet();returnnewServletRegistrationBean(myServlet,"/my","/my02");}@BeanpublicFilterRegistrationBeanmyFilter(){MyFiltermyFilter=newMyFilter();FilterRegistrationBeanfilterRegistrationBean=newFilterRegistrationBean(myFilter);filterRegistrationBean.setUrlPatterns(Arrays.asList("/my","/my02"));returnfilterRegistrationBean;}@BeanpublicServletListenerRegistrationBeanmyListener(){MyServletContextListenerlistener=newMyServletContextListener();returnnewServletListenerRegistrationBean(listener);}}

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

     </div> <div class="zixun-tj-product adv-bottom"></div> </div> </div> <div class="prve-next-news">
    本文:SpringBoot2异常处理与web原生组件注入的方法的详细内容,希望对您有所帮助,信息来源于网络。
    上一篇:Java中的静态字段和静态方法怎么用下一篇:

    19 人围观 / 0 条评论 ↓快速评论↓

    (必须)

    (必须,保密)

    阿狸1 阿狸2 阿狸3 阿狸4 阿狸5 阿狸6 阿狸7 阿狸8 阿狸9 阿狸10 阿狸11 阿狸12 阿狸13 阿狸14 阿狸15 阿狸16 阿狸17 阿狸18