js密码强度检测


Posted in Javascript onJanuary 07, 2016

本文实例讲解了js密码强度检测的实现代码,分享给大家供大家参考,具体内容如下

运行效果图:

js密码强度检测

这段JavaScript代码比较实用,它完成用户注册时判断用户输入密码的强度,分强、弱、中三等级,它可以根据用户输入的密码显示对应的密码强弱等级,方便用户改进输入。

实现代码:

<html>
<head>
<title>JS判断密码强度</title>
<script language=javascript> 
//判断输入密码的类型 
function CharMode(iN){ 
if (iN>=48 && iN <=57) //数字 
return 1; 
if (iN>=65 && iN <=90) //大写 
return 2; 
if (iN>=97 && iN <=122) //小写 
return 4; 
else 
return 8;  
} 
//bitTotal函数 
//计算密码模式 
function bitTotal(num){ 
modes=0; 
for (i=0;i<4;i++){ 
if (num & 1) modes++; 
num>>>=1; 
} 
return modes; 
} 
//返回强度级别 
function checkStrong(sPW){ 
if (sPW.length<=4) 
return 0; //密码太短 
Modes=0; 
for (i=0;i<sPW.length;i++){ 
//密码模式 
Modes|=CharMode(sPW.charCodeAt(i)); 
} 
return bitTotal(Modes); 
} 
 
//显示颜色 
function pwStrength(pwd){ 
O_color="#eeeeee"; 
L_color="#FF0000"; 
M_color="#FF9900"; 
H_color="#33CC00"; 
if (pwd==null||pwd==''){ 
Lcolor=Mcolor=Hcolor=O_color; 
} 
else{ 
S_level=checkStrong(pwd); 
switch(S_level) { 
case 0: 
Lcolor=Mcolor=Hcolor=O_color; 
case 1: 
Lcolor=L_color; 
Mcolor=Hcolor=O_color; 
break; 
case 2: 
Lcolor=Mcolor=M_color; 
Hcolor=O_color; 
break; 
default: 
Lcolor=Mcolor=Hcolor=H_color; 
} 
} 
document.getElementById("strength_L").style.background=Lcolor; 
document.getElementById("strength_M").style.background=Mcolor; 
document.getElementById("strength_H").style.background=Hcolor; 
return; 
} 
</script>
</head>
<body> 
<form name=form1 action="" > 
密码:<input type=password size=8 onKeyUp=pwStrength(this.value) onBlur=pwStrength(this.value)> 
<br>密码强度: 
<table width="210" border="1" cellspacing="0" cellpadding="1" bordercolor="#eeeeee" height="22" style='display:inline'> 
<tr align="center" bgcolor="#f5f5f5"> 
<td width="33%" id="strength_L">弱</td> 
<td width="33%" id="strength_M">中</td> 
<td width="33%" id="strength_H">强</td> 
</tr> 
</table> 
</form>
</body>
</html>

这一款先看一看效果图。

js密码强度检测

具体内容:

<script>
function AuthPasswd(string) {
 if(string.length >=6) {
  if(/[a-zA-Z]+/.test(string) && /[0-9]+/.test(string) && /\W+\D+/.test(string)) {
   noticeAssign(1);
  }else if(/[a-zA-Z]+/.test(string) || /[0-9]+/.test(string) || /\W+\D+/.test(string)) {
   if(/[a-zA-Z]+/.test(string) && /[0-9]+/.test(string)) {
    noticeAssign(-1);
   }else if(/\[a-zA-Z]+/.test(string) && /\W+\D+/.test(string)) {
    noticeAssign(-1);
   }else if(/[0-9]+/.test(string) && /\W+\D+/.test(string)) {
    noticeAssign(-1);
   }else{
    noticeAssign(0);
   }
  }
 }else{
  noticeAssign(null); 
 }
}
 
function noticeAssign(num) {
 if(num == 1) {
  $('#weak').css({backgroundColor:'#009900'});
  $('#middle').css({backgroundColor:'#009900'});
  $('#strength').css({backgroundColor:'#009900'});
  $('#strength').html('很强');
  $('#middle').html('');
  $('#weak').html('');
 }else if(num == -1){
  $('#weak').css({backgroundColor:'#ffcc33'});
  $('#middle').css({backgroundColor:'#ffcc33'});
  $('#strength').css({backgroundColor:''});
  $('#weak').html('');
  $('#middle').html('中');
  $('#strength').html('');
 }else if(num ==0) {
  $('#weak').css({backgroundColor:'#dd0000'});
  $('#middle').css({backgroundColor:''});
  $('#strength').css({backgroundColor:''});
  $('#weak').html('弱');
  $('#middle').html('');
  $('#strength').html('');
 }else{
  $('#weak').html(' ');
  $('#middle').html(' ');
  $('#strength').html(' ');
  $('#weak').css({backgroundColor:''});
  $('#middle').css({backgroundColor:''});
  $('#strength').css({backgroundColor:''});
 }
}
</script>

