2022年02月04日整理发布:javascript怎么设置cookie
现如今大家都会选择在网络上汲取相关知识内容,比如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中文网
广告
X 关闭
X 关闭
-
-
2022年02月04日整理发布:javascript怎么设置cookie
让我给你解释一下javascript是如何设置cookies的。相信朋友们也应该密切关注这个话题。现在我们来谈谈java
-
-
美媒评测比亚迪汉EV:我承认对中国产品有偏见|世界时讯
美媒评测比亚迪汉EV:我承认对中国产品有偏见
-
-
当前短讯!零跑家族再添新成员,分析对零跑汽车股价影响
在今年2月上旬,零跑汽车发布最新新车动态:零跑家族再添新成员,增程式车型得以上市。该增程车型也是零跑家族史当中的首款增程市新能源车型,
-
-
2023年哈尔滨群力家园社区卫生服务中心五癌免费筛查|前沿热点
一、报名指南1、报名时间:自2023年2月开始报名,名额有限,报完为止。2、咨询电话:51663755或15663840977。3、报名方式:中国居民癌症防控行