源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

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

  • 时间:2020-04-04 21:22 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:JS密码生成与强度检测完整实例(附demo源码下载)
本文实例讲述了JS密码生成与强度检测的方法。分享给大家供大家参考,具体如下: [b]1. 生成强密码[/b] 截图如下: [img]http://files.jb51.net/file_images/article/201604/201646102856052.jpg?201636102936[/img] 相关代码如下:
function getPwd(n)
{
 var s = '';
 while(n--)
 s += String.fromCharCode(33 + Math.floor(Math.random()*(126-33)))
 document.getElementById('txt1').value = s;
}

[b]2. 计算密码破解时间[/b] 截图如下: [img]http://files.jb51.net/file_images/article/201604/201646102944724.jpg?20163610304[/img] 相关代码如下:
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;
}

[b]3. 密码安全检测[/b] 截图如下: [img]http://files.jb51.net/file_images/article/201604/201646103012050.jpg?201636103030[/img] 相关代码如下:
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;
}

[b]4. 检测键盘是否大写锁定(Caps Lock键状态)[/b] 截图如下: [img]http://files.jb51.net/file_images/article/201604/201646103038861.jpg?201636103055[/img] 相关代码如下:
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);
 }
}

完整实例代码点击此处[url=http://xiazai.jb51.net/201604/yuanma/js-create-check-password-codes(jb51.net).rar]本站下载[/url]。 更多关于JavaScript相关内容感兴趣的读者可查看本站专题:《[url=http://www.1sucai.cn/Special/502.htm]JavaScript切换特效与技巧总结[/url]》、《[url=http://www.1sucai.cn/Special/472.htm]JavaScript查找算法技巧总结[/url]》、《[url=http://www.1sucai.cn/Special/462.htm]JavaScript动画特效与技巧汇总[/url]》、《[url=http://www.1sucai.cn/Special/439.htm]JavaScript错误与调试技巧总结[/url]》、《[url=http://www.1sucai.cn/Special/297.htm]JavaScript数据结构与算法技巧总结[/url]》、《[url=http://www.1sucai.cn/Special/281.htm]JavaScript遍历算法与技巧总结[/url]》及《[url=http://www.1sucai.cn/Special/119.htm]JavaScript数学运算用法总结[/url]》 [b]PS:对密码感兴趣的读者还可以参考一下本站密码相关工具:[/b] [url=http://tools.jb51.net/password/my_password_safe]密码安全性在线检测[/url] [url=http://tools.jb51.net/password/CreateStrongPassword]高强度密码生成器[/url] [url=http://tools.jb51.net/password/CreateMD5Password]MD5在线加密工具[/url] [url=http://tools.jb51.net/password/htpasswd]在线生成htpasswd工具[/url] [url=http://tools.jb51.net/password/urlencodepwd]URL网址16进制加密工具[/url] [url=http://tools.jb51.net/password/escapepwd]Escape加密/解密工具[/url] [url=http://tools.jb51.net/password/urlrethunder]迅雷、快车、旋风URL加密/解密工具[/url] 希望本文所述对大家JavaScript程序设计有所帮助。
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部