Java自学者论坛

 找回密码
 立即注册

手机号码,快捷登录

恭喜Java自学者论坛(https://www.javazxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,会员资料板块,购买链接:点击进入购买VIP会员

JAVA高级面试进阶训练营视频教程

Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程Go语言视频零基础入门到精通Java架构师3期(课件+源码)
Java开发全终端实战租房项目视频教程SpringBoot2.X入门到高级使用教程大数据培训第六期全套视频教程深度学习(CNN RNN GAN)算法原理Java亿级流量电商系统视频教程
互联网架构师视频教程年薪50万Spark2.0从入门到精通年薪50万!人工智能学习路线教程年薪50万大数据入门到精通学习路线年薪50万机器学习入门到精通教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程MySQL入门到精通教程
查看: 552|回复: 0

ssm项目中使用拦截器加上不生效解决方案

[复制链接]
  • TA的每日心情
    奋斗
    2024-11-24 15:47
  • 签到天数: 804 天

    [LV.10]以坛为家III

    2053

    主题

    2111

    帖子

    72万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    726782
    发表于 2021-6-16 03:33:45 | 显示全部楼层 |阅读模式

      在很多时候,需要拦截器来帮助我们完成一些特定的工作,比如获取请求的参数,本身在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进行初始化

    哎...今天够累的,签到来了1...
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|小黑屋|Java自学者论坛 ( 声明:本站文章及资料整理自互联网,用于Java自学者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2025-2-2 04:42 , Processed in 0.063836 second(s), 30 queries .

    Powered by Discuz! X3.4

    Copyright © 2001-2021, Tencent Cloud.

    快速回复 返回顶部 返回列表