javaweb(2.6)cookie

  • • 发表于 8年前
  • • 作者 大妖怪
  • • 2667 人浏览
  • • 1 条评论
  • • 最后编辑时间 8年前
  • • 来自 [技 术]

原创声明:本文为作者原创,未经允许不得转载,经授权转载需注明作者和出处

还是登陆网站的例子,有很多网站的登录界面会有个记住账号密码的选项,甚至是有些浏览器比如firfox,会在我们点击登录按钮之后会弹出一个选项提示我们记住账号密码。那么这个记住的账号密码是放在什么地方呢?对,就是放在今天我们要讲的cookie里面。上章我们讲到的session其实是前端和服务器之间的一个会话,这个会话主要是保存在服务端,那么今天要讲的cookie,其实也是一个会话,是保存在客户端(浏览器上)的会话。那么同样都是会话,cookie和session有什么区别呢?

  • cookie通过在客户端记录信息确定用户身份,session通过在服务器端记录信息确定用户身份。
    今天我们主要来说说在后端操作cookie。
    由于http协议是一种无状态的协议,一旦数据交换完毕,客户端与服务器端的连接就会关闭,再次交换数据需要建立新的连接,因此服务器无法根据网络请求来判断用户的身份,因此服务端程序会将我们当前会话产生的session的id设置到cookie返回给前端,然后下一次前端请求之后服务端会读取请求中的cookie,根据里面的sessionId确定当前登录的用户。当然,我们在后端也可以通过一些方法来手动来设置一下cookie。
    简单查了下,操作Cookie大概有以下一些方法:
  • Cookie cookie = new Cookie(key,value): 声明一个Cookie(这里的Cookie指的是javax.servlet.http.Cookie类,同下)
  • HttpServletResponse.addCookie(Cookie): 将Cookie发送给客户端
  • HttpServletRequest.getCookies(): 获取客户端请求中携带的Cookie
  • getComment(): 获取注释
  • setComment(): 设置注释
  • getDomain(): 获取Cookie的适用域
  • setDomain(): 设置Cookie的适用域
  • getMaxAge(): 获取Cookie过期之前的时间
  • setMaxAge(): 设置Cookie过期之前的时间
  • getName(): 获取Cookie的名字
  • setName(): 设置Cookie的名字
  • getPath(): 获取Cookie适用的路径
  • setPath(): 设置Cookie适用的路径
  • getSecure(): 获取一个boolean值
  • setSecure(): 设置一个boolean值
  • getValue(): 获取Cookie的值
  • setValue(): 设置Cookie的值
  • getVersion(): 获取Cookie所遵从的协议版本
  • setVersion(): 设置Cookie所遵从的协议版本,默认0

下面来写一个保存用户名密码的小demo:
servlet:

public class CookieServlet extends HttpServlet {
    private static final long serialVersionUID = -271571469551304432L;

    public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        response.setContentType("text/html");

        String uname = request.getParameter("uname");
        String password = request.getParameter("password");
        String ck = request.getParameter("ck");

        // 被选中的状态是on 没有被选中的状态下是null
        if ("on".equals(ck)) {
            // 构造Cookie对象
            // 添加到Cookie中
            Cookie c = new Cookie("users", uname + "-" + password);

            // 设置过期时间
            c.setMaxAge(600);

            // 存储
            response.addCookie(c);
        }
    }
}

jsp:

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>

<%

//el表达式
String names="";
String pwd="";
//取出Cookie
Cookie [] c=request.getCookies();
for(int i=0;i<c.length;i++){
    if(c[i].getName().equals("users")){
        //存着数据(用户名+密码)
        names=c[i].getValue().split("-")[0];
        pwd=c[i].getValue().split("-")[1];

        //再一次的存起来(备用)
        request.setAttribute("xingming",names);
        request.setAttribute("mima", pwd);
    }
}

 %>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
    <base href="<%=basePath%>">

    <title>My JSP 'index.jsp' starting page</title>
    <meta http-equiv="pragma" content="no-cache">
    <meta http-equiv="cache-control" content="no-cache">
    <meta http-equiv="expires" content="0">    
    <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
    <meta http-equiv="description" content="This is my page">
    <!--
    <link rel="stylesheet" type="text/css" href="styles.css">
    -->
  </head>

  <body>
    <form action="cookie" method="post">
        用户名:<input type="text" name="uname" id="uname" value="${xingming}"/><br>
        密码:<input type="password" name="password" id="password" value="${mima }"/><br>
        <input type="checkbox" name="ck">记住用户名和密码<br>
        <input type="submit" value="登录">
    </form>
  </body>
</html>

这样写出来的一个项目,当我们点记住密码然后登陆之后,进去了一个空白页,

然而我们用同一个浏览器在去进入登陆页面时,你会发现账号密码被记住了:

源码下载地址:
http://pan.baidu.com/s/1o8z64GU
鸣谢:又偷了点懒,文中源码均由借(chao)鉴(xi)自http://www.cnblogs.com/thrilling/p/4924077.html

分享到:
1条评论
Ctrl+Enter
作者

大妖怪

大妖怪

APP:1 帖子:76 回复:200 积分:7517

已加入社区[2946]天

梦里巷口,可有你倚门回首

作者详情》
Top