浏览器的cookie信息的创建 /读取/删除-登录案例演示
什么是 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";
您可以使用 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;
使用 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 的值。
创建 、读取、及删除 cookie的函数封装
function setCookie(key,val,options){
options = options || {};
var path = "";
if(options.path){
path = ";path=" + options.path;
}
var expires = "";
if(options.expires){
var d = new Date();
d.setDate(d.getDate()+options.expires);
expires = ";expires=" + d;
}
document.cookie = key + "="+ val + path + expires;
}
function removeCookie(key,options){
options = options || {};
options.expires = -1;
setCookie(key,132,options);
}
function getCookie(key){
var arr = document.cookie.split("; ");
for(var i=0;i<arr.length;i++){
if(arr[i].split("=")[0] === key){
return arr[i].split("=")[1];
}
}
return "";
}
案例演示
<body>
用户名:<input type="text" id="user"><br>
密码:<input type="text" id="pass"><br>
<input type="checkbox" id="onoff">记住帐号密码
<input type="button" value="登录" id="btn">
</body>
<script src="../cookie.js"></script>
<script>
class Login{
constructor(){
this.user = document.getElementById("user")
this.pass = document.getElementById("pass")
this.onoff = document.getElementById("onoff")
this.btn = document.getElementById("btn")
// 1.绑定事件
this.init();
// 0.读取cookie,并渲染初始数据
this.getCookie();
}
init(){
var that = this;
this.btn.onclick = function(){
// 保存数据
that.u = that.user.value;
that.p = that.pass.value;
// 2.判断是否存储
that.isStorage()
}
}
isStorage(){
// console.log(this.onoff.checked)
if(this.onoff.checked){
// 3.存储cookie
this.setCookie()
}
}
setCookie(){
// 存之前将格式设置成对象
var obj = {
user:this.u,
pass:this.p
};
// 4.存时,把对象转成json字符
setCookie("login",JSON.stringify(obj),{
expires:3
})
}
getCookie(){
// 如果没有读到数据,拿到空字符,json.parse会报错,处理默认值
var str = getCookie("login") ? getCookie("login") : '{}';
this.l = JSON.parse(str);
// 设置时如果对象中没有数据,处理默认值
this.user.value = this.l.user || "";
this.pass.value = this.l.pass || "";
}
}
new Login();
</script>
本文来自博客园,作者:JackieDYH,转载请注明原文链接:https://www.cnblogs.com/JackieDYH/p/17634718.html