2022年02月04日整理发布:javascript怎么设置cookie

容堂新

让我给你解释一下javascript是如何设置cookies的。相信朋友们也应该密切关注这个话题。现在我们来谈谈javascript如何为朋友设置cookies。边肖还收集了关于javascript如何设置cookies的相关信息。我希望你看到后会喜欢。

在javascript中,您可以使用document对象的cookie属性来设置、读取或删除cookie。“文档的语法。cookie=' cookiename=值;Expires=到期时间';

本教程操作环境:windows7系统,javascript1.8.5版本1.8.5,戴尔G3电脑。

1、什么是饼干

用于将网页加载到浏览器中的HTTP是一种“无状态”协议,也就是说,当服务器将页面发送到浏览器时,它认为事情已经完成,不保存任何信息。这使得在浏览器会话期间很难保持某种连续性,例如记录用户访问或下载的内容,或者记录用户在私人区域的登录状态。

Cookie是解决这个问题的一种方法。例如,cookie可以记录用户的上次访问,保存用户首选项列表,或者在用户继续购物时将商品保存在购物车中。正确使用cookie可以改善网站的用户体验。

Cookie本身是简短的信息字符串,可以通过页面保存在用户的计算机上,然后由其他页面读取。Cookie通常设置为在一段时间后过期。

饼干的局限性

浏览器对可以保存的cookie数量有限制,通常是几百个或更多。一般每个域名允许20个cookie,每个域最多可以存储4KB的cookie。

除了大小限制可能导致的问题之外,还有很多原因可能会导致硬盘上的cookie消失,例如过期日期,或者用户已经清除了cookie信息,或者切换到另一个浏览器。因此,cookie永远不应该用来保存重要的数据,在编写代码时,我们必须考虑无法获得所需cookie的情况。

2.document.cookie属性

使用JavaScript文档对象的cookie属性来创建、读取和删除cookie。

每个cookie基本上都是一串成对的名称和值,比如下面的:

Username=sam当页面被加载到浏览器中时,浏览器将收集与页面相关的所有cookie,并将它们放入文档中。在该属性中,每个cookie用分号:分隔。

用户名=sam位置=中国;#我说document.cookie被称为“类似字符串”的属性,因为它不是真正的字符串,但是这个属性在提取cookie信息时表现得像字符串。

基于的数据编码和解码

cookie中不能使用某些字符,包括分号、逗号和空白符号(如空格和制表符)。在将数据存储到cookie中之前,需要对数据进行编码,以实现正确的存储。

在存储信息之前,使用JavaScript的escape()函数对其进行编码,同时使用对应的escape()函数对原始cookie数据进行解码。

函数的作用是:将字符串中的非ASCII字符转换为相应的2位或4位十六进制格式,如空格转换为and & amp

例如,下面的代码将输出保存在变量字符串中的原始字符串以及转义()编码后的结果:

超文本标记语言

脚本

函数hello(){ 0

var str=“这是一段(短)文本。”;

document . write(str=' br/' escape(str));

}

/script

/head

身体

div id='div1'hello owrld/br

type=' button ' name=' 111 'n click=' hello()' value='过来按我'

/div

/body

/html

可以看到空格表示为,左括号为(,右括号为)。

3、烹饪

e组成

document.cookie里的信息看上去就像是由成对的名称和值组成的字符串,每一对数据的形式是:

name=value

但实际上,每个cookie还包含其他一些相关信息,下面来分别介绍。

cookieName 和 cookieValue

cookieName和cookieValue就是在cookie字符串里看到的name=value里的名称和值。

domain

domain属性向浏览器指明cookie属于哪个域。这个属性是可选的,在没有指定时,默认值是设置cookie的页面所在的域。

这个属性的作用在于控制子域对cookie的操作。距离来说,如果设置其为www.example.com,那么子域code.example.com里的页面就不能读取这个cookie。但如果domain属性设置为example.com,那么code.example.com里的页面就能访问这个cookie了。

path

path属性指定可以使用cookie的目录。如果只想让目录documents里的页面设置cookie的值,就把path设置为/documents。这个属性是可选的,常用的默认路径是/,表示cookie可以在整个域中使用。

secure

secure属性是可选的,而且几乎很少使用。它表示浏览器在把整个cookie发送给服务器时,是否应该使用SLL安全标准。

expires

每个cookie都有一个失效日期,过期就自动删除了。expires属性要以UTC时间表示。如果没有设置这个属性,cookie的生命期就和当前浏览器会话一样长,会在浏览器关闭时自动删除。

4,编写cookie

要编写新的cookie,只要把包含所需属性的值赋予document.cookie就可以了:

document.cookie = "username=sam;expires=15/05/2018 00:00:00"

使用javascript的Date对象可以避免手工输入日期和时间格式;

var cookieDate = new Date(2018,05,15); document.cookie = "username=sam;expires="+cookieDate.toUTCString();

这样就能达到和前面一样的结果。

#注意这里使用了cookieDate.toUTCString()函数,而不是cookieDate.toString();这是因为cookie的时间要以UTC格式设置。

在实际编码时,应该用excape()函数来确保在给cookie赋值时不会有非法字符:

var cookieDate = new Date(2018,05,15); var user = "Sam Jones"; document.cookie = "username="+excape(user)+";expires="+cookieDate.toUTCString();

5,编写cookie的函数

很自然就会想到编写一个函数专门用于生成cookie,完成编码和可选属性的组合操作。下面的程序清单就列出了一个这样的程序代码:

function createCookie(name,value,days,path,domain,secure){ if(days){ var date = new Date(); date.setTime(date.getTime()+(days*24*60*60*1000)); var expires = date.toGMTString(); } else var expires = ""; cookieString = name + "=" +excape(value); if(expires) cookieString += ";expires=" +expires; if(path) cookieString += ";path=" + escape(path); if(domain) cookieString += ";domain=" + escape(domain); if(secure) cookieString += ";secure=" + escape(secure); document.cookie = sookieString; }

这个函数的执行的操作是相当直观的,name和value参数组合得到"name = value",其中的value还经过编码以避免非法字符。

在处理有效期时,使用的参数不是具体日期,而是cookie有效的天数。函数根据这个天数生成有效的日期字符串。

其他属性都是可选的,如果设置了,就会附加到组成cookie的字符串里。

【推荐学习:javascript高级教程】

以上就是javascript怎么设置cookie的详细内容,更多请关注php中文网其它相关文章!

来源:php中文网

标签:

免责声明:本文由用户上传,与本网站立场无关。财经信息仅供读者参考,并不构成投资建议。投资者据此操作,风险自担。 如有侵权请联系删除!