时间:2021-05-26
最近写了个密码强度验证的函数,主要验证以下内容
1、密码最小和最大长度
2、连续字符串出现的次数
3、字符连续出现的次数
4、禁止特定的字符串作为密码
5、密码字符串的组合强度要求,必须含有大小写字母,必须含有数字,必须含有特殊字符
6、输入密码必须与确认密码一致
7、支持禁止使用用户名作为密码
8、是否存在连续性的字符串,是否存在逆序性的字符串
(function(window, verifyPwd){ window.verifyPwd = { minLength : 6 maxLength : 18, repeatCount : 0, seriesCount : 3, filter : [ "qaz", "wsx", "edc", "qwe", "asd", "zxc" ], arrRegex : ['[0-9]', '[a-z]', '[A-Z]', '[!@#$%^&*()_-]' ], /** * 验证密码 * @param userName 用户名 * @param pwd 密码 * @param confirmPwd 确认密码 * @returns {boolean} */ verify : function(userName, pwd, confirmPwd){ userName = trim(userName); pwd = trim(pwd); if(!userName || userName.length == 0){ alert('请先输入用户名'); return false; } if(!pwd || pwd.length == 0){ alert('请输入密码'); return false; } if (pwd.length < this.minLength) { alert('密码长度至少需要' + this.minLength + '位'); return false; } if (pwd.length > this.maxLength) { alert('密码长度超过'+ this.maxLength +'位'); return false; } if(confirmPwd && confirmPwd.length > 0){ if(pwd != confirmPwd){ alert('输入密码与确认密码不一致'); return false; } } if (pwd.indexOf(userName) >= 0) { alert('密码中不能出现用户名为' + userName); return false; } if (!eval('/' + this.arrRegex[0] + '/').test(pwd)) { alert('密码没有包含数字'); return false; } if (!eval('/' + this.arrRegex[1] + '/').test(pwd)) { alert('密码没有包含小写字母'); return false; } if (!eval('/' + this.arrRegex[2] + '/').test(pwd)) { alert('密码没有包含大写字母'); return false; } if (!eval('/' + this.arrRegex[3] + '/').test(pwd)) { alert('密码没有包含!@#$%&*_等至少一个特殊字符'); return false; } if(this.filter.length > 0){ for(var i = 0, length = this.filter.length; i < length; i++){ var value = this.filter[i]; if(pwd.indexOf(value) < 0){ continue; } alert("密码中不允许含有"+ value); return false; } } if(this.isRepeate(pwd)){ alert('密码中不能出现重复字符'); return false; } if(this.isSeries(pwd)){ alert('密码中不能存在'+ this.seriesCount +'个以上的连续字符'); return false; } return true; }, /** * 是否存在重复字符串 * @param pwd 密码 * @returns {boolean} */ isRepeate : function(pwd){ if(pwd && pwd.length > 0){ for(var i = 0, length = pwd.length; i < length; i++){ var currentChar = pwd.charAt(i); var prevChar = i == 0 ? "" : pwd.charAt(i - 1); if(currentChar == prevChar){ return true; } } } return false; }, /** * 是否存在连续性字符串 * @param pwd 密码 * @returns {boolean} */ isSeries : function(pwd){ if(pwd && pwd.length > 0) { var ascSeriesCount = 1; var descSeriesCount= 1; for (var i = 0, length = pwd.length; i < length; i++) { var currentCharCode = pwd.charCodeAt(i); var prevCharCode = i == 0 ? "" : pwd.charCodeAt(i - 1); if(currentCharCode == prevCharCode + 1){ ascSeriesCount++; if(ascSeriesCount == this.seriesCount){ return true; } } else{ ascSeriesCount = 1; } } for (var i = pwd.length - 1; i >= 0; i--) { var currentCharCode = pwd.charCodeAt(i); var prevCharCode = (i - 1) >= 0 ? pwd.charCodeAt(i - 1) : ""; if(currentCharCode + 1 == prevCharCode){ descSeriesCount++; if(descSeriesCount == this.seriesCount){ return true; } } else{ descSeriesCount = 1; } } } return false; }, /** * 初始化方法 * @param userNameId 用户id * @param pwdId */ init : function(userNameId, pwdId){ $("#"+ pwdId).on("blur", function(){ var userName = $("#"+ userNameId).val(); var pwd = this.value; if(userName.length == 0){ $("#"+ userNameId).focus(); alert("请输入用户名"); return false; } if(this.verify(userName, pwd)){ pwd = md5(pwd); $("#"+ pwdId).val(pwd); } }); } }})(window, undefined);以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
主要介绍使用jQuery实现带有校验密码强度的注册页面,当然要想生成一个漂亮的带有密码强度检验的注册页面要有相关插件和类库配合,具体内容如下:相关的插件和类库c
先看效果图:javascript密码强度校验代码,具体实现思路不多说了,请看下面代码和demo。第一种方法:/**密码安全程度*return:全部为字母或者数字
验证“密码强度”的例子很常见,我们注册新的账号的时候往往设置密码,此时就遇到验证密码强度的问题了。“密码强度”也就是密码难易程度的意思。原理:1、如果输入的密码
本文实例讲述了jquery密码强度校验的验证代码,分享给大家供大家参考。具体如下:预想的效果截图如下:关键代码://下面的正则表达式建议各位收藏哦,项目上有可能
效果如下:输入密码:密码强度:弱中强代码如下:复制代码代码如下:无标题页复制代码代码如下:输入密码:密码强度:弱中强