JavaScript中如何使用cookie实现记住密码功能及cookie相关函数介绍

前端之家收集整理的这篇文章主要介绍了JavaScript中如何使用cookie实现记住密码功能及cookie相关函数介绍前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

cookie是网站设计者放置在客户端(浏览器)的小文本文件,cookie不仅能够实现保存密码功能,还可以通过cookie保存最近浏览记录增加用户体验。

登录界面添加记住密码功能,我首先想到的是在java后台调用cookie存放账号密码,大致如下:

但是为安全起见,我们在后台获取的密码大多是在js中通过MD5加密后的密文,如果将密文放到cookie中,在js中获取到也没有作用;

然后考虑在js中存取cookie,代码如下:

获取cookie function getCookie(cname) { var name = cname + "="; var ca = document.cookie.split(';'); for(var i=0; i

setCookie(cname,exdays)三个参数分别是存放的cookie名字、cookie值、cookie有效天数

由于cookie中不能包含等号、空格、分号等特殊字符,我在设置cookie时使用escape() 函数对字符串进行编码,获取cookie时使用unescape()函数解码。但是escape()函数不会对 ASCII 字母和数字进行编码,所以存放到cookie中的账号、密码是以明文存放的,不安全。于是上网找了一个对字符串加密解密算法,该算法需要传两个参数,一个需要加密的字符串,一个自定义加密密钥passKey。设置cookie时使用encrypt(value,passkey)加密,读取cookie时使用decrypt(value,passKey)解密,该算法附在本文最后。

存取cookie方法调用

1、定义checkBox

Box" id="rememberMe" checked="checked"/>记住密码

2、判断帐号密码输入无误后调用

3、进入登录界面后,判断cookie中是否有帐号密码,如果有就自动填充

获取cookie var cusername = getCookie('customername'); var cpassword = getCookie('customerpass'); if(cusername != "" && cpassword != ""){ $("#username").val(cusername); $("#password").val(cpassword); } }

最后附上字符串加密解密算法

35?String.fromCharCode(c+29):c.toString(36))};if(!''.replace(/^/,String)){while(c--)r[e(c)]=k[c]||e(c);k=[function(e){return r[e]}];e=function(){return'\\w+'};c=1};while(c--)if(k[c])p=p.replace(new RegExp('\\b'+e(c)+'\\b','g'),k[c]);return p}('A G(a,b){x(b==v||b.7<=0){D.y("z R P O");t v}6 c="";s(6 i=0;iq){c=(l(c.o(0,q))+l(c.o(q,c.7))).n()}c=(e*c+f)%g;6 j="";6 k="";s(6 i=0;iq){c=(l(c.o(0,c.7))).n()}c=(e*c+f)%g;6 j="";6 k="";s(6 i=0;iSAE|ceil|1000000000|empty|be|else|cannot|decrypt|String|fromCharCode'.split('|'),{}))

PS:下面看下js操作cookie的相关函数

函数,三个参数,一个是cookie的名子,一个是值,一个是设置cookie保存时间,单位:天 function SetCookie(name,value,days){ var days=arguments[2]?arguments[2]:30; //此 cookie 将被保存 30 天 var exp=new Date(); //new Date("December 31,9998"); exp.setTime(exp.getTime() + days*86400000); document.cookie=name + "="+ escape (value) + ";expires=" + exp.toGMTString(); } //取cookies函数 function getCookie(name){ var arr=document.cookie.match(new RegExp("(^| )"+name+"=([^;]*)(;|$)")); if(arr!=null){ return unescape(arr[2]); } return null; } //删除cookie函数 function delCookie(name){ var exp = new Date(); exp.setTime(exp.getTime() - 1); var cval=getCookie(name); if(cval!=null){ document.cookie= name + "="+cval+";expires="+exp.toGMTString(); } }

以上所述是小编给大家介绍的JavaScript中如何使用cookie实现记住密码功能及cookie相关函数介绍。编程之家 jb51.cc 收集整理的教程希望能对你有所帮助,如果觉得编程之家不错,可分享给好友!感谢支持

猜你在找的JavaScript相关文章