zoukankan      html  css  js  c++  java
  • ssm项目中使用拦截器加上不生效解决方案

      在很多时候,需要拦截器来帮助我们完成一些特定的工作,比如获取请求的参数,本身在request这种获取数据就是一次磁盘的io,

    如果在filter中获取了参数,那么在controller中就不能获取相关参数,,所以一般有时候需要从interceptor来进行相关功能的完成,本来可以在springboot中轻松使用interceptor,那么

    可以在ssm中使用呢,是不是有点难度呢,主要一直使用那个后来一直没有使用ssm,所以今天进行测试下,

    首先,写一个类HttpInterceptor  继承HandlerInterceptorAdapter,或者 实现HandlerInterceptor

    public class HttpInterceptor /*extends HandlerInterceptorAdapter*/ implements HandlerInterceptor{

    然后看具体的代码:

    package com.yd.ydpdm.common.aspect;
    
    import java.util.Map;
    
    import javax.servlet.http.HttpServletRequest;
    import javax.servlet.http.HttpServletResponse;
    
    import org.springframework.stereotype.Component;
    import org.springframework.web.servlet.HandlerInterceptor;
    import org.springframework.web.servlet.ModelAndView;
    import org.springframework.web.servlet.handler.HandlerInterceptorAdapter;
    
    @Component
    public class HttpInterceptor /*extends HandlerInterceptorAdapter*/ implements HandlerInterceptor{
    
    
        private static final String START_TIME = "requestStartTime";
        @Override
        public void afterCompletion(HttpServletRequest request, HttpServletResponse arg1, Object arg2, Exception arg3)
                throws Exception {
              String url = request.getRequestURI().toString();
                long start = (Long) request.getAttribute(START_TIME);
                long end = System.currentTimeMillis();
                System.err.println("request completed. url:{}, cost:{}"+ url+(end - start));
                System.out.println("11111");
            
        }
    
        @Override
        public void postHandle(HttpServletRequest request, HttpServletResponse arg1, Object arg2, ModelAndView arg3)
                throws Exception {
            String url = request.getRequestURI().toString();
            long start = (Long) request.getAttribute(START_TIME);
            long end = System.currentTimeMillis();
            System.out.println(start);
            System.out.println(end);
            System.err.println("request finished. url:{}, cost:{}"+ url+"-------------------------"+(end - start));
            System.out.println("3");
            
        }
    
        @Override
        public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
            String url = request.getRequestURI().toString();
           
            Map parameterMap = request.getParameterMap();
            System.err.println("request start. url:{}, params:{}"+url+parameterMap);
            long start = System.currentTimeMillis();
            System.out.println("2");
            request.setAttribute(START_TIME, start);
            return true;
        }
    
    }

    在前置拦截器中,return true 代表放行的意思,如果return false就不放行的意思.

    如上拦截器就是进行测试的,记录接口执行时间

    在拦截器写完之后还需要进行其他配置,

    在springmvc中配置:

     <mvc:interceptors>
            <mvc:interceptor>
                <mvc:mapping path="/**" />            
                <bean class="com.yd.ydpdm.common.aspect.HttpInterceptor"></bean>
            </mvc:interceptor>
        </mvc:interceptors>

    1. 如果不生效,可以配置:

     <mvc:interceptors>
            <bean class="com.yd.ydpdm.common.aspect.HttpInterceptor"></bean>
            <mvc:interceptor>
                <mvc:mapping path="/**" />            
                <bean class="com.yd.ydpdm.common.aspect.HttpInterceptor"></bean>
            </mvc:interceptor>
        </mvc:interceptors>

    配置一个独立的bean,是由于在<mvc:annotation-driven />这个里面有个拦截器的级别高,导致不生效,

    2 然后我在测试过程出现了问题,就是配置了,然后所有的都写了,就是不生效这个拦截器,所以找来很久原因,但是一直没找出来

    最后具体原因就是写的代码不生效,,

    最终原因是,在这个过程中代码在编译工具中没有进行编译,.再进行一次编译之后就生效了

    3 如果在前置拦截器中,retrun false

     4 并不需要配置@component注解因为在项目初始化的时候就进行了初始化,因为在web.xml中文件是入口文件,配置了之后就会进行加载,,并不需要springbean进行初始化

  • 相关阅读:
    Just Do It:战胜拖延症(终极大法!)
    拖延是一种什么病
    数学之美系列二十三 谈谈香农第一定律
    深度挖掘
    当机器统治世界
    算法是如何秘密左右我们的行为方式
    比人类更强:为什么机器人终将也必将接手我们的工作?
    Google移动的未来在哪里?Google Now
    数学之美系列十九 马尔可夫链的扩展 贝叶斯网络 (Bayesian Networks)
    Matlab与COM应用(一)——COM技术概述
  • 原文地址:https://www.cnblogs.com/xiufengchen/p/11205283.html
Copyright © 2011-2022 走看看