首页 > 编程 > JavaScript > 正文

JS密码生成与强度检测完整实例(附demo源码下载)

2019-11-20 10:17:23
字体:
来源:转载
供稿:网友

本文实例讲述了JS密码生成与强度检测的方法。分享给大家供大家参考,具体如下:

1. 生成强密码

截图如下:

相关代码如下:

function getPwd(n){ var s = ''; while(n--) s += String.fromCharCode(33 + Math.floor(Math.random()*(126-33))) document.getElementById('txt1').value = s;}

2. 计算密码破解时间

截图如下:

相关代码如下:

function getTime(){ var str = '预计破解用时:'; var selChar = document.getElementById('selChar'); var txtPwdLen = document.getElementById('txtPwdLen'); var num = Math.pow(parseInt(selChar.value), parseInt(txtPwdLen.value)); str += formatTime(num / (1024*1024*1024*2.4*2)); document.getElementById('span2').innerHTML = str;}function formatTime(s){ var str = ''; if(s<1)return '小于1秒!'; s = Math.floor(s); if(s >= 1) str = s % 60 + '秒' + str; s = Math.floor(s / 60); if(s >= 1) str = s % 60 + '分' + str; s = Math.floor(s / 60); if(s >= 1) str = s % 24 + '时' + str; s = Math.floor(s / 24); if(s >= 1) str = s + '天' + str; return str;}

3. 密码安全检测

截图如下:

相关代码如下:

function showPwd(){  var p = document.getElementById('txt2').value;  if(p.length < 4)  {    showError('密码至少4位!');    return;  }  var o = checkPwd(p);  if(o.isSame)  {    showError('密码为重复字符!');    return;  }  for(var i=0; i<arrPwd.length; i++)  {    if(arrPwd[i] == p || arrPwd[i].indexOf(p) == 0)    {      showError('密码为100大常用密码!');      return;    }  }  var year = parseInt(p.substr(0,4));  if(!isNaN(year) && year>1900 && year<2100)  {    var month = parseInt(p.substr(4,2));    if(!isNaN(month) && month>0 && month<13)    {      var day = parseInt(p.substr(6,2));      if(!isNaN(day) && day>0 && day<32)      {        showError('不要使用日期作为密码!');        return;      }    }  }  var hasUpper = false;  var hasLow = false;  var hasNum = false;  var hasOther = false;  for(var i=0; i<p.length; i++)  {    var c = p.charCodeAt(i);    if(c>=65&&c<=90)hasUpper=true;    else if(c>=97&&c<=122)hasLow=true;    else if(c>=48&&c<=57)hasNum=true;    else hasOther=true;  }  var pwdNum = 0;  if(hasUpper)pwdNum+=26;  if(hasLow)pwdNum+=26;  if(hasNum)pwdNum+=10;  if(hasOther)pwdNum+=32;  var num = Math.pow(pwdNum, p.length);  var str = '密码长度:' + p.length + ' 强度:' + pwdNum + ' 预计破解用时:' + formatTime(num / (1024*1024*1024*2.4*2));  var span1 = document.getElementById('span1');  span1.style.color = 'blue';  span1.innerHTML = str;}

4. 检测键盘是否大写锁定(Caps Lock键状态)

截图如下:

相关代码如下:

var $lock = false;function checkCapsLock(fn){ document.documentElement.onkeypress = function(e) {  var e = e || event;  var k = e.keyCode || e.which;  var s = e.shiftKey || (k == 16) || false;  if(k>=65&&k<=90)$lock=!s;  if(k>=97&&k<=122)$lock=s;  fn($lock); } document.documentElement.onkeyup = function(e) {  var e = e || event;  var k = e.keyCode || e.which;  if(k==20)$lock = !$lock;  fn($lock); }}

完整实例代码点击此处本站下载

更多关于JavaScript相关内容感兴趣的读者可查看本站专题:《JavaScript切换特效与技巧总结》、《JavaScript查找算法技巧总结》、《JavaScript动画特效与技巧汇总》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》及《JavaScript数学运算用法总结

PS:对密码感兴趣的读者还可以参考一下本站密码相关工具:

密码安全性在线检测

高强度密码生成器

MD5在线加密工具

在线生成htpasswd工具

URL网址16进制加密工具

Escape加密/解密工具

迅雷、快车、旋风URL加密/解密工具

希望本文所述对大家JavaScript程序设计有所帮助。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表