最近写了个密码强度验证的函数,主要验证以下内容
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);
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
华山资源网 Design By www.eoogi.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
华山资源网 Design By www.eoogi.com
暂无评论...
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
2024年11月16日
2024年11月16日
- 林隆璇.1989-愤怒的情歌【巨石】【WAV+CUE】
- 勤琴《海上花》[DTS-WAV分轨]
- 群星《歌声有故事》[DTS-WAV分轨]
- [发烧人声]群星《邂逅》DTS-WAV
- 艻打绿《夏/狂热(苏打绿版)》[320K/MP3][106.42MB]
- 艻打绿《夏/狂热(苏打绿版)》[FLAC分轨][574.2MB]
- 黄雨勳《魔法列车首部曲》[320K/MP3][33.1MB]
- 李蕙敏.2014-记得·销魂新歌+精丫乐意唱片】【WAV+CUE】
- 谢金燕.1995-含泪跳恰蔷冠登】【WAV+CUE】
- 于文文.2024-天蝎座【华纳】【FLAC分轨】
- 黄雨勳《魔法列车首部曲》[FLAC/分轨][173.61MB]
- 群星《歌手2024 第13期》[320K/MP3][50.09MB]
- 群星《歌手2024 第13期》[FLAC/分轨][325.93MB]
- 阿木乃《爱情买卖》DTS-ES【NRG镜像】
- 江蕾《爱是这样甜》DTS-WAV