前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >SpringMVC拦截器

SpringMVC拦截器

作者头像
試毅-思伟
发布2018-09-06 10:54:22
8200
发布2018-09-06 10:54:22
举报
文章被收录于专栏:Java开发

编写拦截器

代码语言:javascript
复制
package com.platform.interceptor;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;

/**
 * 测试SpringMVC拦截器
 * 
 * @author Joey
 * @project:copyright_platform
 * @date:2017年4月27日
 * 
 */
public class TestInterceptor implements HandlerInterceptor {

    private Logger logger = LoggerFactory.getLogger(getClass());

    /**
     * 在业务处理器处理请求之前被调用 如果返回false 从当前的拦截器往回执行所有拦截器的afterCompletion(),再退出拦截器链
     * 
     * 如果返回true 执行下一个拦截器,直到所有的拦截器都执行完毕 再执行被拦截的Controller 然后进入拦截器链,
     * 从最后一个拦截器往回执行所有的postHandle() 接着再从最后一个拦截器往回执行所有的afterCompletion()
     */
    @Override
    public boolean preHandle(HttpServletRequest request,
            HttpServletResponse response, Object handler) throws Exception {
        logger.info("==============执行顺序: 1、preHandle================");
        String url = request.getRequestURL().toString();
        if (url.matches("admim/login")) {
            request.getRequestDispatcher("/admin/login.html").forward(request,
                    response);
            return false;
        }
        return true;
    }

    /**
     * 在业务处理器处理请求执行完成后,生成视图之前执行的动作
     */
    @Override
    public void postHandle(HttpServletRequest request,
            HttpServletResponse response, Object handler,
            ModelAndView modelAndView) throws Exception {
        logger.info("==============执行顺序: 2、postHandle================");
    }

    /**
     * 在DispatcherServlet完全处理完请求后被调用
     * 
     * 当有拦截器抛出异常时,会从当前拦截器往回执行所有的拦截器的afterCompletion()
     */
    @Override
    public void afterCompletion(HttpServletRequest request,
            HttpServletResponse response, Object handler, Exception ex)
            throws Exception {
        logger.info("==============执行顺序: 3、afterCompletion================");
    }

}

简单的就是进行日志的一个打印功能!

可以自己实现想要的功能

SpringMVC的配置文件:

代码语言:javascript
复制
<!-- 在实际开发中通常都需配置 mvc:annotation-driven标签,这个标签是开启注解 -->  
<mvc:annotation-driven></mvc:annotation-driven>  
<mvc:interceptors>
    <mvc:interceptor>
        <mvc:mapping path="/admin/**" />
        <mvc:exclude-mapping path="admin/sys/login" />
        <bean class="com.platform.interceptor.TestInterceptor" />
    </mvc:interceptor>
</mvc:interceptors>

mvc:mapping是你要映射的拦截路径 可以有多个 mvc:exclude-mapping 是你排除映射的拦截路径,也可以有多个 下面那个bean 就是你自定义的拦截器了

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2017.12.20 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档