密码强度检测

 
 
输入密码: 
onBlur=pwStrength(this.value)> 

密码强度: 
height="23" style='display:inline'> 
 
 
 
 
 
 

 


========================================

http://www.cnblogs.com/pmars/archive/2012/10/24/2736831.html

http://blog.csdn.net/heaven13483/article/details/7495482

==========================================

boost正则表达式库简单介绍
头文件 regex.hpp

常用的类
boost::regex 正则表达式

boost::cmatch 以char数组为容器,存储匹配返回值。
boost::smatch 以std::string为容器,存储匹配返回值。

boost::regex_match 匹配算法
boost::regex_search 查找算法
boost::regex_replace 替换算法

简单例子

#include

#include

int main( int argc, char* argv[] )
{
    char *buf = "This is boost::regex example";

    boost::regex exampleregex( "boost::regex" );
    boost::cmatch result;

    if( boost::regex_search( buf, result, exampleregex ) )
    {
        std::cout << result.str() << std::endl;
    }

    return 0;
}

注意regex.hpp的包含。要在开发工具中设置boost头文件所在位子。

===================================


【转】用正则表达式来匹配密码强度不错

网上找了些资料

一个好用的检查密码强度的正则表达式,可以检查至少有一个大写,一个小写, 一个特殊字符,长度要是8:
(?=^.{8,}$)((?=.*\d)|(?=.*\W+))(?![.\n])(?=.*[A-Z])(?=.*[a-z]).*$

////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////

是否有小写字母,是否有数字,是否有特殊字符,密码长度是不是大于6.最后返回弱 中 强
function isSecurity(v){
 if (v.length < 3) { iss.reset();return;}
 var lv = -1;
 if (v.match(/[a-z]/ig)){lv++;}
 if (v.match(/[0-9]/ig)){lv++;}
 if (v.match(/(.[^a-z0-9])/ig)){lv++;}
 if (v.length < 6 && lv > 0){lv--;}
 iss.reset();
 switch(lv) { 
 case 0:
 iss.level0();
 break;
 case 1:
 iss.level1();
 break;
 case 2:
 iss.level2();
 break;
 default:
 iss.reset();
 }

/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////

///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////

一个正则表达式验证密码强度

规则如下:

四种组合指 数字,小写字母,大写字母,其它字符

把密码强度分为四等:

1. 密码长度小于或等于四位.或者密码只有一种组合
2. 密码长度大于四位, 且有两种组合.
3. 密码长度大于四位, 且有三种组合.
4. 密码长度大于四位, 且有四种组合.

如果没有输入则返回0 这个是相对简单的一个方法,仔细看来还有待改进。

判断函数:

其实函数主体只有一句,只利用了一个正则.之间却应用了好几个技巧.
首先,这个正则会得到五个捕获组.
前四个捕获组会告诉我们这个字符串包含有多少种组合(返回多少个匹配代表多少种组合)
如果这个字符串小于5位的话,则会得到第五个捕获组,长度为1(即强度为1),如果没有输入,就连捕获组5都不会得到.强度为0
里面其它地方的小技巧理解起来应该也不会很难的.相信仔细阅读会理解

下面是一个应用实例
 

===================================

你可能感兴趣的:(密码强度检测)