【Java】SpringMVC拦截器

1.定义拦截器
  • 实现HandlerInterceptor接口
  • 继承HandlerInterceptorAdaptor类
2.拦截器方法
  • preHandle:拦截于请求刚进入时,进行判断,需要boolean返回值,如果返回true将继续执行,如果返回false,将不进行执行。
  • postHandle:拦截于方法成功返回后,视图渲染前,可以对modelAndView进行操作。
  • afterCompletion:拦截于方法成功返回后,视图渲染前,可以进行成功返回的日志记录。
3.拦截器配置
    <mvc:interceptors>
        <mvc:interceptor>
            <!-- 配置拦截URL -->
            <mvc:mapping path="/*"/>
            <!-- 配置拦截器实现类 -->
            <bean class="Interceptor"></bean>
        </mvc:interceptor>
    </mvc:interceptors>
4.登录校验的实现
//AuthcInterceptor.java - 拦截器实现
public class AuthcInterceptor implements HandlerInterceptor {

    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        String uri = request.getRequestURI();
        System.out.println("已进入拦截器,拦截URL: " + uri);
        //如果匹配上URI中存在login,即不拦截该请求
        if (uri.matches(".+login$")) {
            return true;
        }
        User c_user = (User) request.getSession().getAttribute("USER_SESSION");
        if (null != c_user) {
            return true;
        }
        response.sendRedirect("../");
        return false;
    }

    @Override
    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {

    }

    @Override
    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {

    }

}

// UserController.java - 实现用户登录的controller
@Controller
@RequestMapping("/user")
public class UserController {

    @Autowired
    IUserService userService;

    @RequestMapping(value = "/login", method = RequestMethod.POST)
    @ResponseBody
    public Result login(@Valid User user, BindingResult bindingResult, @ApiIgnore HttpSession session) {
        if (bindingResult.hasFieldErrors()) {
            for (FieldError error : bindingResult.getFieldErrors()) {
                return ResultGenerator.genFailResult(error.getDefaultMessage());
            }
        }
        User c_user = userService.login(user);
        if(null == c_user) {
            return ResultGenerator.genFailResult("该用户不存在");
        }
        session.setAttribute("USER_SESSION", c_user);
        return ResultGenerator.genSuccessResult();
    }

    @RequestMapping(value = "/logout", method = RequestMethod.GET)
    public String logout(HttpSession session) {
        //用户正常退出,销毁session对象
        session.invalidate();
        return "redirect:login";
    }
}
<!-- spring-mvc.xml - 拦截器的配置 -->
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:mvc="http://www.springframework.org/schema/mvc"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
       http://www.springframework.org/schema/beans/spring-beans.xsd
       http://www.springframework.org/schema/mvc
       http://www.springframework.org/schema/mvc/spring-mvc.xsd">

    <mvc:interceptors>
        <mvc:interceptor>
            <!-- 拦截对象是方法 -->
            <mvc:mapping path="/user/**"/>
            <bean class="cn.edu.yau.interceptors.AuthcInterceptor"></bean>
        </mvc:interceptor>
    </mvc:interceptors>

</beans>
  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值