拦截器

  • 概述

    • springmbc的处理器拦截器类似于servelt开发中的过滤器FIlter,用于对处理器进行预处理和后处理,开发者可以自己定义一些拦截器来实现特定的功能

      过滤器与拦截器的区别

  • 拦截器是AOP思想的具体应用

    过滤器

  • servlet规范中的一部分,任何java web工程都可以使用

  • 在url-pattern中配置了 /* 之后,可以对所有要访问的资源进行拦截

    拦截器

  • 拦截器是springmvc框架自己的,只有使用了springmvc框架的工程才能使用

  • 拦截器只会拦截访问的控制器方法,如果访问的是静态资源则不会进行拦截

    自定义拦截器

  • 如何实现自定义拦截器呢?

  • 要进行自定义拦截器,必须要实现HandlerInterceptor接口
    • 新建一个 module ,添加web支持
    • 配置web.xml 和 springmvc-servlet.xml 文件
    • 编写一个拦截器 ```java package com.kuang.interceptor;

import org.springframework.web.servlet.HandlerInterceptor; import org.springframework.web.servlet.ModelAndView;

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

public class MyInterceptor implements HandlerInterceptor {

  1. //在请求处理的方法之前执行
  2. //如果返回true执行下一个拦截器
  3. //如果返回false就不执行下一个拦截器
  4. public boolean preHandle(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o) throws Exception {
  5. System.out.println("------------处理前------------");
  6. return true;
  7. }
  8. //在请求处理方法执行之后执行
  9. public void postHandle(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o, ModelAndView modelAndView) throws Exception {
  10. System.out.println("------------处理后------------");
  11. }
  12. //在dispatcherServlet处理后执行,做清理工作.
  13. public void afterCompletion(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o, Exception e) throws Exception {
  14. System.out.println("------------清理------------");
  15. }

}

  1. - 接下来在springmvc的配置文件中配置拦截器
  2. ```java
  3. <!--关于拦截器的配置-->
  4. <mvc:interceptors>
  5. <mvc:interceptor>
  6. <!--/** 包括路径及其子路径-->
  7. <!--/admin/* 拦截的是/admin/add等等这种 , /admin/add/user不会被拦截-->
  8. <!--/admin/** 拦截的是/admin/下的所有-->
  9. <mvc:mapping path="/**"/>
  10. <!--bean配置的就是拦截器-->
  11. <bean class="com.kuang.interceptor.MyInterceptor"/>
  12. </mvc:interceptor>
  13. </mvc:interceptors>
  • 编写一个controller ,接收请求 ```java package com.kuang.controller;

import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.ResponseBody;

//测试拦截器的控制器 @Controller public class InterceptorController {

  1. @RequestMapping("/interceptor")
  2. @ResponseBody
  3. public String testFunction() {
  4. System.out.println("控制器中的方法执行了");
  5. return "hello";
  6. }

}

  1. - 前端inde.jsp
  2. ```java
  3. <a href="${pageContext.request.contextPath}/interceptor">拦截器测试</a>
  • 测试

image.png

DEMO - 验证用户是否登陆

实现思路

  • 有一个登陆页面,需要写一个controller访问页面
  • 登陆页面有一提交表单的工作,需要在controller中处理,判断用户名密码是否正确,如果正确,向session中写入用户信息,返回登陆成功
  • 拦截用户请求,判断用户是否登陆,如果已经登陆,方形,否则跳转到登陆页面

    测试

  • 编写一个登陆页面 login.jsp ```java <%@ page contentType=”text/html;charset=UTF-8” language=”java” %>

登录页面


用户名:
密码:

  1. - 编写一个Controller请求
  2. ```java
  3. package com.kuang.controller;
  4. import org.springframework.stereotype.Controller;
  5. import org.springframework.web.bind.annotation.RequestMapping;
  6. import javax.servlet.http.HttpSession;
  7. @Controller
  8. @RequestMapping("/user")
  9. public class UserController {
  10. //跳转到登陆页面
  11. @RequestMapping("/jumplogin")
  12. public String jumpLogin() throws Exception {
  13. return "login";
  14. }
  15. //跳转到成功页面
  16. @RequestMapping("/jumpSuccess")
  17. public String jumpSuccess() throws Exception {
  18. return "success";
  19. }
  20. //登陆提交
  21. @RequestMapping("/login")
  22. public String login(HttpSession session, String username, String pwd) throws Exception {
  23. // 向session记录用户身份信息
  24. System.out.println("接收前端==="+username);
  25. session.setAttribute("user", username);
  26. return "success";
  27. }
  28. //退出登陆
  29. @RequestMapping("logout")
  30. public String logout(HttpSession session) throws Exception {
  31. // session 过期
  32. session.invalidate();
  33. return "login";
  34. }
  35. }
  • 编写一个登陆成功的页面success.jsp ```java <%@ page contentType=”text/html;charset=UTF-8” language=”java” %>

登录成功页面


${user} 注销

  1. - index页面上测试跳转,启动tomcat,发现未登录也能进入主页
  2. ```java
  3. <%@ page contentType="text/html;charset=UTF-8" language="java" %>
  4. <html>
  5. <head>
  6. <title>$Title$</title>
  7. </head>
  8. <body>
  9. <h1>首页</h1>
  10. <hr>
  11. <%--登录--%>
  12. <a href="${pageContext.request.contextPath}/user/jumplogin">登录</a>
  13. <a href="${pageContext.request.contextPath}/user/jumpSuccess">成功页面</a>
  14. </body>
  15. </html>
  • 编写用户登陆拦截器 ```java package com.kuang.interceptor;

import org.springframework.web.servlet.HandlerInterceptor; import org.springframework.web.servlet.ModelAndView;

import javax.servlet.ServletException; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import javax.servlet.http.HttpSession; import java.io.IOException;

public class LoginInterceptor implements HandlerInterceptor {

  1. public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws ServletException, IOException {
  2. // 如果是登陆页面则放行
  3. System.out.println("uri: " + request.getRequestURI());
  4. if (request.getRequestURI().contains("login")) {
  5. return true;
  6. }
  7. HttpSession session = request.getSession();
  8. // 如果用户已登陆也放行
  9. if(session.getAttribute("user") != null) {
  10. return true;
  11. }
  12. // 用户没有登陆跳转到登陆页面
  13. request.getRequestDispatcher("/WEB-INF/jsp/login.jsp").forward(request, response);
  14. return false;
  15. }
  16. public void postHandle(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o, ModelAndView modelAndView) throws Exception {
  17. }
  18. public void afterCompletion(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o, Exception e) throws Exception {
  19. }

}

  1. - Springmvc的配置文件中注册拦截器
  2. ```java
  3. <!--关于拦截器的配置-->
  4. <mvc:interceptors>
  5. <mvc:interceptor>
  6. <mvc:mapping path="/**"/>
  7. <bean id="loginInterceptor" class="com.kuang.interceptor.LoginInterceptor"/>
  8. </mvc:interceptor>
  9. </mvc:interceptors>
  • 再次进行测试则无误,拦截器中,返回true则继续进行后续方法,返回fasle则不执行后续拦截器

    文件上传和下载

  • 准备工作

    • 文件上传是项目开发中常见功能,springmvc可以很好的支持上传,但是在springmvc上下文中默认没有装配 MultipartResolver,因此默认情况下其不能处理文件上传工作,如果想使用spring的文件上传功能,需要在上下文中配置multipartResolver
  • 前端表单要求:为了能上传文件,必须将表单的method设置为post,并将enctype设置为multipart/form-data