SpringMVC攔截器和異常處理器使用示例超詳細講解
攔截器
1、攔截器的配置
SpringMVC中的攔截器用于攔截控制器方法的執(zhí)行
SpringMVC中的攔截器需要實現(xiàn)HandlerInterceptor
public class FirstInterceptor implements HandlerInterceptor {
//在控制器方法之前攔截
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
System.out.println("FirstInterceptor-preHandle");
return true;
}
//在控制器方法之后攔截
@Override
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
System.out.println("FirstInterceptor-postHandle");
}
//在視圖渲染之后攔截
@Override
public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
System.out.println("FirstInterceptor-afterCompletion");
}
}SpringMVC的攔截器必須在SpringMVC的配置文件中進行配置:
<!-- 配置攔截器-->
<mvc:interceptors>
<!-- 第一種 直接將攔截器類添加進來-->
<!-- <bean class="com.Interceptors.FirstInterceptor"/>-->
<!-- 第二種 先將攔截器類注入(在FirstInterceptor類添加注解@Component),然后在掃描組件添加,就可以使用-->
<!-- <ref bean="firstInterceptor"/>-->
<!-- 以上兩種配置方式都是對DispatcherServlet所處理的所有的請求進行攔截,不能配置 -->
<!-- 第三種 可以對攔截路徑配置-->
<mvc:interceptor>
<!-- 需要攔截的路徑-->
<mvc:mapping path="/**"/>
<!-- 不攔截的路徑-->
<mvc:exclude-mapping path="/"/>
<ref bean="firstInterceptor"/>
</mvc:interceptor>
</mvc:interceptors>
<!--
以上配置方式可以通過ref或bean標簽設(shè)置攔截器,通過mvc:mapping設(shè)置需要攔截的請求,通過mvc:exclude-mapping設(shè)置需要排除的請求,即不需要攔截的請求
-->
2、攔截器的三個抽象方法
SpringMVC中的攔截器有三個抽象方法:
preHandle:控制器方法執(zhí)行之前執(zhí)行preHandle(),其boolean類型的返回值表示是否攔截或放行,返回true為放行,即調(diào)用控制器方法;返回false表示攔截,即不調(diào)用控制器方法
postHandle:控制器方法執(zhí)行之后執(zhí)行postHandle()
afterComplation:處理完視圖和模型數(shù)據(jù),渲染視圖完畢之后執(zhí)行afterComplation()
3、多個攔截器的執(zhí)行順序
a>若每個攔截器的preHandle()都返回true
此時多個攔截器的執(zhí)行順序和攔截器在SpringMVC的配置文件的配置順序有關(guān):
preHandle()會按照配置的順序執(zhí)行,而postHandle()和afterComplation()會按照配置的反序執(zhí)行
b>若某個攔截器的preHandle()返回了false
preHandle()返回false和它之前的攔截器的preHandle()都會執(zhí)行,postHandle()都不執(zhí)行,返回false的攔截器之前的攔截器的afterComplation()會執(zhí)行
異常處理器
1、基于配置的異常處理
SpringMVC提供了一個處理控制器方法執(zhí)行過程中所出現(xiàn)的異常的接口:HandlerExceptionResolver
HandlerExceptionResolver接口的實現(xiàn)類有:DefaultHandlerExceptionResolver和SimpleMappingExceptionResolver
SpringMVC提供了自定義的異常處理器SimpleMappingExceptionResolver,使用方式:
<bean class="org.springframework.web.servlet.handler.SimpleMappingExceptionResolver">
<property name="exceptionMappings">
<props>
<!--
properties的鍵表示處理器方法執(zhí)行過程中出現(xiàn)的異常
properties的值表示若出現(xiàn)指定異常時,設(shè)置一個新的視圖名稱,跳轉(zhuǎn)到指定頁面
-->
<prop key="java.lang.ArithmeticException">error</prop>
</props>
</property>
<!--
exceptionAttribute屬性設(shè)置一個屬性名,將出現(xiàn)的異常信息在請求域中進行共享
設(shè)置異常信息保存在共享域中的鍵,默認保存在請求域,value為異常保存的鍵
-->
<property name="exceptionAttribute" value="exception"></property>
</bean>2、基于注解的異常處理
//@ControllerAdvice將當(dāng)前類標識為異常處理的組件
@ControllerAdvice
public class ExceptionController {
//@ExceptionHandler用于設(shè)置所標識方法處理的異常
@ExceptionHandler(ArithmeticException.class)
//ex表示當(dāng)前請求處理中出現(xiàn)的異常對象
public String handleArithmeticException(Exception exception, Model model){
model.addAttribute("exception", exception);
return "error";
}
}到此這篇關(guān)于SpringMVC攔截器和異常處理器使用示例超詳細講解的文章就介紹到這了,更多相關(guān)SpringMVC攔截器和異常處理器內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
SpringBoot2.X整合Spring-Cache緩存開發(fā)的實現(xiàn)
本文主要介紹了SpringBoot2.X整合Spring-Cache緩存開發(fā)的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-07-07
Spring Boot集成ElasticSearch實現(xiàn)搜索引擎的示例
這篇文章主要介紹了Spring Boot集成ElasticSearch實現(xiàn)搜索引擎的示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-11-11
Character.UnicodeBlock中cjk的說明詳解
這篇文章主要為大家詳細介紹了Character.UnicodeBlock中cjk的說明,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-09-09

