springMVC中拦截器的配置

本文基于springMVC框架,以自定义拦截器为例。
SpringMVC的拦截器HandlerInterceptorAdapter对应提供了三个preHandle,postHandle,afterCompletion方法。
preHandle在业务处理器处理请求之前被调用,
postHandle在业务处理器处理请求执行完成后,生成视图之前执行,
afterCompletion在DispatcherServlet完全处理完请求后被调用,可用于清理资源等 。所以要想实现自己的权限管理逻辑,需要继承HandlerInterceptorAdapter并重写其三个方法。

  1. springmvc.xml中配置
    <!-- 拦截所有springmvc的url! -->
    <mvc:interceptors>
        <bean class="com.interceptor.SessionInterceptor"></bean> 
    </mvc:interceptors>

2 ,SessionInterceptor.java代码,我这里全部贴了。

package com.interceptor;

import java.util.HashMap;
import java.util.Map;

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

import org.springframework.web.servlet.ModelAndView;
import org.springframework.web.servlet.handler.HandlerInterceptorAdapter;

import com.entity.User;

public class SessionInterceptor extends HandlerInterceptorAdapter {

    private static final Map<Integer, User> userMap = new HashMap<Integer, User>();

    @Override
    public boolean preHandle(HttpServletRequest request,HttpServletResponse response, Object handler) throws Exception {
        //注册,不拦截
         if(request.getRequestURL().toString().endsWith("register.do")){
             return true;
         }
    //不是登录请求,判断是否已经登录   if(!request.getRequestURL().toString().endsWith("login.do")){
            User user = (User) request.getSession().getAttribute("user");
             if(user!=null){
                     Integer userId = user.getUserid();
                    User mapUser = userMap.get(userId);

                    if((request.getSession().getId() != mapUser.getSessionId())  &&  ( System.currentTimeMillis() - mapUser.getLoginTime() > 5000 ))
                    {
                        response.sendRedirect(request.getContextPath()+"/login.jsp");
                        return false;
                    }

             }else{

                 response.sendRedirect(request.getContextPath()+"/login.jsp");
                    return false;
             }

        }


        return true;

    }


    @Override
    public void postHandle(HttpServletRequest request,HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
        if(request.getRequestURL().toString().endsWith("login.do"))
        {
            User user = (User)request.getSession().getAttribute("user");
            if(null!=user){
                User user1 = new User();    
                user1.setSessionId(request.getSession().getId());
                user1.setLoginTime(System.currentTimeMillis());

                userMap.put(user.getUserid(), user1);
            }
        }

    }

}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值