秀外慧中的springMVC(四)---springmvc的拦截器

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;
	}

}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值