當前位置:
首頁 >
前端技术
> javascript
>内容正文
javascript
SpringMVC拦截器(interceptors)
生活随笔
收集整理的這篇文章主要介紹了
SpringMVC拦截器(interceptors)
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
一、什么是攔截器?
spring提供的一個特殊的組件,當DispatcherServlet收到請求之后,如果有攔截器,會先調用攔截器,然后調用響應的處理器(Controller)。 注: 過濾器屬于servlet規范,而攔截器屬于spring框架。
二、如何寫一個攔截器?
1.寫一個java類,實現HandlerInterceptor接口
//實現HandlerInterceptor接口 //可自動生成preHandle()、postHandle()、afterCompletio()方法 public class SomeInterceptor implements HandlerInterceptor{/*** DispatcherServlet收到請求之后,會先調用preHandle方法* 如果該方法的返回值為true,則繼續向后調用 * 如果該方法的返回值為false,則不再向后調用* * Object handler:描述處理器方法的一個對象*/public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler)throws Exception {System.out.println("preHandle()");return true;}/*** 處理器(Controlle)的方法已經執行完畢* 正準備將結果(ModelAndView對象)返回* 給DispatcherServlet之前執行postHandle方法* 可以在該方法里去修改處理器返回的結果*/public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler,ModelAndView modelAndView) throws Exception {System.out.println("postHandle()");}/*** 當preHandle返回值為true該方法才會執行* afterCompletion在postHandle方法執行之后才執行* * Exception ex處理處理器所拋出的異常,可以寫一個攔截器用來處理處理器拋出的異常*/public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex)throws Exception {System.out.println("afterCompletion()");}}2.實現具體的攔截處理邏輯。比如:session驗證
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler)throws Exception {System.out.println("preHandle()");HttpSession session= request.getSession();Object obj = session.getAttribute("admin");if(obj == null) {//未登錄,重定向到登錄界面response.sendRedirect("toLogin.do");return false;}return false;}3.配置攔截器(springmvc配置文件中)
<!-- 配置攔截器 --><!-- 如果有多個攔截器,會按照配置的先后順序執行 --><mvc:interceptors><mvc:interceptor><!-- 攔截器路徑配置 --><!-- 攔截路徑多的話會分層多加一個*號即攔截所有的請求路徑為/**--><!-- 要攔截的路徑 --><mvc:mapping path="/**"/><!-- 攔截器不需要攔截的路徑 --><mvc:exclude-mapping path=""/><!-- 攔截器類 -->><bean class="攔截器要攔截的java代碼路徑"></mvc:interceptor></mvc:interceptors>總結
以上是生活随笔為你收集整理的SpringMVC拦截器(interceptors)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: MySQL 笔记7 -- 权限操作与视
- 下一篇: MySQL 笔记8 -- 存储过程和索