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 相关文章推荐
共享自己写一个框架DreamScript
Jan 20 Javascript
ASP 过滤数组重复数据函数(加强版)
May 31 Javascript
你需要知道的10个最佳javascript开发实践小结
Apr 15 Javascript
javascript自定义startWith()和endWith()的两种方法
Nov 11 Javascript
Javascript的闭包详解
Dec 26 Javascript
AngularJs基本特性解析(一)
Jul 21 Javascript
Vue.js路由组件vue-router使用方法详解
Dec 02 Javascript
JavaScript中最常用的10种代码简写技巧总结
Jun 28 Javascript
实现图片首尾平滑轮播(JS原生方法—节流)
Oct 17 Javascript
Angular5中调用第三方js插件的方法
Feb 26 Javascript
JavaScript实现表单注册、表单验证、运算符功能
Oct 15 Javascript
vue.js多页面开发环境搭建过程
Apr 24 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
如何利用http协议发布博客园博文评论
2015/08/03 PHP
php使用正则表达式获取字符串中的URL
2016/12/29 PHP
PHP 传输会话curl函数的实例详解
2017/09/12 PHP
PHP设计模式之单例模式原理与实现方法分析
2018/04/25 PHP
postman的安装与使用方法(模拟Get和Post请求)
2018/08/06 PHP
PHP call_user_func和call_user_func_array函数的简单理解与应用分析
2019/11/25 PHP
最新的10款jQuery内容滑块插件分享
2011/09/18 Javascript
JavaScript回调(callback)函数概念自我理解及示例
2013/07/04 Javascript
详解AngularJS过滤器的使用
2016/03/11 Javascript
jQuery如何解决IE输入框不能输入的问题
2016/10/08 Javascript
JS实现页面跳转参数不丢失的方法
2016/11/28 Javascript
一个Js文件函数中调用另一个Js文件函数的方法演示
2017/08/14 Javascript
JavaScript类的继承方法小结【组合继承分析】
2018/07/11 Javascript
jQuery实现菜单的显示和隐藏功能示例
2018/07/24 jQuery
JS实现用特殊符号替换字符串的中间部分区域的实例代码
2018/07/24 Javascript
详解写好JS条件语句的5条守则
2019/02/28 Javascript
零基础学Python(一)Python环境安装
2014/08/20 Python
Python使用正则匹配实现抓图代码分享
2015/04/02 Python
python3实现ftp服务功能(服务端 For Linux)
2017/03/24 Python
获取Pytorch中间某一层权重或者特征的例子
2019/08/17 Python
python topk()函数求最大和最小值实例
2020/04/02 Python
用纯CSS3实现网页中常见的小箭头
2017/10/16 HTML / CSS
Lacoste美国官网:经典POLO衫品牌
2016/10/12 全球购物
Origins加拿大官网:雅诗兰黛集团高端植物护肤品牌
2017/11/19 全球购物
瑞典廉价机票预订网站:Seat24
2018/06/19 全球购物
婴儿鞋,独特的婴儿服装和配件:Zutano
2018/11/03 全球购物
美国摩托车头盔、零件、齿轮及配件商店:Cycle Gear
2019/06/12 全球购物
简述使用ftp进行文件传输时的两种登录方式?它们的区别是什么?常用的ftp文件传输命令是什么?
2016/11/20 面试题
商务英语毕业生自荐信范文
2013/11/08 职场文书
校长先进事迹材料
2014/02/01 职场文书
2014超市收银员工作总结
2014/11/13 职场文书
2014年个人工作总结报告
2014/11/27 职场文书
2014五年级班主任工作总结
2014/12/05 职场文书
2015年节能降耗工作总结
2015/05/22 职场文书
golang json数组拼接的实例
2021/04/28 Golang
在项目中使用redis做缓存的一些思路
2021/09/14 Redis