通过cookie保存并读取用户登录信息实例

通过cookie的getCookies()方法可获取所有cookie对象的集合;通过getName()方法可以获取指定的名称的cookie;通过getValue()方法获取到cookie对象的值。另外,将一个cookie对象发送到客户端,使用response对象的addCookie()方法。 
下面通过cookie保存并读取用户登录信息的例子加深一下理解。 
(1)创建index.jsp文件。在改文件中,首先获取cookie对象的集合,如果集合不为空,就通过for循环遍历cookie集合,从中找出设置的cookie(这里设置为lee),并从该cookie中提取出用户名和注册时间,再根据获取的结果显示不同的提示信息。
Java代码   收藏代码
  1. <%@ page language="java" contentType="text/html; charset=utf-8"  
  2.     pageEncoding="utf-8"%>  
  3.     <%@page import="java.net.URLDecoder" %>  
  4. <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">  
  5. <html>  
  6. <head>  
  7. <meta http-equiv="Content-Type" content="text/html; charset=utf-8">  
  8. <title>通过cookie保存并读取用户登陆信息</title>  
  9. </head>  
  10. <body>  
  11. <%  
  12. Cookie[] cookies=request.getCookies();//从request中获得cookie对象的集合  
  13. String user="";//登录用户  
  14. String date="";//注册时间  
  15. if(cookies!=null){  
  16.     for(int i=0;i<cookies.length;i++){  
  17.         if(cookies[i].getName().equals("lee")){  
  18.             user=URLDecoder.decode(cookies[i].getValue().split("#")[0]);//获取用户名  
  19.             date=cookies[i].getValue().split("#")[1];//获取注册时间  
  20.                                                                              
  21.         }  
  22.     }  
  23.                                                                      
  24. }  
  25. if("".equals(user)&&"".equals(date)){ //如果没有注册  
  26. %>  
  27. 游客你好,欢迎你初次光临!  
  28. <form action="deal.jsp"method="post">  
  29. 请输入姓名:<input name="user"type="text"value="">  
  30. <input type="submit"value="确定">  
  31. </form>  
  32. <%  
  33. }else//已经注册  
  34.     %>  
  35.     欢迎[<b><%=user %><b>]再次光临<br>  
  36.     你注册的时间是:<%=date %>  
  37. <%  
  38. }  
  39. %>  
  40. </body>  
  41. </html>  
Java代码   收藏代码
  1. <%@ page language="java" contentType="text/html; charset=utf-8"  
  2.     pageEncoding="utf-8"%>  
  3.     <%@page import="java.net.URLEncoder" %>  
  4. <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">  
  5. <html>  
  6. <head>  
  7. <meta http-equiv="Content-Type" content="text/html; charset=utf-8">  
  8. <title>写入cookie</title>  
  9. </head>  
  10. <body>  
  11. <%  
  12. request.setCharacterEncoding("utf-8");//设置请求的编译为utf-8  
  13. String user=URLEncoder.encode(request.getParameter("user"),"utf-8");//获取用户名  
  14. Cookie cookie=new Cookie("lee",user+"#"+new java.util.Date().toLocaleString());//创建并实例化cookie对象  
  15. cookie.setMaxAge(60*60*24*30);//设置cookie有效期为30天  
  16. response.addCookie(cookie);  
  17. %>  
  18. <script type="text/javascript">window.location.href=\'#\'" /script>  
  19. </body>  
  20. </html>  
技巧:在向cookie中保存的信息中如果包括中文,需要调用java.net.URLEncoder类的encode()方法保存到cookie中的信息进行编码;在读取内容时,需要应用到java.net.URLDecoder类的decode()方法进行解码。这样就可
以成功地向cookie中写入中文

转:http://840327220.iteye.com/blog/2020296
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值