您好,登錄后才能下訂單哦!
小編給大家分享一下JavaScript實現密碼強度實時驗證的方法,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!
在網絡服務中,為了保證用戶的私密信息足夠安全,會要求用戶輸入具有一定安全級別的密碼,這樣可以更好的防止他人盜用。比如在注冊一些游戲賬號時,如果輸入純數字或純英文字符低于6位,就會提示密碼強度太低,請重新輸入。一些密碼強度驗證的方法都是計算字符的類型,然后分類加權累算。權重越高,相應的強度也就越高。
具體的寫法及實現方式有很多種,本文只介紹其中一種方案
<!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){ //判斷節點類型 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; /*字符權重; 數字1,字母2,其他字符為3 當密碼長度小于6時不符合標準 長度>=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){//數字 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實現密碼強度實時驗證的方法”有了一定的了解,如果想了解更多相關知識,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。