最近写了个密码强度验证的函数,主要验证以下内容
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 ""; 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);
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
暂无“javascrpt密码强度校验函数详解”评论...
更新动态
2025年01月01日
2025年01月01日
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]