最近在研究Spring MVC拦截器,那么今天也算个学习笔记吧!有需要了解使用Spring MVC拦截器实现日志记录的朋友可参考。希望此文章对各位有所帮助。
1. 定义一个类实现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{
/**
* 在渲染视图之后被调用;
* 可以用来释放资源
*/
public void afterCompletion(HttpServletRequest arg0,
HttpServletResponse arg1, Object arg2, Exception arg3)
throws Exception {
// TODO Auto-generated method stub
System.out.println( "MyInterceptors afterCompletion" );
}
/**
* 该方法在目标方法调用之后,渲染视图之前被调用;
* 可以对请求域中的属性或视图做出修改
*
*/
public void postHandle(HttpServletRequest arg0, HttpServletResponse arg1,
Object arg2, ModelAndView arg3) throws Exception {
// TODO Auto-generated method stub
System.out.println( "MyInterceptors postHandle" );
}
/**
* 可以考虑作权限,日志,事务等等
* 该方法在目标方法调用之前被调用;
* 若返回TURE,则继续调用后续的拦截器和目标方法
* 若返回FALSE,则不会调用后续的拦截器和目标方法
*
*/
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 调用方法名:" +handlerMethod.getMethod().getName());
/*
写一个日记类和Service,将需要的属性保存到数据库
*/
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 >
|
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:http://blog.csdn.net/baidu_21578557/article/details/51956302