以上就是本文的全部内容,希望对大家学习javascript程序设计有所帮助。

Javascript 相关文章推荐
用 JavaScript 迁移目录
Dec 18 Javascript
Javascript hasOwnProperty 方法 &amp; in 关键字
Nov 26 Javascript
js实现微信分享代码
Oct 11 Javascript
JavaScript 正则表达式中global模式的特性
Feb 25 Javascript
Vue.js中extend选项和delimiters选项的比较
Jul 17 Javascript
Vue的Class与Style绑定的方法
Sep 01 Javascript
taro开发微信小程序的实践
May 21 Javascript
el-input 标签中密码的显示和隐藏功能的实例代码
Jul 19 Javascript
JavaScript获取当前url路径过程解析
Dec 27 Javascript
vue使用自定义事件的表单输入组件用法详解【日期组件与货币组件】
Jun 01 Javascript
JavaScript中使用Spread运算符的八种方法总结
Jun 18 Javascript
Vue 打包的静态文件不能直接运行的原因及解决办法
Nov 19 Vue.js
实例详解JSON数据格式及json格式数据域字符串相互转换
Jan 07 #Javascript
基于JavaScript实现通用tab选项卡(通用性强)
Jan 07 #Javascript
基于JavaScript代码实现兼容各浏览器的设为首页和加入收藏
Jan 07 #Javascript
JavaScript设计模式初探
Jan 07 #Javascript
JavaScript类型系统之Object详解
Jan 07 #Javascript
7个去伪存真的JavaScript面试题
Jan 07 #Javascript
jQuery表格插件datatables用法详解
Nov 23 #Javascript
You might like
DOTA2 1月28日更新:监管系统降临刀塔世界
2021/01/28 DOTA
兼容PHP5的PHP目录管理函数库
2008/07/10 PHP
为PHP初学者的8点有效建议
2010/11/20 PHP
zf框架的registry(注册表)使用示例
2014/03/13 PHP
PHP的引用详解
2015/02/22 PHP
Nginx服务器上安装并配置PHPMyAdmin的教程
2015/08/18 PHP
jQuery判断元素是否是隐藏的代码
2011/04/24 Javascript
JQuery入门——用映射方式绑定不同事件应用示例
2013/02/05 Javascript
jQuery使用andSelf()来包含之前的选择集
2014/05/19 Javascript
js控制文本框输入的字符类型方法汇总
2015/06/19 Javascript
js流动式效果显示当前系统时间
2016/05/16 Javascript
js中setTimeout的妙用--防止循环超时
2017/03/06 Javascript
浅谈 Vue 项目优化的方法
2017/12/16 Javascript
vue使用axios实现文件上传进度的实时更新详解
2017/12/20 Javascript
微信小程序之多列表的显示和隐藏功能【附源码】
2018/08/06 Javascript
ng-alain的sf如何自定义部件的流程
2020/06/12 Javascript
基于Echarts图表在div动态切换时不显示的解决方式
2020/07/20 Javascript
python映射列表实例分析
2015/01/26 Python
Python语言描述机器学习之Logistic回归算法
2017/12/21 Python
python 获取当天每个准点时间戳的实例
2018/05/22 Python
python中的split()函数和os.path.split()函数使用详解
2019/12/21 Python
python爬虫开发之Request模块从安装到详细使用方法与实例全解
2020/03/09 Python
python 服务器运行代码报错ModuleNotFoundError的解决办法
2020/09/16 Python
python调用摄像头的示例代码
2020/09/28 Python
Django创建一个后台的基本步骤记录
2020/10/02 Python
html5借用repeating-linear-gradient实现一把刻度尺(ruler)
2019/09/09 HTML / CSS
群众路线教育实践活动心得体会
2014/03/07 职场文书
护士自我鉴定总结
2014/03/24 职场文书
推荐信格式要求
2014/05/09 职场文书
个人工作作风整改措施思想汇报
2014/10/13 职场文书
应届生求职自荐信范文
2015/03/04 职场文书
羊脂球读书笔记
2015/06/30 职场文书
小学生组织委员竞选稿
2015/11/21 职场文书
手把手教你使用TensorFlow2实现RNN
2021/07/15 Python
详解ZABBIX监控ESXI主机的问题
2022/06/21 Servers
Go语言编译原理之变量捕获
2022/08/05 Golang