您好,登錄后才能下訂單哦!
小編給大家分享一下JavaScript實現(xiàn)密碼強度實時驗證的方法,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!
在網(wǎng)絡(luò)服務(wù)中,為了保證用戶的私密信息足夠安全,會要求用戶輸入具有一定安全級別的密碼,這樣可以更好的防止他人盜用。比如在注冊一些游戲賬號時,如果輸入純數(shù)字或純英文字符低于6位,就會提示密碼強度太低,請重新輸入。一些密碼強度驗證的方法都是計算字符的類型,然后分類加權(quán)累算。權(quán)重越高,相應(yīng)的強度也就越高。
具體的寫法及實現(xiàn)方式有很多種,本文只介紹其中一種方案
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>密碼強度實時驗證</title> </head> <body> <h3>密碼強度實時驗證</h3> <input id="passwordStrength" data-hint='請輸入密碼' type="password" ><span id="showStrength"></span> <script type="text/javascript"> window.onload = function () { function setCss(_this,cssOption){ //判斷節(jié)點類型 if (!_this || _this.nodeType ===3 || _this.nodeType === 8 ||!_this.style) { return; } for(var cs in cssOption){ _this.style[cs] = cssOption[cs]; } return _this; } function trim(chars){ return (chars ||"").replace(/^(\s|\u00a0)+|(\s|\u00a0)+$/g,""); } function passwordStrength(passwordStrength,showStrength){ var self = this; /*字符權(quán)重; 數(shù)字1,字母2,其他字符為3 當(dāng)密碼長度小于6時不符合標(biāo)準(zhǔn) 長度>=6,強度小于10,強度弱 長度>=6,長度>=10且<15,強度中 長度>=6,強度>=15,強*/ passwordStrength.onkeyup = function(){ var _color = ["red","yellow","orange","green"], msgs = ["密碼太短","弱","中","強"], _strength = 0, _v= trim(passwordStrength.value) _vL= _v.length, i=0; var charStrength = function(char){ //計算單個字符強度 if(char>=48 && char <=57){//數(shù)字 return 1; } if(char>=97 && char<=122){//小寫 return 2; }else{ return 3; //特殊字符 } } if(_vL<6){//計算模式 showStrength.innerText = msgs[0]; setCss(showStrength,{ "color":_color[0] }) }else{ for(;i<_vL;i++){ //遍歷字符 _strength+=charStrength(_v.toLocaleLowerCase().charCodeAt(i)); } if(_strength<10){ //強度小于10 showStrength.innerText = msgs[1]; setCss(showStrength,{ "color":_color[1] }) } if(_strength>=10&&_strength<15){ showStrength.innerText = msgs[2]; setCss(showStrength,{ "color":_color[2] }) } if(_strength>=15){ showStrength.innerText = msgs[3]; setCss(showStrength,{ "color":_color[3] }) } } } } passwordStrength( document.getElementById("passwordStrength"), document.getElementById("showStrength")); }; </script> </body> </html>
看完了這篇文章,相信你對“JavaScript實現(xiàn)密碼強度實時驗證的方法”有了一定的了解,如果想了解更多相關(guān)知識,歡迎關(guān)注億速云行業(yè)資訊頻道,感謝各位的閱讀!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。