Cookie的基础

什么是Cookie?

Cookie:中文名称为“小甜品”,是web服务器保存在客户端的一系列文本信息。

典型应用一:判断注册用户是否已经登陆网站。

典型应用二:“购物车”的处理

Cookie的作用

  • 对特定对象的追踪
  • 保存用户网页浏览记录与习惯
  • 简化登陆

安全风险:容易泄露用户信息

Jsp中创建于使用Cookie

创建Cookie对象:

Cookie newCookie =new Cookie(String key,Object value);

写入Cookie对象:

response.addCookie(newCookie);

读取Cookie对象:

Cookie [] cookies=request.getCookies();

常用方法:

Cookie的基础_第1张图片

示例代码:
简单的登陆示例代码:

<h1>用户登录h1>
    <hr>
    <% 
      request.setCharacterEncoding("utf-8");
      String username="";
      String password = "";
      Cookie[] cookies = request.getCookies();
      if(cookies!=null&&cookies.length>0)
      {
           for(Cookie c:cookies)
           {
              if(c.getName().equals("username"))
              {
                   username =  URLDecoder.decode(c.getValue(),"utf-8");
              }
              if(c.getName().equals("password"))
              {
                   password =  URLDecoder.decode(c.getValue(),"utf-8");
              }
           }
      }
    %>
    <form name="loginForm" action="dologin.jsp" method="post">
       <table>
         <tr>
           <td>用户名:td>
           <td><input type="text" name="username" value="<%=username %>"/>td>
         tr>
         <tr>
           <td>密码:td>
           <td><input type="password" name="password" value="<%=password %>" />td>
         tr>
         <tr>
           <td colspan="2"><input type="checkbox" name="isUseCookie" checked="checked"/>十天内记住我的登录状态td>
         tr>
         <tr>
           <td colspan="2" align="center"><input type="submit" value="登录"/><input type="reset" value="取消"/>td>
         tr>
       table>
    form>

dologin部分代码:

       request.setCharacterEncoding("utf-8");
       //首先判断用户是否选择了记住登录状态
       String[] isUseCookies = request.getParameterValues("isUseCookie");
       if(isUseCookies!=null&&isUseCookies.length>0)
       {
          //把用户名和密码保存在Cookie对象里面
          String username = URLEncoder.encode(request.getParameter("username"),"utf-8");
          //使用URLEncoder解决无法在Cookie当中保存中文字符串问题
          String password = URLEncoder.encode(request.getParameter("password"),"utf-8");

          Cookie usernameCookie = new Cookie("username",username);
          Cookie passwordCookie = new Cookie("password",password);
          usernameCookie.setMaxAge(864000);
          passwordCookie.setMaxAge(864000);//设置最大生存期限为10天
          response.addCookie(usernameCookie);
          response.addCookie(passwordCookie);
       }
       else
       {
          Cookie[] cookies = request.getCookies();
          if(cookies!=null&&cookies.length>0)
          {
             for(Cookie c:cookies)
             {
                if(c.getName().equals("username")||c.getName().equals("password"))
                {
                    c.setMaxAge(0); //设置Cookie失效
                    response.addCookie(c); //重新保存。
                }
             }
          }
       }
    %>
    "users.jsp" target="_blank">查看用户信息

成功登陆之后的界面:

 <h1>用户信息h1>
    <hr>
    <% 
      request.setCharacterEncoding("utf-8");
      String username="";
      String password = "";
      Cookie[] cookies = request.getCookies();
      if(cookies!=null&&cookies.length>0)
      {
           for(Cookie c:cookies)
           {
              if(c.getName().equals("username"))
              {
                   username = URLDecoder.decode(c.getValue(),"utf-8");
              }
              if(c.getName().equals("password"))
              {
                   password = URLDecoder.decode(c.getValue(),"utf-8");
              }
           }
      }
    %>
    <BR>
    <BR>
    <BR>
         用户名:<%=username %><br>
         密码:<%=password %><br>

Cookie与Session之间的对比:

Cookie的基础_第2张图片

你可能感兴趣的:(Java-Web)