SpringMVC拦截器

编写拦截器

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的配置文件:

<!-- 在实际开发中通常都需配置 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 就是你自定义的拦截器了

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏别先生

Hibernate之关联关系映射(一对一主键映射和一对一外键映射)

1:Hibernate的关联关系映射的一对一外键映射:   1.1:第一首先引包,省略   1.2:第二创建实体类:     这里使用用户信息和身份证信息的关系...

22870
来自专栏码匠的流水账

使用RSQL实现端到端的动态查询

RSQL(RESTful Service Query Language)是Feed Item Query Language (FIQL) 的超集,是一种REST...

10800
来自专栏Lambda

Junit加载Spring容器作单元测试_添加事务回滚

Junit加载Spring容器作单元测试_添加事务回滚 在执行单元测试时,为了避免产生脏数据,将测试单元设置成事务回滚!!!!! package com...

21950
来自专栏老码农专栏

Actframework依赖注入 II - 注入对象类型

12130
来自专栏Java3y

从零开始写项目第一篇【搭建环境】

使用Maven搭建SSM环境 SSM需要的基础jar包有哪些??整理一下: c3p0数据连接池 springMVC的JSON springAOP springC...

562100
来自专栏青玉伏案

iOS开发之表视图爱上CoreData

  在接触到CoreData时,感觉就是苹果封装的一个ORM。CoreData负责在Model的实体和sqllite建立关联,数据模型的实体类就相当于Java中...

20980
来自专栏進无尽的文章

编码篇-一个商品录入时的UITableCell的总结

我们都知道iOS的UITableView有自带的 左滑动删除的方式,此中方式中,不论是删除数据源,还是删除对应的Cell都是很简单的。可是有时候,产品不是通过滑...

15730
来自专栏JAVA后端开发

JAVA实现编写平台代码生成器

[项目中经常写CRUD,但实际这些工作,我觉得如果有一个完整的代码规范,完全可以自动生成,加快开发效率. 代码生成器技术原理不复杂,一般就是写好一个模板生成一...

1.2K20
来自专栏JAVA技术站

Sharding-Jdbc之读写分离导读 原

      Sharding-JDBC是一个开源的分布式数据库中间件,它无需额外部署和依赖,完全兼容JDBC和各种ORM框架。Sharding-JDBC作为面向...

74730
来自专栏Java面试通关手册

从分析我抓取的60w知乎网民来学习如何在SSM项目中使用Echarts

去年在接触Java爬虫的时候,接触到了一个关于知乎的爬虫。个人觉得写的非常好,当时抓取的效率和成功率还是特别特别高,现在可能知乎反扒做的更好,这个开源知乎爬虫没...

26430

扫码关注云+社区

领取腾讯云代金券