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 相关文章推荐
jQuery 遍历json数组的实现代码
Sep 22 Javascript
子页向父页传值示例
Nov 27 Javascript
jQuery级联操作绑定事件实例
Sep 02 Javascript
javascript转换日期字符串为Date日期对象的方法
Feb 13 Javascript
全面了解addEventListener和on的区别
Jul 14 Javascript
AngularJs 动态加载模块和依赖
Sep 15 Javascript
vue模板语法-插值详解
Mar 06 Javascript
详解webpack多页面配置记录
Jan 22 Javascript
vue中如何动态绑定图片,vue中通过data返回图片路径的方法
Feb 07 Javascript
微信小程序scroll-view仿拼多多横向滑动滚动条
Apr 21 Javascript
vue通过滚动行为实现从列表到详情,返回列表原位置的方法
Aug 31 Javascript
微信小程序picker组件两列关联使用方式
Oct 27 Javascript
实例详解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
台湾中原大学php教程孙仲岳主讲
2008/01/07 PHP
php中sprintf与printf函数用法区别解析
2014/02/17 PHP
推荐11款jQuery开发的复选框和单选框美化插件
2011/08/02 Javascript
jQuery提交表单ajax查询实例代码
2012/10/07 Javascript
javaScript复制功能调用实现方案
2012/12/13 Javascript
node.js+Ajax实现获取HTTP服务器返回数据
2014/11/26 Javascript
Javascript中使用parseInt函数需要注意的问题
2015/04/02 Javascript
javascirpt实现2个iframe之间传值的方法
2016/06/30 Javascript
深入浅析JavaScript中的scrollTop
2016/07/11 Javascript
JS使用正则实现去掉字符串左右空格的方法
2016/12/27 Javascript
使用Vuex实现一个笔记应用的方法
2018/03/13 Javascript
详解如何快速配置webpack多入口脚手架
2018/12/28 Javascript
JavaScript解析及序列化JSON的方法实例分析
2019/01/04 Javascript
layui实现form表单同时提交数据和文件的代码
2019/10/25 Javascript
JS图片懒加载的优点及实现原理
2020/01/10 Javascript
VUE 单页面使用 echart 窗口变化时的用法
2020/07/30 Javascript
如何编写一个 Webpack Loader的实现
2020/10/18 Javascript
vue中配置scss全局变量的步骤
2020/12/28 Vue.js
[01:02:07]Liquid vs Newbee 2019国际邀请赛小组赛 BO2 第一场 8.15
2019/08/16 DOTA
Python正则表达式介绍
2012/08/06 Python
在Python的Django框架中获取单个对象数据的简单方法
2015/07/17 Python
python 实现在txt指定行追加文本的方法
2018/04/29 Python
python smtplib发送带附件邮件小程序
2018/05/22 Python
详解Python计算机视觉 图像扭曲(仿射扭曲)
2019/03/27 Python
Django基础知识 web框架的本质详解
2019/07/18 Python
详解Django 时间与时区设置问题
2019/07/23 Python
M.M.LaFleur官网:美国职业女装品牌
2020/10/27 全球购物
经济信息管理专业大学生求职信
2013/09/27 职场文书
大学学年自我鉴定
2013/10/28 职场文书
国税会议欢迎词
2014/01/16 职场文书
12岁生日感言
2014/01/21 职场文书
中式餐厅创业计划书范文
2014/01/23 职场文书
2016春季幼儿园大班开学寄语
2015/12/03 职场文书
土木工程生产实习心得体会
2016/01/22 职场文书
导游词之湖北武当山
2019/09/23 职场文书
nginx里的rewrite跳转的实现
2021/03/31 Servers