session 存储登录信息,超5次等待1分钟

简单说明:

用户登录缓存到session,用户登录错误次数超过5次,等待1分钟

import java.util.Date;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;


import com.ly.cloud.soc.entity.login.UserLoginInfo;


/**
 * @author krs
 * @date 创建时间2017年10月20日 上午11:33:25 
 * @describe 处理用户登录的信息
 */
public class SessionUtils {
	
	private static final String SESSION_USER_LOGIN = "session_user_login_";


	private static int LIMIT_TIME = 1*60*1000; //登录错误的限制
	/**
	 * 
	 *@describe 往session添加用户登录的错误信息
	 *@param request
	 *@param response
	 *@param username
	 */
	public static void addUserError(HttpServletRequest request, HttpServletResponse response, String username) {
		HttpSession session = request.getSession();
		String key = SESSION_USER_LOGIN + username;
		UserLoginInfo uli = (UserLoginInfo) session.getAttribute(key);
		if(uli != null){
			//第5次就不添加
			if(uli.getCount() < 6){
				uli.setCount(uli.getCount()+1);
				uli.setLoginTime(new Date());		
			}		
		}else{
			uli = new UserLoginInfo();
			uli.setCount(1);
			uli.setUsername(username);
			uli.setLoginTime(new Date());		
		}
		//更新sesion里面的值		
		session.setAttribute(key, uli);
	}


	/**
	 * 
	 *@describe 验证用户用户是否登录失败超5次。时间过5分钟允许登录
	 *@param request
	 *@param response
	 *@param yhzh
	 *@return
	 */
	public static boolean checkUserLogin(HttpServletRequest request, HttpServletResponse response, String username) {
		boolean flag = false;
		HttpSession session = request.getSession();
		String key = SESSION_USER_LOGIN + username;
		UserLoginInfo uli = (UserLoginInfo) session.getAttribute(key);
		if(uli != null){
			Date loginTime =  uli.getLoginTime();	
			if(uli.getCount() >= 5 ){
			//小于5分钟	
			boolean time =  (System.currentTimeMillis()-loginTime.getTime()) <= LIMIT_TIME;
				if(time){
					flag = true;			
				}else{
					//超过5分钟,清空session
					session.setAttribute(key, null);
				}							
			}
				
		}
		return flag;
	}

}

import java.util.Date;
/**
 * @author krs
 * @date 创建时间2017年10月20日 上午11:50:45 
 * @describe 用户登录信息
 */
public class UserLoginInfo {
	//用户登录账号
	private String username;

	//用户最后登录时间
	private Date loginTime;
	
	//用户登录错误的次数
	private int count;

	public String getUsername() {
		return username;
	}

	public void setUsername(String username) {
		this.username = username;
	}

	public Date getLoginTime() {
		return loginTime;
	}

	public void setLoginTime(Date loginTime) {
		this.loginTime = loginTime;
	}

	public int getCount() {
		return count;
	}

	public void setCount(int count) {
		this.count = count;
	}
			
}


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值