SpringMVC拦截器

栏目: Java · 发布时间: 6年前

内容简介:SpringMVC拦截器

java里的拦截器是动态拦截Action调用的对象,它提供了一种机制可以使开发者在一个Action执行的前后执行一段代码,也可以在一个Action执行前阻止其执行,同时也提供了一种可以提取Action中可重用部分代码的方式。在AOP中,拦截器用于在某个方法或者字段被访问之前,进行拦截,然后再之前或者之后加入某些操作。

拦截器代码

java部分

public class HandlerInterceptorAdapter implements HandlerInterceptor {   
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) 
            throws Exception{
    }   
    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView)
            throws Exception{
    }   
    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex)
            throws Exception{
    }
}

spring-MVC配置部分

<!--配置拦截器, 多个拦截器,顺序执行 -->
    <mvc:interceptors>
        <mvc:interceptor>
            <!-- 匹配的是url路径, 如果不配置或/**,将拦截所有的Controller -->
            <mvc:mapping path="/ps/**" />
            <!--<mvc:mapping path="/user/**" />-->
            <!--<mvc:mapping path="/test/**" />-->
            <bean class="com.weixin.InterceptorAdapter.HandlerInterceptorAdapter"></bean>
        </mvc:interceptor>
        <!-- 当设置多个拦截器时,先按顺序调用preHandle方法,然后逆序调用每个拦截器的postHandle和afterCompletion方法 -->
    </mvc:interceptors>

拦截器用法

接口源码

//继承spring的拦截接口,实现以下三个方法
public interface HandlerInterceptor {
    // 在业务处理器处理请求之前被调用
    boolean preHandle(HttpServletRequest var1, HttpServletResponse var2, Object var3) throws Exception;
    // 在业务处理器处理请求完成之后,生成视图之前执行
    void postHandle(HttpServletRequest var1, HttpServletResponse var2, Object var3, ModelAndView var4) throws Exception;
    // 在DispatcherServlet完全处理完请求之后被调用,可用于清理资源,日志打印
    void afterCompletion(HttpServletRequest var1, HttpServletResponse var2, Object var3, Exception var4) throws Exception;
}

preHandle详解

preHandle 方法有三个参数,分别是HttpServletRequest HttpServletResponse Object 传参: - HttpServletRequest 控制程序在业务处理器前的请求参数 - HttpServletResponse 控制程序在经过处理器后的返回参数 - Object 被拦截的请求Action的实体 返回值: - true表示继续流程 - false表示流程中断,不会继续调用其他的拦截器或处理器,此时我们需要通过response来产生响应

实例:

public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception{
        //计算出服务器当前时间
        Long timeNowForServer=new Date().getTime();
        //获取从前端接口请求的参数
        if(null!=request.getParameter("token")){
        //因为前端请求做了加密,所以这里需要对应的解密过程
            String token=EncryptUtil.aesDecrypt(request.getParameter("token"),"0000000000000000");
            if(null!=token) {
                Long timeNowForClient = Long.parseLong(token);
                //如果请求接口在五秒内
                Long timeMinus = timeNowForServer - timeNowForClient;
                if (-50000 <= timeMinus && timeMinus <= 50000) {
                    //继续接口流程
                    return true;
                } else {
                    //返回相应的HTTP状态码,达到拦截的效果
                    //response.sendError(http状态码,页面显示的拦截原因);
                    response.sendError(405, "Parameters illegal");
                    //打回这次操作,返回相应的response
                    return false;
                }
            }else{
                response.sendError(405, "Parameters illegal");
                return false;
            }
        //或者请求地址中含有getUserInfo就放开对这个请求的拦截,等于白名单的效果
        }else if(request.getRequestURI().indexOf("getUserInfo")>0){
            return true;
        }else{
             //跳转到其他页面
             response.sendRedirect(request.getContextPath() + "/Login1.html");                  
             return false;
        }
    }

状态码可参照HTTP状态码大全


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

代码

代码

劳伦斯・莱斯格 / 李旭 / 中信出版社 / 2004-10-1 / 30.00元

劳伦斯·莱斯格的著作《代码》 问世便震动了学界和业界,被人称为“也许是迄今为止互联网领域最重要的书籍”,也被一些学者称为“网络空间法律的圣经”。 《代码》挑战了早期人们对互联网的认识,即技术已经创造了一个自由的环境,因而网络空间无法被规制——也就是说,网络的特性使它押脱了政府的控制。莱斯格提出,事实恰恰相反。 代码的存在证明,网络并不是本制拷贝 ,不可规制的,它并没有什......一起来看看 《代码》 这本书的介绍吧!

随机密码生成器
随机密码生成器

多种字符组合密码

HTML 编码/解码
HTML 编码/解码

HTML 编码/解码

MD5 加密
MD5 加密

MD5 加密工具