记住用户名-Cookie应用实例

来源:互联网 发布:unity3d 导弹跟随 编辑:程序博客网 时间:2024/05/01 01:45

1.简单流程图

在网站登录中经常会有记住用户名这一操作,利用Cookie便可以实现,其间单的流程如下



2.利用代码实现

新建一个Login的Servelet,写入下面代码
[java] view plain copy
 在CODE上查看代码片派生到我的代码片
  1. public void doGet(HttpServletRequest request, HttpServletResponse response)  
  2.             throws ServletException, IOException {  
  3.         response.setContentType("text/html;charset=UTF-8");  
  4.         PrintWriter out = response.getWriter();  
  5.         String userName ="";  
  6.         String checked = "";  
  7.         //得到客户端保存的Cookie数据  
  8.         Cookie[] cookies = request.getCookies();  
  9.         for (int i = 0;cookies!=null && i < cookies.length; i++) {  
  10.             if("userName".equals(cookies[i].getName())){  
  11.                 userName = cookies[i].getValue();  
  12.                 checked = "checked='checked'";  
  13.             }  
  14.         }  
  15.           
  16.         out.write("<form action='"+request.getContextPath()+"/servlet/DoLogin' method='post'>");  
  17.         out.write("用户名:<input type='text' name='userName' value='"+userName+"'/><br/>");  
  18.         out.write("密码:<input type='password' name='pwd'/><br/>");  
  19.         out.write("<input type='checkbox' name='remember' "+checked+" />记住用户名<br/>");  
  20.         out.write("<input type='submit' value='登录'/><br/>");  
  21.         out.write("</form>");  
  22.     }  

再新建一个DoLogin方法
[java] view plain copy
 在CODE上查看代码片派生到我的代码片
  1. public void doGet(HttpServletRequest request, HttpServletResponse response)  
  2.             throws ServletException, IOException {  
  3.         request.setCharacterEncoding("UTF-8");  
  4.         response.setContentType("text/html;charset=UTF-8");  
  5.         PrintWriter out = response.getWriter();  
  6.         //获取表单数据  
  7.         String userName = request.getParameter("userName");  
  8.         String pwd = request.getParameter("pwd");  
  9.         String remember = request.getParameter("remember");  
  10.           
  11.         Cookie ck = new Cookie("userName", userName);  
  12.         ck.setPath("/");  
  13.         //处理业务逻辑  
  14.         //分发转向  
  15.         if("tom".equals(userName)&&"123".equals(pwd)){  
  16.             if(remember!=null){  
  17.                 ck.setMaxAge(Integer.MAX_VALUE);//设置Cookie的有效保存时间  
  18.             }else{  
  19.                 ck.setMaxAge(0);//删除 Cookie  
  20.             }  
  21.             response.addCookie(ck);//将Cookie写回到客户端  
  22.             out.write("登录成功!");  
  23.         }else{  
  24.             out.write("登录失败!");  
  25.             //设置2秒跳到重新登录  
  26.             response.setHeader("refresh""2;url="+request.getContextPath()+"/servlet/Login");  
  27.         }  
  28.           


得到的结果为:


登录后显示成功登录

再次访问时,“用户名”和“登录用户名”均自动填充


3.总结

以上便是利用Cookie的知识来实现的一个网站经常拥有的功能,如果有错误,请提出,谢谢。

0 0
原创粉丝点击