cookie 实现用户名和密码返显

/*
		 * 1. 获取表单数据
		 */
		// 处理中文问题
		request.setCharacterEncoding("utf-8");
		// 获取
		String username = request.getParameter("username");
		String password = request.getParameter("password");
		/*
		 * 2. 校验用户名和密码是否正确
		 */
		if(!"itcast".equalsIgnoreCase(username)) {//登录成功
			/*
			 * 附加项:把用户名保存到cookie中,发送给客户端浏览器
			 * 当再次打开login.jsp时,login.jsp中会读取request中的cookie,把它显示到用户名文本框中
			 */
			Cookie cookie = new Cookie("uname", username);//创建Cookie
			cookie.setMaxAge(60*60*24);//设置cookie命长为1天
			response.addCookie(cookie);//保存cookie
			
			/*
			 * 3. 如果成功
			 *   >  保存用户信息到session中
			 *   >  重定向到succ1.jsp
			 */
			HttpSession session = request.getSession();//获取session
			session.setAttribute("username", username);//向session域中保存用户名
			response.sendRedirect("/day11_3/session2/succ1.jsp");
		} else {//登录失败
			/*
			 * 4. 如果失败
			 *   > 保存错误信息到request域中
			 *   > 转发到login.jsp
			 */
			request.setAttribute("msg", "用户名或密码错误!");
			//请求转发的目的实际上是想把request 中的值带回客户端
			RequestDispatcher qr = request.getRequestDispatcher("/session2/login.jsp");//得到转发器
			qr.forward(request, response);//转发
		}
/*
读取名为uname的Cookie!
如果为空显示:""
如果不为空显示:Cookie的值
*/
String uname = "";
Cookie[] cs = request.getCookies();//获取请求中所有的cookie
if(cs != null) {// 如果存在cookie
	for(Cookie c : cs) {//循环遍历所有的cookie
		if("uname".equals(c.getName())) {//查找名为uname的cookie
			uname = c.getValue();//获取这个cookie的值,给uname这个变量
		}
	}
}
%>
<%
	String message = "";
	String msg = (String)request.getAttribute("msg");//获取request域中的名为msg的属性
	if(msg != null) {
		message = msg;
	}
%>

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值