网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > ASP.NET技巧
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
网络编程:ASP教程,ASP.NET教程,PHP教程,JSP教程,C#教程,数据库,XML教程,Ajax,Java,Perl,Shell,VB教程,Delphi,C/C++教程,软件工程,J2EE/J2ME,移动开发
本月文章推荐
.ASP.NET—From验证:全部代码及讲.
.在ASP.NET中创建安全的web站点(.
.使用WebClient自动填写并提交ASP.
..NET自动字符编码识别程序库 NCh.
.Asp.net+Xml实现无数据库论坛一点.
.Asp.net(c#)实现多线程断点续传.
.ASP.NET 无法确保在注册的 JavaS.
.IIS URL重写模块和ASP.NET路由组.
.Asp.net cache 简述.
.FCKeditor2.2+ASP.NET2.0不完全攻.
.使用PagedDataSource类实现DataL.
.asp.net 2.0里当readonly遇上ena.
.压力监测程序sqlserver和MYSQL版.
.ASP.NET程序中用Repeater实现分页.
.ASP.NET中备份SQL Server数据库的.
.小tips:asp.net 2.0中在gridview.
.ASP.Net常用功能整理--生成图片的.
.DATAGRID分页,增加首页、最后一.
.ASP.NET中不定级动态菜单的实现.
.在IIS与.net框架中配置中把扩展名.

使用ASP.NET Atlas开发检测密码强度的自定义Behavior

发表日期:2006-5-17


作者:Dflying Chen (http://dflying.cnblogs.com/

本文源于维生素C.net的一篇文章利用数学方法来大大降低一个逻辑判断实现的难度的例子。检测代码来自THIN的检验密码强度的JS类。

Atlas中提供了客户端JavaScript强大的面向对象功能,这几天看到了上述二位的帖子,觉得这个功能需求在日常开发中还是很常见的。晚上闲来无事,将上述功能封装为Atlas中的Behavior,以方便重用。关于Atlas的Behavior,请参考:在ASP.NET Atlas中创建自定义的Behavior。

按照在ASP.NET Atlas中创建自定义的Behavior这篇文章的五个自定义步骤,很容易写出了这个Behavior。其中最重要的部分为检验密码强度的算法,这里我偷了个懒,只是简单的将THIN的代码完全Copy过来(兄弟不要骂我-_-b),有心的朋友可以将它重构成更“Atlas”的样子。这个检测函数将在每次用户在相应的input中按键时被触发:

function keyPressHandler() {

    // you may refactor this part to make the code more 'Atlas like' :-)
    var PasswordStrength ={
        Level : ["高,实在是高","还行啦","靠,这样也行"],
        LevelValue : [30,20,0],//强度值
        Factor : [1,2,5],//字符加数,分别为字母,数字,其它
        KindFactor : [0,0,10,20],//密码含几种组成的加数
        Regex : [/[a-zA-Z]/g,/\d/g,/[^a-zA-Z0-9]/g] //字符正则数字正则其它正则
        }
    PasswordStrength.StrengthValue = function(pwd)
    {
        var strengthValue = 0;
        var ComposedKind = 0;
        for(var i = 0 ; i < this.Regex.length;i++)
        {
            var chars = pwd.match(this.Regex[i]);
            if(chars != null)
            {
                strengthValue += chars.length * this.Factor[i];
                ComposedKind ++;
            }
        }
        strengthValue += this.KindFactor[ComposedKind];
        return strengthValue;
    }
    PasswordStrength.StrengthLevel = function(pwd)
    {
        var value = this.StrengthValue(pwd);
        for(var i = 0 ; i < this.LevelValue.length ; i ++)
        {
            if(value >= this.LevelValue[i] )
                return this.Level[i];
        }
    }
    // end of the refactoring section
   
    $(_checkResultLabelID).innerHTML = PasswordStrength.StrengthLevel(this.control.element.value);
}

同时在这个Behavior中添加了属性checkResultLabelID,用来指定显示检验结果的Label:

var _checkResultLabelID;
this.get_checkResultLabelID = function() {
    return _checkResultLabelID;
}
this.set_checkResultLabelID = function(value) {
    if (_checkResultLabelID != value) {
        _checkResultLabelID = value;
        this.raisePropertyChanged('checkResultLabelID');
    }
}

您也可以很方便的添加一些更花哨的功能,例如对于不同强度的输入,提示文字的背景颜色有所改变等。完整的源代码请参考本文后面的下载。

测试的步骤也很简单,首先在ScriptManager中添加这个Behavior的引用:

<atlas:ScriptManager runat="server" ID="ScriptManager1">
    <Scripts>
        <atlas:ScriptReference Path="PasswordStrengthCheckBehavior.js" />
    </Scripts>
</atlas:ScriptManager>

然后在页面上添加一个input,用来输入密码(演示程序中没有设定type为password),和一个span,用来显示检验结果:

<div>
    Input a password:
    <input id="password" type="text" />
    <span id="result"></span>
</div>

最后,Atlas Script中将上面的input提升为Atlas控件,并加入我们刚刚写好的Behavior:

<script type="text/xml-script">
    <page xmlns:script="http://schemas.microsoft.com/xml-script/2005">
        <components>
            <textBox id="password">
                <behaviors>
                    <passwordStrengthCheckBehavior checkResultLabelID="result" />
                </behaviors>
            </textBox>
        </components>
    </page>
</script>

就是这么简单,浏览器中如下:

简单密码:

中等密码:

复杂密码:

源代码以及示例程序可以在此下载:http://www.cnblogs.com/Files/dflying/PasswordStrengthCheckBehaviorDemo.zip

上一篇:解决ASP.NET的进程帐户没有访问 IIS的权限 人气:10687
下一篇:在ASP.NET Atlas中调用Web Service—处理错误,超时以及响应用户的取消操作 人气:6762
浏览全部ASP.NET的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