JavaScript使用cookie实现记住账号密码功能


Posted in Javascript onApril 27, 2015

很多登录功能上都有个“记住密码”的功能,其实无非就是对cookie的读取。

下面展示这个功能的代码,原作者已无法考究。。。。

测试方法:直接输入账号密码,提交后,刷新页面,再输入同样的账号,就可以显示

<!DOCTYPE HTML>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>js COOKIE 记住帐号或密码</title>
<script type="text/javascript">
  window.onload=function onLoginLoaded() {
    if (isPostBack == "False") {
      GetLastUser();
    }
  }
   
  function GetLastUser() {
    var id = "49BAC005-7D5B-4231-8CEA-16939BEACD67";//GUID标识符
    var usr = GetCookie(id);
    if (usr != null) {
      document.getElementById('txtUserName').value = usr;
    } else {
      document.getElementById('txtUserName').value = "001";
    }
    GetPwdAndChk();
  }
  //点击登录时触发客户端事件
   
  function SetPwdAndChk() {
    //取用户名
    var usr = document.getElementById('txtUserName').value;
    alert(usr);
    //将最后一个用户信息写入到Cookie
    SetLastUser(usr);
    //如果记住密码选项被选中
    if (document.getElementById('chkRememberPwd').checked == true) {
      //取密码值
      var pwd = document.getElementById('txtPassword').value;
      alert(pwd);
      var expdate = new Date();
      expdate.setTime(expdate.getTime() + 14 * (24 * 60 * 60 * 1000));
      //将用户名和密码写入到Cookie
      SetCookie(usr, pwd, expdate);
    } else {
      //如果没有选中记住密码,则立即过期
      ResetCookie();
    }
  }
   
  function SetLastUser(usr) {
    var id = "49BAC005-7D5B-4231-8CEA-16939BEACD67";
    var expdate = new Date();
    //当前时间加上两周的时间
    expdate.setTime(expdate.getTime() + 14 * (24 * 60 * 60 * 1000));
    SetCookie(id, usr, expdate);
  }
  //用户名失去焦点时调用该方法
   
  function GetPwdAndChk() {
    var usr = document.getElementById('txtUserName').value;
    var pwd = GetCookie(usr);
    if (pwd != null) {
      document.getElementById('chkRememberPwd').checked = true;
      document.getElementById('txtPassword').value = pwd;
    } else {
      document.getElementById('chkRememberPwd').checked = false;
      document.getElementById('txtPassword').value = "";
    }
  }
  //取Cookie的值
   
  function GetCookie(name) {
    var arg = name + "=";
    var alen = arg.length;
    var clen = document.cookie.length;
    var i = 0;
    while (i < clen) {
      var j = i + alen;
      //alert(j);
      if (document.cookie.substring(i, j) == arg) return getCookieVal(j);
      i = document.cookie.indexOf(" ", i) + 1;
      if (i == 0) break;
    }
    return null;
  }
  var isPostBack = "<%= IsPostBack %>";
   
  function getCookieVal(offset) {
    var endstr = document.cookie.indexOf(";", offset);
    if (endstr == -1) endstr = document.cookie.length;
    return unescape(document.cookie.substring(offset, endstr));
  }
  //写入到Cookie
   
  function SetCookie(name, value, expires) {
    var argv = SetCookie.arguments;
    //本例中length = 3
    var argc = SetCookie.arguments.length;
    var expires = (argc > 2) ? argv[2] : null;
    var path = (argc > 3) ? argv[3] : null;
    var domain = (argc > 4) ? argv[4] : null;
    var secure = (argc > 5) ? argv[5] : false;
    document.cookie = name + "=" + escape(value) + ((expires == null) ? "" : ("; expires=" + expires.toGMTString())) + ((path == null) ? "" : ("; path=" + path)) + ((domain == null) ? "" : ("; domain=" + domain)) + ((secure == true) ? "; secure" : "");
  }
   
  function ResetCookie() {
    var usr = document.getElementById('txtUserName').value;
    var expdate = new Date();
    SetCookie(usr, null, expdate);
  }
</script>
</head>
<body>
<form id="form1">
 <div> 用户名:
  <input type="text" ID="txtUserName" onblur="GetPwdAndChk()">
  <input type="password" ID="txtPassword">
  密码:
  <input type="checkbox" ID="chkRememberPwd" />
  记住密码
  <input type="button" OnClick="SetPwdAndChk()" value="进入"/>
 </div>
