JavaScript用户密码安全强度判定

判断用户输入的字符组合
服务器君一共花费了321.790 ms进行了6次数据库查询,努力地为您提供了这个页面。
试试阅读模式?希望听取您的建议

判断用户输入的密码,然后告诉用户其密码的强度是一个很好的用户体验设计,一来可以提高用户密码的安全度,也可以让用户对网站产生信任感。下面是一个简单的判断用户密码强度的JavaScript程序。

效果演示

输入密码:
密码强度:
温馨提示: 密码至少需要4个字符,并且最好包含数字,字母(大小写都有)与特殊符号。

分析

密码已经是我们生活工作中必不可少的工具,但一个不安全的密码有又有可能会给我们造成不必要的损失。作为网站设计者,如果我们在网页中能对用户输入的密码进行安全评估,并显示出相应的提示信息,那么对用户设置一个安全的密码将有很大帮助。同时也使得网站更具人性化,更有吸引力。

什么是一个安全的密码呢?本程序按以下的方式进行评估。

  • 如果密码少于5位,那么就认为这是一个弱密码。
  • 如果密码只由数字、小写字母、大写字母或其它特殊符号当中的一种组成,则认为这是一个弱密码。
  • 如果密码由数字、小写字母、大写字母或其它特殊符号当中的两种组成,则认为这是一个中度安全的密码。
  • 如果密码由数字、小写字母、大写字母或其它特殊符号当中的三种以上组成,则认为这是一个比较安全的密码。

程序代码

<meta http-equiv="Content-Type" content="text/html; charset=utf-8"> 
<script language=javascript> 
//CharMode函数 
//测试某个字符是属于哪一类. 
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; 
} 
//checkStrong函数 
//返回密码的强度级别 
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); 
} 
//pwStrength函数.www.qichepeijian.com 
//当用户放开键盘或密码输入框失去焦点时,根据不同的级别显示不同的颜色 
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> 
<form name="form1" action="" > 
<table width="400" border="0">
  <tr>
    <td width="25%">输入密码:</td>
    <td width="75%"><input type="password" size="40" onKeyUp="pwStrength(this.value)" onBlur="pwStrength(this.value)"> </td>
  </tr>
  <tr>
    <td>密码强度:</td>
    <td>
<table width="300" border="1" bordercolor="#cccccc" height="23"> 
	<tr bgcolor="#eeeeee"> 
		<td width="100" id="strength_L">弱</td> 
		<td width="100" id="strength_M">中</td> 
		<td width="100" id="strength_H">强</td> 
	</tr> 
</table> 
    </td>
  </tr>
  <tr>
    <td>温馨提示:</td>
    <td>密码至少需要4个字符,并且最好包含数字,字母(大小写都有)与特殊符号。</td>
  </tr>
</table>
</form>

本文地址:http://www.nowamagic.net/librarys/veda/detail/401,欢迎访问原出处。

不打个分吗?

转载随意,但请带上本文地址:

http://www.nowamagic.net/librarys/veda/detail/401

如果你认为这篇文章值得更多人阅读,欢迎使用下面的分享功能。
小提示:您可以按快捷键 Ctrl + D,或点此 加入收藏

大家都在看

阅读一百本计算机著作吧,少年

很多人觉得自己技术进步很慢,学习效率低,我觉得一个重要原因是看的书少了。多少是多呢?起码得看3、4、5、6米吧。给个具体的数量,那就100本书吧。很多人知识结构不好而且不系统,因为在特定领域有一个足够量的知识量+足够良好的知识结构,系统化以后就足以应对大量未曾遇到过的问题。

奉劝自学者:构建特定领域的知识结构体系的路径中再也没有比学习该专业的专业课程更好的了。如果我的知识结构体系足以囊括面试官的大部分甚至吞并他的知识结构体系的话,读到他言语中的一个词我们就已经知道他要表达什么,我们可以让他坐“上位”毕竟他是面试官,但是在知识结构体系以及心理上我们就居高临下。

所以,阅读一百本计算机著作吧,少年!

《高性能JavaScript》 Nicholas C. Zakas (作者), 赵泽欣 (合著者), 丁琛 (译者)

《高性能JavaScript》揭示的技术和策略能帮助你在开发过程中消除性能瓶颈。你将会了解如何提升各方面的性能,包括代码的加载、运行、DOM 交互、页面生存周期等。雅虎的前端工程师 Nicholas C. Zakas 和其他五位 JavaScript 专家介绍了页面代码加载的最佳方法和编程技巧,来帮助你编写更为高效和快速的代码。你还会了解到构建和部署文件到生产环境的最佳实践,以及有助于定位线上问题的工具。如果你使用 JavaScript 构建交互丰富的 Web 应用,那么 JavaScript 代码可能是造成你的Web应用速度变慢的主要原因。

更多计算机宝库...