JavaScript實現密碼強度實時驗證
阿新 • • 發佈:2020-03-19
JavaScript實現密碼強度實時驗證,供大家參考,具體內容如下
在網路服務中,為了保證使用者的私密資訊足夠安全,會要求使用者輸入具有一定安全級別的密碼,這樣可以更好的防止他人盜用。比如在註冊一些遊戲賬號時,如果輸入純數字或純英文字元低於6位,就會提示密碼強度太低,請重新輸入。一些密碼強度驗證的方法都是計算字元的型別,然後分類加權累算。權重越高,相應的強度也就越高。
具體的寫法及實現方式有很多種,本文只介紹其中一種方案
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>密碼強度實時驗證</title> </head> <body> <h2>密碼強度實時驗證</h2> <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>
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。