cookie使用

news/2024/5/18 15:05:00 标签: cookie

Cookie 用于存储 web 页面的用户信息。

什么是 Cookie?

Cookie 是一些数据, 存储于你电脑上的文本文件中。

当 web 服务器向浏览器发送 web 页面时,在连接关闭后,服务端不会记录用户的信息。

Cookie 的作用就是用于解决 "如何记录客户端的用户信息":

当用户访问 web 页面时,他的名字可以记录在 cookie 中。

在用户下一次访问该页面时,可以在 cookie 中读取用户访问记录。

Cookie 以名/值对形式存储,如下所示:

username=John Doe

当浏览器从服务器上请求 web 页面时, 属于该页面的 cookie 会被添加到该请求中。服务端通过这种方式来获取用户的信息。

使用 JavaScript 创建Cookie

JavaScript 可以使用 document.cookie 属性来创建 、读取、及删除 cookie

JavaScript 中,创建 cookie 如下所示:

document.cookie="username=John Doe";

您还可以为 cookie 添加一个过期时间(以 UTC 或 GMT 时间)。默认情况下,cookie 在浏览器关闭时删除:  

document.cookie="username=John Doe; expires=Thu, 18 Dec 2043 12:00:00 GMT";
//写cookies
function setCookie(cname,cvalue,exdays){
  var d = new Date();
  d.setTime(d.getTime()+(exdays*24*60*60*1000));
  var expires = "expires="+d.toGMTString();
  document.cookie = cname + "=" + cvalue + "; " + expires;
}

  您可以使用 path 参数告诉浏览器 cookie 的路径。默认情况下,cookie 属于当前页面。

document.cookie="username=John Doe; expires=Thu, 18 Dec 2043 12:00:00 GMT; path=/";

使用 JavaScript 读取 Cookie

在 JavaScript 中, 可以使用以下代码来读取 cookie

var x = document.cookie;

document.cookie 将以字符串的方式返回所有的 cookie,类型格式: cookie1=value; cookie2=value; cookie3=value;

function getCookie(cname){
  var name = cname + "=";
  var ca = document.cookie.split(';');
  for(var i=0; i<ca.length; i++) 
  {
    var c = ca[i].trim();
    if (c.indexOf(name)==0) return c.substring(name.length,c.length);
  }
  return "";
}

使用 JavaScript 修改 Cookie

在 JavaScript 中,修改 cookie 类似于创建 cookie,如下所示:

document.cookie="username=John Smith; expires=Thu, 18 Dec 2043 12:00:00 GMT; path=/";

旧的 cookie 将被覆盖。

使用 JavaScript 删除 Cookie

删除 cookie 非常简单。您只需要设置 expires 参数为以前的时间即可,如下所示,设置为 Thu, 01 Jan 1970 00:00:00 GMT:

document.cookie = "username=; expires=Thu, 01 Jan 1970 00:00:00 GMT";

注意,当您删除时不必指定 cookie 的值。

document.cookie 属性看起来像一个普通的文本字符串,其实它不是。

即使您在 document.cookie 中写入一个完整的 cookie 字符串, 当您重新读取该 cookie 信息时,cookie 信息是以名/值对的形式展示的。

如果您设置了新的 cookie,旧的 cookie 不会被覆盖。 新 cookie 将添加到 document.cookie 中,所以如果您重新读取document.cookie,您将获得如下所示的数据:

cookie1=value; cookie2=value;

操作Cookie无非是存、取、删,下面就一起简单学一下jQuery Cookie的使用。

jquery cookie常用操作:

$.cookie('the_cookie'); // 获得cookie
$.cookie('the_cookie', 'the_value'); // 设置cookie
$.cookie('the_cookie', 'the_value', { expires: 7 }); //设置带时间的cookie
$.cookie('the_cookie', '', { expires: -1 }); // 删除
$.cookie('the_cookie', null); // 删除 cookie
$.cookie('the_cookie', 'the_value', {expires: 7, path: '/', domain: 'jquery.com', secure: true});//新建一个cookie 包括有效期 路径 域名等

把它放到测试服务器上或者本地localhost服务器上才会生效。 

