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


Posted in Javascript onApril 06, 2016

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

1. 生成强密码

截图如下:

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

相关代码如下:

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

2. 计算密码破解时间

截图如下:

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

相关代码如下:

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. 密码安全检测

截图如下:

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

相关代码如下:

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键状态)

截图如下:

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

相关代码如下:

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);
 }
}

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

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

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

Javascript 相关文章推荐
根据当前时间在jsp页面上显示上午或下午
Aug 18 Javascript
JavaScript实现判断图片是否加载完成的3种方法整理
Mar 13 Javascript
jquery实现图片放大镜功能
Nov 23 Javascript
jQuery+Ajax实现无刷新操作
Jan 04 Javascript
微信小程序 Audio API详解及实例代码
Sep 30 Javascript
Jquery EasyUI Datagrid右键菜单实现方法
Dec 30 Javascript
js实现图片加载淡入淡出效果
Apr 07 Javascript
Angular2搜索和重置按钮过场动画
May 24 Javascript
gulp教程_从入门到项目中快速上手使用方法
Sep 14 Javascript
在微信小程序中渲染HTML内容的方法示例
Sep 28 Javascript
js时间转换毫秒的实例代码
Aug 21 Javascript
js中实现继承的五种方法
Jan 25 Javascript
JS控制伪元素的方法汇总
Apr 06 #Javascript
JS实现把鼠标放到链接上出现滚动文字的方法
Apr 06 #Javascript
IE8 内存泄露(内存一直增长 )的原因及解决办法
Apr 06 #Javascript
jQuery实现HTML表格单元格的合并功能
Apr 06 #Javascript
JS中JSON对象和String之间的互转及处理技巧
Apr 06 #Javascript
js老生常谈之this,constructor ,prototype全面解析
Apr 05 #Javascript
实例详解ECMAScript5中新增的Array方法
Apr 05 #Javascript
You might like
smarty的保留变量问题
2008/10/23 PHP
在PHP中利用wsdl创建标准webservice的实现代码
2011/12/07 PHP
浅谈PHP中output_buffering
2015/07/13 PHP
phpStorm+XDebug+chrome 配置详解
2019/04/01 PHP
laravel http 自定义公共验证和响应的方法
2019/09/29 PHP
Javascript 解疑
2009/11/11 Javascript
利用谷歌地图API获取点与点的距离的js代码
2012/10/11 Javascript
js实现日期级联效果
2014/01/23 Javascript
jQuery根据ID获取input、checkbox、radio、select的示例
2014/08/11 Javascript
JavaScript编程中布尔对象的基本使用
2015/10/25 Javascript
用JS实现简单的登录验证功能
2017/07/28 Javascript
Bootstrap popover 实现鼠标移入移除显示隐藏功能方法
2018/01/24 Javascript
nodejs使用redis作为缓存介质实现的封装缓存类示例
2018/02/07 NodeJs
JavaScript实现获取两个排序数组的中位数算法示例
2019/02/26 Javascript
javascript 模块依赖管理的本质深入详解
2020/04/30 Javascript
Python实现字符串与数组相互转换功能示例
2017/09/22 Python
python之从文件读取数据到list的实例讲解
2018/04/19 Python
python和pygame实现简单俄罗斯方块游戏
2021/02/19 Python
IntelliJ IDEA安装运行python插件方法
2018/12/10 Python
详解Python3注释知识点
2019/02/19 Python
在pytorch 中计算精度、回归率、F1 score等指标的实例
2020/01/18 Python
国际奢侈品品牌童装购物网站:Designer Childrenswear
2019/05/08 全球购物
linux比较文件内容的命令是什么
2015/09/23 面试题
部队万能检讨书
2014/02/20 职场文书
愚人节活动策划方案
2014/03/11 职场文书
超市中秋节促销方案
2014/03/21 职场文书
外国人聘用意向书
2014/04/01 职场文书
兴趣小组活动总结
2014/05/05 职场文书
销售员未完成销售业绩的检讨书
2014/10/12 职场文书
作风建设年度心得体会
2014/10/29 职场文书
写给老师的感谢信
2015/01/20 职场文书
公司市场部岗位职责
2015/04/15 职场文书
java开发双人五子棋游戏
2022/05/06 Java/Android
错误码NET::ERR_CERT_DATE_INVALID证书已过期解决方法?
2022/07/07 数码科技
Java实现字符串转为驼峰格式的方法详解
2022/07/07 Java/Android
python中使用redis用法详解
2022/12/24 Redis