最近在研究Spring MVC攔截器,那么今天也算個學(xué)習(xí)筆記吧!有需要了解使用Spring MVC攔截器實現(xiàn)日志記錄的朋友可參考。希望此文章對各位有所幫助。
1. 定義一個類實現(xiàn)HandlerInterceptor,比如:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
|
public class MyInterceptors implements HandlerInterceptor{ /** * 在渲染視圖之后被調(diào)用; * 可以用來釋放資源 */ public void afterCompletion(HttpServletRequest arg0, HttpServletResponse arg1, Object arg2, Exception arg3) throws Exception { // TODO Auto-generated method stub System.out.println( "MyInterceptors afterCompletion" ); } /** * 該方法在目標(biāo)方法調(diào)用之后,渲染視圖之前被調(diào)用; * 可以對請求域中的屬性或視圖做出修改 * */ public void postHandle(HttpServletRequest arg0, HttpServletResponse arg1, Object arg2, ModelAndView arg3) throws Exception { // TODO Auto-generated method stub System.out.println( "MyInterceptors postHandle" ); } /** * 可以考慮作權(quán)限,日志,事務(wù)等等 * 該方法在目標(biāo)方法調(diào)用之前被調(diào)用; * 若返回TURE,則繼續(xù)調(diào)用后續(xù)的攔截器和目標(biāo)方法 * 若返回FALSE,則不會調(diào)用后續(xù)的攔截器和目標(biāo)方法 * */ public boolean preHandle(HttpServletRequest arg0, HttpServletResponse arg1, Object arg2) throws Exception { // TODO Auto-generated method stub HandlerMethod handlerMethod = (HandlerMethod) arg2; System.out.println( "MyInterceptors preHandle 調(diào)用方法名:" +handlerMethod.getMethod().getName()); /* 寫一個日記類和Service,將需要的屬性保存到數(shù)據(jù)庫 */ return true ; } } |
2.在Springmvc.xml中裝配
1
2
3
4
5
6
7
|
<!-- 裝配攔截器 --> < mvc:interceptors > < mvc:interceptor > < mvc:mapping path = "/*" /> < bean class = "com.datatub.springmvc.interceptors.MyInterceptors" ></ bean > </ mvc:interceptor > </ mvc:interceptors > |
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持服務(wù)器之家。
原文鏈接:http://blog.csdn.net/baidu_21578557/article/details/51956302