javascrpt密碼強(qiáng)度校驗(yàn)函數(shù)詳解
最近寫了個(gè)密碼強(qiáng)度驗(yàn)證的函數(shù),主要驗(yàn)證以下內(nèi)容
1、密碼最小和最大長(zhǎng)度
2、連續(xù)字符串出現(xiàn)的次數(shù)
3、字符連續(xù)出現(xiàn)的次數(shù)
4、禁止特定的字符串作為密碼
5、密碼字符串的組合強(qiáng)度要求,必須含有大小寫字母,必須含有數(shù)字,必須含有特殊字符
6、輸入密碼必須與確認(rèn)密碼一致
7、支持禁止使用用戶名作為密碼
8、是否存在連續(xù)性的字符串,是否存在逆序性的字符串
(function(window, verifyPwd){ window.verifyPwd = { /*最小長(zhǎng)度*/ minLength : 6 /*最大長(zhǎng)度*/ maxLength : 18, /*字符重復(fù)次數(shù)*/ repeatCount : 0, /*連續(xù)字符*/ seriesCount : 3, /*特定過濾字符串*/ filter : [ "qaz", "wsx", "edc", "qwe", "asd", "zxc" ], /*允許的字符串*/ arrRegex : ['[0-9]', '[a-z]', '[A-Z]', '[!@#$%^&*()_-]' ], /** * 驗(yàn)證密碼 * @param userName 用戶名 * @param pwd 密碼 * @param confirmPwd 確認(rèn)密碼 * @returns {boolean} */ verify : function(userName, pwd, confirmPwd){ userName = trim(userName); pwd = trim(pwd); if(!userName || userName.length == 0){ alert('請(qǐng)先輸入用戶名'); return false; } if(!pwd || pwd.length == 0){ alert('請(qǐng)輸入密碼'); return false; } if (pwd.length < this.minLength) { alert('密碼長(zhǎng)度至少需要' + this.minLength + '位'); return false; } if (pwd.length > this.maxLength) { alert('密碼長(zhǎng)度超過'+ this.maxLength +'位'); return false; } /*判斷輸入密碼與確認(rèn)密碼是否一致*/ if(confirmPwd && confirmPwd.length > 0){ if(pwd != confirmPwd){ alert('輸入密碼與確認(rèn)密碼不一致'); return false; } } /*判斷密碼中是否存在用戶名*/ if (pwd.indexOf(userName) >= 0) { alert('密碼中不能出現(xiàn)用戶名為' + userName); return false; } if (!eval('/' + this.arrRegex[0] + '/').test(pwd)) { alert('密碼沒有包含數(shù)字'); 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('密碼沒有包含!@#$%&*_等至少一個(gè)特殊字符'); 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; } } /*判斷是否存在重復(fù)字符串*/ if(this.isRepeate(pwd)){ alert('密碼中不能出現(xiàn)重復(fù)字符'); return false; } /*判斷是否存在連續(xù)性字符串*/ if(this.isSeries(pwd)){ alert('密碼中不能存在'+ this.seriesCount +'個(gè)以上的連續(xù)字符'); return false; } return true; }, /** * 是否存在重復(fù)字符串 * @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; }, /** * 是否存在連續(xù)性字符串 * @param pwd 密碼 * @returns {boolean} */ isSeries : function(pwd){ if(pwd && pwd.length > 0) { /*自身算起*/ var ascSeriesCount = 1; var descSeriesCount= 1; /*存在順序型的連續(xù)性的字符串*/ 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; } } /*存在逆序性的連續(xù)性的字符串*/ 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("請(qǐng)輸入用戶名"); return false; } /*若驗(yàn)證正確,進(jìn)行加密處理*/ if(this.verify(userName, pwd)){ pwd = md5(pwd); $("#"+ pwdId).val(pwd); } }); } } })(window, undefined);
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
JavaScript實(shí)現(xiàn)將UPC轉(zhuǎn)換成ISBN的方法
這篇文章主要介紹了JavaScript實(shí)現(xiàn)將UPC轉(zhuǎn)換成ISBN的方法,涉及javascript字符串操作的相關(guān)技巧,需要的朋友可以參考下2015-05-05Js類的靜態(tài)方法與實(shí)例方法區(qū)分及jQuery拓展的兩種方法
這篇文章主要介紹了Js類的靜態(tài)方法與實(shí)例方法區(qū)分及jQuery拓展的兩種方法 的相關(guān)資料,對(duì)靜態(tài)方法(Static)和實(shí)例方法(非Static)不太理解的朋友可以一起學(xué)習(xí)下2016-06-06提高團(tuán)隊(duì)代碼質(zhì)量利器ESLint及Prettier詳解
這篇文章主要為大家介紹了提高團(tuán)隊(duì)代碼質(zhì)量利器ESLint及Prettier使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-11-11js 多種變量定義(對(duì)象直接量,數(shù)組直接量和函數(shù)直接量)
js 多種變量定義(對(duì)象直接量,數(shù)組直接量和函數(shù)直接量),大家可以參考下,對(duì)于以后學(xué)習(xí)js 面向?qū)τ谂cjson操作會(huì)有幫助。2010-05-05微信小程序中實(shí)現(xiàn)自定義Navbar方法詳解
這篇文章主要介紹了微信小程序中實(shí)現(xiàn)自定義Navbar方法,Navbar由 StatusBar和TitleBar組成,只需要知道它們各自的高度,就可以很好地完成自定義,需要的朋友可以參考下2024-05-05