springmvc 登录鉴权过滤器

package com.common.filter;

import java.io.IOException;

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

import org.springframework.http.HttpStatus;
import org.springframework.web.filter.OncePerRequestFilter;

import com.common.util.SessionKeyContent;

/**
 * 登录过滤器
 * <功能详细描述>
 * 
 * @author  chenlujun
 * @version  [版本号, 2014年10月11日]
 * @see  [相关类/方法]
 * @since  [产品/模块版本]
 */
public class SessionFilter extends OncePerRequestFilter
{
    
    /** 登录验证过滤器 */
    
    @Override
    protected void doFilterInternal(HttpServletRequest request, HttpServletResponse response, FilterChain filterChain)
        throws ServletException, IOException
    {
        // 不过滤的uri
        String[] notFilter =
            new String[] {"/images", "/js", "/css", "/login/tologin", "/login/mainframe", "/user/exist",
                "/user/checkPassword", "/signcode"};
        
        // 请求的uri
        String uri = request.getRequestURI();
        // 是否过滤
        boolean doFilter = true;
        for (String s : notFilter)
        {
            if (uri.indexOf(s) != -1)
            {
                // 如果uri中包含不过滤的uri,则不进行过滤
                doFilter = false;
                break;
            }
        }
        
        if (doFilter)
        {
            // 执行过滤
            // 从session中获取登录者实体
            Object obj = request.getSession().getAttribute(SessionKeyContent.SESSION_KEY_OBJ_USER_BEAN);
            if (null == obj)
            {
                boolean isAjaxRequest = isAjaxRequest(request);
                if (isAjaxRequest)
                {
                    response.setCharacterEncoding("UTF-8");
                    response.sendError(HttpStatus.UNAUTHORIZED.value(), "您已经太长时间没有操作,请刷新页面");
                    return ;
                }
                response.sendRedirect("../login/tologin");
                return;
            }
            else
            {
                // 如果session中存在登录者实体,则继续
                filterChain.doFilter(request, response);
            }
        }
        else
        {
            // 如果不执行过滤,则继续
            filterChain.doFilter(request, response);
        }
    }
    
    /** 判断是否为Ajax请求 
     * <功能详细描述>
     * @param request
     * @return 是true, 否false 
     * @see [类、类#方法、类#成员]
     */
    public static boolean isAjaxRequest(HttpServletRequest request)
    {
        String header = request.getHeader("X-Requested-With"); 
        if (header != null && "XMLHttpRequest".equals(header)) 
            return true; 
        else 
            return false;  
    }
    
}

web.xml中配置

<filter>  
        <filter-name>sessionFilter</filter-name>  
        <filter-class>com.common.filter.SessionFilter</filter-class>  
    </filter>  
    <filter-mapping>  
        <filter-name>sessionFilter</filter-name>  
        <url-pattern>/*</url-pattern>  
    </filter-mapping>  



  • 2
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值