</form>
</body>
</html>
Javascript 相关文章推荐
5 cool javascript apps
Mar 24 Javascript
编写兼容IE和FireFox的脚本
May 18 Javascript
javascript获得CheckBoxList选中的数量
Oct 27 Javascript
javascript同页面多次调用弹出层具体实例代码
Aug 16 Javascript
jQuery的deferred对象详解
Nov 12 Javascript
Node.js操作mysql数据库增删改查
Mar 30 Javascript
在 Angular2 中实现自定义校验指令(确认密码)的方法
Jan 23 Javascript
JS之if语句对接事件动作逻辑(详解)
Jun 28 Javascript
JS获取日期的方法实例【昨天,今天,明天,前n天,后n天的日期】
Sep 28 Javascript
JS实现简单表格排序操作示例
Oct 07 Javascript
Es6 Generator函数详细解析
Feb 24 Javascript
详解关于React-Router4.0跳转不置顶解决方案
May 10 Javascript
使用console进行性能测试
Apr 27 #Javascript
浅谈javascript实现八大排序
Apr 27 #Javascript
javascript关于open.window子页面执行完成后刷新父页面的问题分析
Apr 27 #Javascript
jQuery插件Tmpl的简单使用方法
Apr 27 #Javascript
javascript关于运动的各种问题经典总结
Apr 27 #Javascript
分享9点个人认为比较重要的javascript 编程技巧
Apr 27 #Javascript
javascript+html5实现仿flash滚动播放图片的方法
Apr 27 #Javascript
You might like
php使用Jpgraph绘制柱形图的方法
2015/06/10 PHP
5款适合PHP使用的HTML编辑器推荐
2015/07/03 PHP
Yii净化器CHtmlPurifier用法示例(过滤不良代码)
2016/07/15 PHP
php微信公众号开发(2)百度BAE搭建和数据库使用
2016/12/15 PHP
php readfile下载大文件失败的解决方法
2017/05/22 PHP
PHP超级全局变量【$GLOBALS,$_SERVER,$_REQUEST等】用法实例分析
2019/12/11 PHP
才发现的超链接js导致网页中GIF动画停止的解决方法
2007/11/02 Javascript
jquery indexOf使用方法
2013/08/19 Javascript
JS求平均值的小例子
2013/11/29 Javascript
node.js不得不说的12点内容
2014/07/14 Javascript
JavaScript制作简易的微信打飞机
2015/03/31 Javascript
浅谈Javascript数组索引
2015/07/29 Javascript
跟我学习javascript的作用域与作用域链
2015/11/19 Javascript
基于javascript实现根据身份证号码识别性别和年龄
2016/01/22 Javascript
web 前端常用组件之Layer弹出层组件
2016/09/22 Javascript
9个让JavaScript调试更简单的Console命令
2016/11/14 Javascript
微信小程序将字符串生成二维码图片的操作方法
2018/07/17 Javascript
layui实现数据表格点击搜索功能
2020/03/26 Javascript
微信小程序之 catalog 切换实现解析
2019/09/12 Javascript
vue-quill-editor 自定义工具栏和自定义图片上传路径操作
2020/08/03 Javascript
[09:33]2015国际邀请赛第四日TOP10
2015/08/08 DOTA
[04:44]DOTA2 2017全国高校联赛视频回顾
2017/08/21 DOTA
利用python程序生成word和PDF文档的方法
2017/02/14 Python
python+splinter实现12306网站刷票并自动购票流程
2018/09/25 Python
python简单贪吃蛇开发
2019/01/28 Python
python算法与数据结构之单链表的实现代码
2019/06/27 Python
Django实现跨域请求过程详解
2019/07/25 Python
python 数据提取及拆分的实现代码
2019/08/26 Python
python boto和boto3操作bucket的示例
2020/10/30 Python
中国双语服务优势的在线购票及活动平台:247tickets
2018/10/26 全球购物
CSS实现fullpage.js全屏滚动效果的示例代码
2021/03/24 HTML / CSS
送餐员岗位职责范本
2014/02/21 职场文书
活动总结怎么写
2014/04/28 职场文书
销售团队获奖感言
2014/08/14 职场文书
写给汽车4S店的创业计划书,拿来即用!
2019/08/09 职场文书
有关信念的名言语录集锦
2019/12/06 职场文书