1.拦截器知识
springmvc的拦截器分为
前置拦截器--->controller--->后置拦截器--->最终拦截器
其中拦截器可以设置多个组成拦截器链
前置拦截器主要是权限控制,一些控制等,如果返回true则继续运行,如果返回false则停止本次请求,可以设置返回等
后置拦截器,请求后controller执行,可以在这个方法中设置和修改model属性,添加全局参数等
最终拦截器是在视图本解析完毕准备返回浏览器时候执行,可以拦截异常,进行日志的监控等
2.springmvc的拦截器的配置
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:mvc="http://www.springframework.org/schema/mvc"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:aop="http://www.springframework.org/schema/aop"
xmlns:tx="http://www.springframework.org/schema/tx"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
http://www.springframework.org/schema/mvc
http://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-3.0.xsd
http://www.springframework.org/schema/aop
http://www.springframework.org/schema/aop/spring-aop-3.0.xsd
http://www.springframework.org/schema/tx
http://www.springframework.org/schema/tx/spring-tx-3.0.xsd ">
<!-- mvc注解驱动 当有扫描器时候component-scan此标签可以省略
<mvc:annotation-driven/>
-->
<!-- 扫描器 -->
<context:component-scan base-package="org.senssic.springmvc"></context:component-scan>
<!-- 定义ViewResolver -->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/jsp/"/>
<property name="suffix" value=".jsp"/>
</bean>
<!-- 文件上传 解析器,其中multipartResolver为固定-->
<bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
<!-- 上传文件的最大值,以byte为单位 -->
<property name="defaultEncoding" value="UTF-8"/>
<!-- 指定所上传文件的总大小不能超过200m。注意maxUploadSize属性的限制不是针对单个文件,而是所有文件的容量之和 -->
<property name="maxUploadSize" value="200000000"/>
</bean>
<!-- SpringMVC在超出上传文件限制时,会抛出org.springframework.web.multipart.MaxUploadSizeExceededException -->
<!-- 该异常是SpringMVC在检查上传的文件信息时抛出来的,而且此时还没有进入到Controller方法中 -->
<bean id="exceptionResolver" class="org.springframework.web.servlet.handler.SimpleMappingExceptionResolver">
<property name="exceptionMappings">
<props>
<!-- 遇到MaxUploadSizeExceededException异常时,自动跳转到/WEB-INF/jsp/error_fileupload.jsp页面 -->
<prop key="org.springframework.web.multipart.MaxUploadSizeExceededException">error_fileupload</prop>
</props>
</property>
</bean>
<mvc:interceptors>
<!-- 可以设置多个拦截器形成拦截器链 -->
<mvc:interceptor>
<!-- 某一模块:/xxx/** 所有请求:/** -->
<mvc:mapping path=""/>
<bean class="org.senssic.springmvc.MyIntercept"></bean>
</mvc:interceptor>
</mvc:interceptors>
</beans>
3.拦截器类
package org.senssic.springmvc;
import java.util.Map;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;
public class MyIntercept implements HandlerInterceptor {
/**
* 最终拦截器,视图已经被解析完毕
*
* @see主要是做监控,所有页面异常将被放到exception中即arg3中,可以存放日志等
*/
@Override
public void afterCompletion(HttpServletRequest arg0,
HttpServletResponse arg1, Object arg2, Exception arg3)
throws Exception {
System.out.println("最终拦截器,控制异常监控等");
}
/**
* 后置拦截,controller执行完,视图解析器没有解析成页面
*
* @see主要用于model的修改和添加
*/
@Override
public void postHandle(HttpServletRequest arg0, HttpServletResponse arg1,
Object arg2, ModelAndView arg3) throws Exception {
Map<String, Object> map = arg3.getModel();
map.put("ssss", "ffff");
System.out.println("后置拦截器,我是controller执行后进行拦截的");
}
/**
* 前置拦截(位于controller之前来执行),如果返回为true则放行继续运行可以访问controller,
* false不可以访问controller
*
* @see 最多用于权限拦截
*/
@Override
public boolean preHandle(HttpServletRequest arg0, HttpServletResponse arg1,
Object arg2) throws Exception {
System.out.println("前置拦截器,在还未访问controller时候进行拦截的");
return true;
}
}