一、概述
springmvc的处理器拦截器是类似于servlet开发中的过滤器filter,用于对处理器进行预处理和后处理。开发者可以自己定义一些拦截器来实现特定的功能。
过滤器和拦截器的区别:拦截器是aop思想的具体应用。
过滤器:
- servlet规划的一部分,任何javaweb工程都可以用
- 在配置了url-pattern后,可以对所有访问的资源进行拦截
拦截器:
- 拦截器是springmvc自己的,只要使用了springmvc框架的工程才能用
- 拦截器只会拦截访问的控制器方法,如果访问的是静态资源则不会拦截
二、实现拦截器
实现拦截器,首先要实现HandlerInterceptor接口
<!-- 拦截器配置-->
<mvc:interceptors>
<mvc:interceptor>
<!-- 拦截这个路径下的所有请求 *代表只拦截一层,**代表拦截任意层。-->
<mvc:mapping path="/**"/>
<bean class="com.wei.interceptor.Myinterceptor"></bean>
</mvc:interceptor>
</mvc:interceptors>
package com.wei.interceptor;
import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
//正常情况下,我们使用拦截器只会实现preHandle方法处理请求
public class Myinterceptor implements HandlerInterceptor {
//拦截器是aop思想的具体实现
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
System.out.println("==========处理前===============");
//return true则执行下一个拦截,放行
// return false则不执行下一个拦截,放行
return false;
}
@Override
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
System.out.println("==========处理后===============");
}
@Override
public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
System.out.println("==========清理===============");
}
}
三、实现登录拦截
<!-- 配置拦截器-->
<mvc:interceptors>
<mvc:interceptor>
<!-- 拦截/book下的所有请求-->
<mvc:mapping path="/book/**"/>
<bean class="com.wei.interceptor.LoginInterceptor"></bean>
</mvc:interceptor>
</mvc:interceptors>
登录请求页面:
package com.wei.controller;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import javax.servlet.http.HttpSession;
@Controller
@RequestMapping("/lo")
public class LoginController {
@RequestMapping("/login")
public String login(HttpSession session,String username, String password){
//用户信息保存在session中
session.setAttribute("userinfo",username);
return "redirect:/book/queryall";
}
@RequestMapping("/logout")
public String logout(HttpSession session,String username, String password){
//用户信息保存在session中
session.removeAttribute("userinfo");
return "redirect:/book/queryall";
}
}