SpringMVC拦截器实现登录验证

Spring拦截器说明:

  1. 拦截器通过统一拦截从浏览器发往服务器的请求,进行相应的处理,完成功能增强
  2. SpringMVC拦截器是可插拔式设计,使用时,直接在配置文件中应用该拦截器即可
  3. 使用场景:解决浏览器请求的共性问题(如:用户权限验证,乱码等)
  4. SpringMVC中的拦截器类通过实现HandlerInterceptor接口完成,
    HandlerInterceptor接口中定义了如下三个方法:
    • boolean preHandle(HttpServletRequest request,HttpServletRepsonse repsonse,Object handler).      该方法在请求处理之前被调用,可以在此方法中进行一些初始化操作,也可以进行一些判断来决定请求是否继续执行。(若返回值为true,则正常往下执行,若为false,其余两个方法不会执行,且后边的Interceptor和Controller不再执行)
    • boolean postHandle(HttpServletRequest request,HttpServletRepsonse repsonse,Object handler,ModelAndView mv).     该方法在请求被Controller处理之后,返回dispatcherServlet进行视图渲染之前执行,因此我们能操作Controller处理后的ModelAndView对象。
    • void afterCompletion(HttpServletRequest request,HttpServletRepsonse repsonse,Object handler,Exception exception)     该方法在整个请求结束之后执行,主要进行资源清理等。

登录验证实现:

控制器:
InterceptorController.java

import javax.servlet.http.HttpSession;

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.servlet.ModelAndView;
import com.zpc.entity.User;

@Controller
public class InterceptorController {

    private static final Log logger = LogFactory.getLog(InterceptorController.class);

    @RequestMapping(value="/{formName}")
    public String loginForm(@PathVariable String formName) {
        //动态页面跳转
        return formName;
    }

    @RequestMapping(value="/loginForm",method=RequestMethod.POST)
    public ModelAndView login(String username,String password,ModelAndView mv,HttpSession session) {
        if(username.equals("zpc") && username != null && password.equals("123456") && password != null) {
            User user = new User();
            user.setUsername(username);
            user.setPassword(password);
            logger.info(user);
            session.setAttribute("user", user);
            mv.setViewName("redirect:index");
        }else {
            mv.addObject("error","用户名或密码错误");
            mv.setViewName("login");
        }
        return mv;
    }
}

bookController.java

import java.util.ArrayList;
import java.util.List;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.servlet.ModelAndView;

import com.zpc.entity.Book;

public class bookController {

    @RequestMapping(value="/index")
    public ModelAndView book(ModelAndView mv) {

        List<Book> books = new ArrayList<Book>();
        books.add(new Book(10001,"JavaScript从入门到精通","明日科技"));
        books.add(new Book(10002,"Ajax从入门到精通","强锋科技"));
        books.add(new Book(10003,"Spring+MyBatista企业应用实战","疯狂软件"));
        mv.addObject(books);
        mv.setViewName("index");
        return mv;
    }
}

拦截器类:
MyInterceptor.java

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

import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;
import com.zpc.entity.User;

public class MyInterceptor implements HandlerInterceptor {

    private static final String[] IGNORE_URI = {"/login"};

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

        System.out.println("afterCompletion方法执行了...");
    }

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

        System.out.println("postHandle方法执行了...");
    }

    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {

        System.out.println("preHandle方法执行了...");
        boolean flag = false;
        String servletPath = request.getServletPath();
        for(String s : IGNORE_URI) {
            if(servletPath.contains(s)) {
                flag = true;
                break;
            }
        }
        if(flag == false) {
            User user  = (User) request.getSession().getAttribute("user");
            if(user == null) {
                request.setAttribute("error", "您还没有登录,请登录!");
                request.getRequestDispatcher("login").forward(request, response);
            }else {
                flag = true;
            }
        }
        return flag;
    }
}

SpringMVC配置文件(主要看 定义SpringMVC拦截器):
dispatcher-config.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:p="http://www.springframework.org/schema/p"     
       xmlns:context="http://www.springframework.org/schema/context"  
       xmlns:mvc="http://www.springframework.org/schema/mvc"    
       xsi:schemaLocation="http://www.springframework.org/schema/beans
       http://www.springframework.org/schema/beans/spring-beans-4.3.xsd   
       http://www.springframework.org/schema/aop 
       http://www.springframework.org/schema/aop/spring-aop-4.3.xsd   
       http://www.springframework.org/schema/tx 
       http://www.springframework.org/schema/tx/spring-tx-4.3.xsd  
       http://www.springframework.org/schema/mvc
       http://www.springframework.org/schema/mvc/spring-mvc-4.3.xsd 
       http://www.springframework.org/schema/context 
       http://www.springframework.org/schema/context/spring-context-4.3.xsd">     

      <!-- 启用Spring关于annotation的DI,以便在Spring-MVC中使用Spring强大的功能。激活@Required @Autowired @Resource 等标注 -->
      <context:annotation-config/>

      <!-- 1.扩充了注解驱动,可以将请求参数绑定到控制器参数
           2.自动注册了RequestMappingHandlerMapping和RequestMappingHandlerAdapter两个bean
           3.@NumberFormatannotation支持
           4.@DateTimeFormat支持
           5.@Valid支持
           6.读写XML文件的支持(JAXB)
           7.读写JSON的支持 
      -->
      <mvc:annotation-driven/>

     <!-- 定义SpringMVC拦截器 -->
      <mvc:interceptors>
        <mvc:interceptor>
        <!-- 拦截所有请求 -->
            <mvc:mapping path="/*"/>
            <bean class="com.zpc.interceptor.MyInterceptor"/>
        </mvc:interceptor>
      </mvc:interceptors>   

      <!-- 使用默认的Servlet响应静态文件。如js,css,image等 -->
      <mvc:default-servlet-handler/>

      <!-- 只管理Controller类型的bean,忽略其它类型的bean,如@Service -->     
      <context:component-scan base-package="com.zpc.controller" >    
        <context:include-filter type="annotation" expression="org.springframework.stereotype.Controller"/> 
      </context:component-scan>     

      <!-- 对模型视图名称的解析,即在模型视图名称添加前后缀 -->     
      <bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver"/>    
 </beans>  

登录页面:
login.jsp

<%@ page language="java" contentType="text/html; charset=utf-8"
    pageEncoding="utf-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>login</title>
</head>
<body>
    <form action="loginForm" method="POST">
        <font color="red">${requestScope.error}</font>
        用户名:<input type="text" name="username"/><br/>
        密&nbsp;&nbsp;&nbsp;&nbsp;码:<input type="text" name="password"/><br/>
        <input type="submit" value="登录"/>
    </form>
</body>
</html>

结果页:
index.jsp

<%@ page language="java" contentType="text/html; charset=utf-8"
    pageEncoding="utf-8"%>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>index</title>
</head>
<body>
    <h4>欢迎[${sessionScope.user.username}]访问</h4><br/>
    <table>
        <tr> 
            <th>编号</th><th>书名</th><th>作者</th>
        </tr>
        <c:forEach items="${requestScope.books}" var="book">
            <tr>
                <td>${book.bookId}</td>
                <td>${book.bookName}</td>
                <td>${book.author}</td>
            </tr>
        </c:forEach>
    </table>
</body>
</html>

当在地址栏直接输入http://localhost:8080/interceptor/login时,进入登录页

当在地址栏直接输入http://localhost:8080/interceptor/index时,进入登录页,并提示未登录,说明拦截器起作用了

当在地址栏直接输入http://localhost:8080/interceptor/loginForm时,报404错误,因为我们配置的访问方法为POST方法

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值