封装一个函数添加一个cookie

    function addCookie(name, value, expireDays) {
        var cookieString = name + "=" + value;
        if (expireDays > 0) {
            var date = new Date();
            date.setTime(date.getTime() + expireDays * 24 * 3600 * 1000);
            cookieString = cookieString + "; expires=" + date.toGMTString();
            cookieString += ";path=/";
        }
        document.cookie = cookieString;
    }

封装一个函数获取cookie值:

    function getCookie(c_name) {
        if (document.cookie.length > 0) {
            c_start = document.cookie.indexOf(c_name + "=");
            if (c_start != -1) {
                c_start = c_start + c_name.length + 1;
                c_end = document.cookie.indexOf(";", c_start);
                if (c_end == -1)
                    c_end = document.cookie.length;
                return unescape(document.cookie.substring(c_start, c_end));
            }
        }
        return "";
    }

 


http://www.niftyadmin.cn/n/887107.html

相关文章

networkx设置节点的大小_网架结构节点设计详解(值得收藏)

网架结构因其能够实现大跨度、耗钢量低、承载能力高&#xff0c;能根据建筑设汁的要求实现不同的造型等特点&#xff0c;在工程上大量应用。网架结构在我国已经应用了几十年&#xff0c;其设计水平和施工方法已相当成熟。在设计与施工中&#xff0c;应做到技术先进、安全适用、…

C语言叠堆在变量周围,C语言之程序中内存的来源:栈 堆 数据段

程序在运行的时候&#xff0c;其内存的来源主要通过三种方法&#xff1a; 栈 堆 数据段&#xff0c;总体上来讲栈是一般用来存放小内存的局部变量&#xff0c;堆内存和数据段的属性很像&#xff0c;在使用的的时候&#xff0c;如果这个变量是伴随程序一直存在则使用全局变量…

关于Ajax无法下载文件到浏览器本地的问题(文件下载的几种方式)

最近在做网站的时候遇到这样一个功能&#xff0c;在如图所示的页面中&#xff0c;需要用户点击链接的时候&#xff0c;能够以异步Ajax的方式判断服务器中是否存储有相应的Excel文件&#xff0c;如果没有的话就提示用户没有找到&#xff0c;如果有的话就下载到用户本地。 当然&a…

edittext去掉_让你的 EditText 全部清除

项目地址(欢迎 Star)&#xff1a;ClearEditText在输入文本的时候&#xff0c;通常当前输入的地方的末尾会有一个 x 来结束&#xff0c;它的作用是&#xff0c;如果我们想要清空这一整行输入的时候&#xff0c;点一下 x 就可以了。它的存在&#xff0c;还是很有必要的。然后&…

c语言statistic静态变量,c语言程序设计教程_李含光_郑关胜_清华大学出版社习题答案习题答案完美打印版.doc...

c语言程序设计教程_李含光_郑关胜_清华大学出版社习题答案习题答案完美打印版第1章习题参考答案1&#xff0e;单项选择题(1)A (2)C (3)D (4)C (5)B2&#xff0e;填空题(1)函数(2)主函数(main)printf() &#xff0c; scanf()1&#xff0e;单项选择题1-5 CBCCC 6-10 CDCDC 11-13 …

ES6 Promise用法讲解

所谓Promise&#xff0c;简单说就是一个容器&#xff0c;里面保存着某个未来才会结束的事件&#xff08;通常是一个异步操作&#xff09;的结果。 ES6 规定&#xff0c;Promise对象是一个构造函数&#xff0c;用来生成Promise实例。 下面代码创造了一个Promise实例。 const …

三角网导线平差实例_导线平差实例(一):简易平差

导线平差计算一般包括简易平差和严密平差。我们将分别以实例介绍这两种平差方法&#xff0c;以期在导线测量和内业计算形成完整的实战技能模块。在《点到点的附合导线计算实例》我们介绍了无定向导线的计算方法&#xff0c;本文将详细介绍定向导线简易平差计算。01实例数据及示…

c语言 dll库是线程安全吗,教大家写一个远程线程的DLL注入,其实还是蛮简单的……………………...

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼然后新建一个win32 application 的工程 新建c source file 写入&#xff1a;#include#includeint WINAPI WinMain(HINSTANCE hInstance,HINSTANCE hPrevInstance,LPSTR lpCmdLine,int nShowCmd){char DllName[MAX_PATH]"C:\\P…