过滤器Filter实现自动登录 cookie.setPath没有设置 /,引发客户端访问时候没带指定cookie的问题。

1、客户端访问的时候,有时候没带指定的cookie。
这个是网上找到的path取值规则:
当cookie的path设置了值不为null的时候,以设置的值为准。
当cookie的path为null时候,获取请求的URI的path值
当URI的path值是以“/”结尾的时候,直接设置为cookie的path值
当URI的path值不是以“/”结尾的时候,查看path里面是否有“/”
如果有“/”的话,直接截取到最后一个“/”,然后设置为cookie的path值。
如果没有“/”的话,将cookie的path设置为”/”。

在本例中,因为是在请求servlet/loginServlet的时候,在LoginServlet这个servlet中设置的Cookie cookie = new Cookie(“autologin”, username+"|"+password);,如果cookie没有设置cookie.setPath("/");则只有当请求servlet/loginServlet的时候才会带上autologin这个cookie。

2、客户端关闭后,session数据取不到。
这个是因为,当服务端执行request.getSession()的时候,会向客户端写入一个名称为JSESSIONID的Cookie,但是这个JSESSIONID没有设置有效时间maxAge,所以默认有效期是浏览器内存。当浏览器关闭在重新打开的时候,原来的JSESSIONID已经不见了,当服务端再次执行reqeust.getSession的时候,会向客户端写入一个新的JSESSIONID;

测试cookie不设置setPath()

Cookie cookie = new Cookie(“autologin”, username+"|"+password);
cookie.setMaxAge(60*3);
response.addCookie(cookie);
测试场景:首先访问login.jsp,勾选“自动登录”执行登录操作,这样会访问/servlet/loginServlet,设置autologin这个cookie。
关闭浏览器,观察各个访问路径是否携带autologin这个cookie。

1、http://localhost:8999/index.jsp 没有携带autologin

2:http://localhost:8999/login.jsp 没有携带autologin

3:http://localhost:8999/servlet/loginServlet 携带autologin

测试设置path为 / 的情况:

1、http://localhost:8999/index.jsp 携带autologin

Cookie cookie = new Cookie(“autologin”, username+"|"+password);
cookie.setMaxAge(603);
/

  • 如果不设置Path,则只有请求LoginServlet的时候才会带上autologin这个cookie
  • 即请求 servlet/loginServlet
    */
    cookie.setPath("/");
    response.addCookie(cookie);
    测试场景:首先访问login.jsp,勾选“自动登录”执行登录操作,这样会访问/servlet/loginServlet,设置autologin这个cookie。
    关闭浏览器,观察各个访问路径是否携带autologin这个cookie。

2:http://localhost:8999/login.jsp 携带autologin

3:http://localhost:8999/servlet/loginServlet 携带autologin

最后附上代码:
login.jsp

<form action="servlet/loginServlet" method="post">
	   用户名:<input type="text" name="username" value="${param.username}"><br>
		 密码:<input type="password" name="password" value="${param.password }"><br>
	 自动登录:<input type="checkbox" name="autologin" ><br>
	 
	 <input type="submit" value="提交">
</form>

index.jsp

<body>
	欢迎${sessionScope.user.username }登陆!!!!!
</body>
LoginServlet:


@Override
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
	
	request.setCharacterEncoding("UTF-8");
	response.setContentType("text/html;charset=UTF-8");
	
	String username = request.getParameter("username");
	String password = request.getParameter("password");
	String autologin = request.getParameter("autologin");
	
	System.out.println(autologin);
	
	User user = null;
	if("zhangsan".equals(username) && "12345".equals(password)){
		user = new User();
		user.setUsername(username);
		user.setPassword(password);
	}
	
	
	if(user!=null){
		HttpSession session = request.getSession();
		session.setAttribute("user", user);
		//设置 JSESSIONID 的有效期,否则关闭浏览器后JSESSIONID就失效了
		Cookie jsessionidCookie = new Cookie("JSESSIONID", session.getId());
		jsessionidCookie.setMaxAge(60*2);//2分钟有效
		jsessionidCookie.setPath("/");
		response.addCookie(jsessionidCookie);
		if("on".equals(autologin)){
			Cookie cookie = new Cookie("autologin", username+"|"+password);
			cookie.setMaxAge(60*3);
			/*
			 * 如果不设置Path,则只有请求LoginServlet的时候才会带上autologin这个cookie
			 * 即请求 servlet/loginServlet
			 */
			cookie.setPath("/");
			response.addCookie(cookie);
		}else{
			Cookie cookie = new Cookie("autologin",null);
			cookie.setMaxAge(0);
			response.addCookie(cookie);
		}
		
		response.sendRedirect("/index.jsp");
		
	}else{
		request.getRequestDispatcher("/login.jsp").forward(request, response);
	}
}

过滤器AutoLoginFilter:

@Override
	public void doFilter(ServletRequest req, ServletResponse resp, FilterChain chain)
			throws IOException, ServletException {
	
	HttpServletRequest request = null;
	HttpServletResponse response = null;
	
	try {
		request = (HttpServletRequest)req;
		response = (HttpServletResponse)resp;
	} catch (Exception e) {
		throw new RuntimeException("no http reqeust or response");
	}
	
	HttpSession session = request.getSession();
	User user = (User) session.getAttribute("user");
	//设置 JSESSIONID 的有效期
	Cookie jsessionidCookie = new Cookie("JSESSIONID", session.getId());
	jsessionidCookie.setMaxAge(60*2);//2分钟有效
	jsessionidCookie.setPath("/");
	response.addCookie(jsessionidCookie);
	if(user!=null){
		
		session.setAttribute("user", user);
		chain.doFilter(request, response);
	}else{
		Cookie[] cookies = request.getCookies();
		Cookie cookie = CookieUtils.findCookieByName(cookies, "autologin");
		if(cookie!=null){
			
			String path = cookie.getPath();
			System.out.println("autologin的path为:"+path);
			
			String value = cookie.getValue();
			//对于特殊的分割符号,要加 \\ 进行转译
			String[] split = value.split("\\|");
			String username = split[0];
			String password = split[1];
			
			User cookieuser = null;
			if("zhangsan".equals(username) && "12345".equals(password)){
				cookieuser = new User();
				cookieuser.setUsername(username);
				cookieuser.setPassword(password);
			}
			
			if(cookieuser!=null){
				session.setAttribute("user", cookieuser);
			}
			
			chain.doFilter(request, response);
		}else{
			chain.doFilter(request, response);
		}
	}
}

————————————————
版权声明:本文为CSDN博主「91奔跑的蜗牛」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/xldmx/article/details/102910821

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值