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 相关文章推荐
SharePoint 客户端对象模型 (一) ECMA Script
May 22 Javascript
JavaScript var声明变量背后的原理示例解析
Oct 12 Javascript
SeaJS 与 RequireJS 的差异对比
Dec 08 Javascript
JS实现支持多选的遍历下拉列表代码
Aug 20 Javascript
jQuery无刷新切换主题皮肤实例讲解
Oct 21 Javascript
js表单登陆验证示例
Oct 19 Javascript
vue.js实现表格合并示例代码
Nov 30 Javascript
AngularJS Controller作用域
Jan 09 Javascript
vue-cli项目中怎么使用mock数据
Sep 27 Javascript
浅谈React组件之性能优化
Mar 02 Javascript
Vue 源码分析之 Observer实现过程
Mar 29 Javascript
详解vuex数据传输的两种方式及this.$store undefined的解决办法
Aug 26 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
在任意字符集下正常显示网页的方法一
2007/04/01 PHP
基于asp+ajax和数据库驱动的二级联动菜单
2010/05/06 PHP
用mysql_fetch_array()获取当前行数据的方法详解
2013/06/05 PHP
PHP生成网站桌面快捷方式代码分享
2014/10/11 PHP
symfony2.4的twig中date用法分析
2016/03/18 PHP
PHP中for循环与foreach的区别
2017/03/06 PHP
PHP魔术方法之__call与__callStatic使用方法
2017/07/23 PHP
Prototype使用指南之selector.js
2007/01/10 Javascript
Javascript创建Silverlight Plugin以及自定义nonSilverlight和lowSilverlight样式
2010/06/28 Javascript
广泛收集的jQuery拖放插件集合
2012/04/09 Javascript
在jQuery中 关于json空对象筛选替换
2013/04/15 Javascript
JS使用post提交的两种方式
2015/12/03 Javascript
小心!AngularJS结合RequireJS做文件合并压缩的那些坑
2016/01/09 Javascript
jQuery UI Bootstrap是什么?
2016/06/17 Javascript
使用Bootstrap typeahead插件实现搜索框自动补全的方法
2016/07/07 Javascript
数组Array的排序sort方法
2017/02/17 Javascript
使用JS组件实现带ToolTip验证框的实例代码
2017/08/23 Javascript
jQuery完成表单验证的实例代码(纯代码)
2017/09/30 jQuery
JavaScript中Require调用js的实例分享
2017/10/27 Javascript
vue数据操作之点击事件实现num加减功能示例
2019/01/19 Javascript
详解JS实现系统登录页的登录和验证
2019/04/29 Javascript
layui异步加载table表中某一列数据的例子
2019/09/16 Javascript
微信小程序自定义tabbar custom-tab-bar 6s出不来解决方案(cover-view不兼容)
2019/11/01 Javascript
JS前后端实现身份证号验证代码解析
2020/07/23 Javascript
python去掉字符串中重复字符的方法
2014/02/27 Python
详解Python 定时框架 Apscheduler原理及安装过程
2019/06/14 Python
使用Python实现文字转语音并生成wav文件的例子
2019/08/08 Python
Python3 requests文件下载 期间显示文件信息和下载进度代码实例
2019/08/16 Python
TFRecord文件查看包含的所有Features代码
2020/02/17 Python
英国领先的在线旅游和休闲零售商:lastminute.com
2019/01/23 全球购物
北大青鸟学生求职信
2013/09/24 职场文书
女儿十岁生日答谢词
2014/01/27 职场文书
机械电子工程专业自荐书
2014/06/10 职场文书
Nginx反向代理多个服务器的实现方法
2021/03/31 Servers
MySQL非空约束(not null)案例讲解
2021/08/23 MySQL
Python各协议下socket黏包问题原理
2022/04/12 Python