美文网首页
cookie记录用户名

cookie记录用户名

作者: win_wlq | 来源:发表于2017-01-03 16:22 被阅读0次

在说如何用cookie记录用户名之前,我们先来说说cookie的工作原理:

cookie : 存储数据,当用户访问了某个网站(网页)的时候,我们就可以通过cookie来像访问者电脑上存储数据 ;
1.不同的浏览器存放的cookie位置不一样,也是不能通用的 ;
2.cookie的存储是以域名形式进行区分的 ;
3.cookie的数据可以设置名字的;
4.一个域名下存放的cookie的个数是有限制的,不同的浏览器存放的个数不一样 ;
5.每个cookie存放的内容大小也是有限制的,不同的浏览器存放大小不一样 ;
6.我们通过document.cookie来获取当前网站下的cookie的时候,得到的字符串形式的值,他包含了当前网站下所有的cookie。他会把所有的cookie通过一个分号+空格的形式串联起来;
7.如果我们想长时间存放一个cookie。需要在设置这个cookie的时候同时给他设置一个过期的时间 ;
8.cookie默认是临时存储的,当浏览器关闭进程的时候自动销毁;

cookie的存储方式:

document.cookie = '名字=值';
document.cookie = 'username=win';
document.cookie = 'age=23';
document.cookie = '名称=值;expires=' + 字符串格式的时间;(给cookie设置过期时间)
var oDate = new Date(); (给cookie设置过期时间)
oDate.setDate( oDate.getDate() + 5 );(给cookie设置过期时间)
alert(typeof oDate.toGMTString()); (把日期对象转成字符串的形式)
document.cookie = 'username=win;expires=' + oDate.toGMTString();(给cookie设置成转换后的过期时间)
 > ######封装一个 读取Cookie方法的函数:
 function getCookie(key) {   
   var arr1 = document.cookie.split('; ');  (username=win; age=23,把数据从分号开始拆成一个个cookie)
   for (var i=0; i<arr1.length; i++) {   (循环cookie)   
   var arr2 = arr1[i].split('=');     (username=win,,把数据从等号开始拆分) 
   if ( arr2[0] == key ) {         (判断截取的cookie值是否和key值相等)
   return decodeURI(arr2[1]);      
       }  
    }
 }
封装一个 设置Cookie的函数:
function setCookie(key, value, t) {   
 var oDate = new Date();   
 oDate.setDate( oDate.getDate() + t );   
 document.cookie = key + '=' + value + ';expires=' + oDate.toGMTString();
}
封装一个删除Cookie的函数:
 function removeCookie(key) {   
  setCookie(key, '', -1);
}
传参运行测试:
setCookie('sex','男', 10););
removeCookie('username');
removeCookie('age');
removeCookie('sex');  
完整示例:
 <script>
  window.onload = function() {      
  var oUsername = document.getElementById('username');   
  var oLogin = document.getElementById('login');   
  var oDel = document.getElementById('del');      
  if ( getCookie('username') ) {      
     oUsername.value = getCookie('username');   
  }      
 oLogin.onclick = function() {           
   alert('登陆成功');      
   setCookie('username', oUsername.value, 5);         
}     
   oDel.onclick = function() {      
   removeCookie('username');      
   oUsername.value = '';   
   }   
}
function getCookie(key) {   
   var arr1 = document.cookie.split('; ');  (username=win; age=23,把数据从分号开始拆成一个个cookie)
   for (var i=0; i<arr1.length; i++) {   (循环cookie)   
   var arr2 = arr1[i].split('=');     (username=win,,把数据从等号开始拆分) 
   if ( arr2[0] == key ) {         (判断截取的cookie值是否和key值相等)
   return decodeURI(arr2[1]);      
       }  
    }
 }
function setCookie(key, value, t) {   
 var oDate = new Date();   
 oDate.setDate( oDate.getDate() + t );   
 document.cookie = key + '=' + value + ';expires=' + oDate.toGMTString();
}
function removeCookie(key) {  
   setCookie(key, '', -1);
}
</script>
<body>   
  <input type="text" id="username" />    
  <input type="button" value="登陆" id="login" />    
 <input type="button" value="删除" id="del" />
</body>    

分享技术,分享快乐!

相关文章

  • cookie记录用户名

    在说如何用cookie记录用户名之前,我们先来说说cookie的工作原理: cookie : 存储数据,当用户访问...

  • 2018-04-17session与cookie的区别

    cookie,session,token 区别 cookie:在客户端存储用户的一些数据,比如用户名,浏览记录等 ...

  • Cookie的使用方法

    一、cookie的作用 在我们平常写的B/S程序中,会经常用到cookie,主要有以下一些作用: 1、记录用户名和...

  • 本地存储LocalStorage

    cookie : 和服务端打交道的都用cookie(用户名密码等) 4kb

  • CAS单点登录原理解析

    1、基于Cookie的单点登录的回顾 基于Cookie的单点登录核心原理: 将用户名密码加密之后存于Cookie中...

  • CAS单点登录原理

    基于Cookie的单点登录的回顾 基于Cookie的单点登录核心原理:将用户名密码加密之后存于Cookie中,之后...

  • Cookie、LocalStorage、SessionStora

    1. 使用场景 Cookie:记住用户名密码、欢迎语LocalStrong:记录后只要不手动清除就会一直存在Ses...

  • JS的cookie

    cookie cookie是什么?用来保存用户信息 自动登录、记住用户名 cookie的特性 1.同一个网站所有页...

  • Django--状态保持

    cookie --记住用户名案例。 1、设置cookie cookie是由服务器生成,存储在浏览器端的一小段文本信...

  • CAS单点登录原理解析(转载)

    1、基于Cookie的单点登录的回顾 基于Cookie的单点登录核心原理: 将用户名密码加密之后存于Cook...

网友评论

      本文标题:cookie记录用户名

      本文链接:https://www.haomeiwen.com/subject/cjqnvttx.html