当前位置: 首页 > 图文教程 > 网络编程 > ASP.NET > 递归法提升密码穷举算法性能

ASP.NET
ASP.NET在上传文件时对文件类型的高级判断的代码
JQuery运用ajax注册用户实例(后台asp.net)
Asp.net与SQLserver一起打包部署安装图文教程
asp.net 上传下载输出二进制流实现代码
asp.net(C#)解析Json的类代码
asp.net 截取字符串代码
asp.net ubb使用代码
asp.net XML文件操作实现代码
asp.net利用HttpModule实现防sql注入
ASP.NET(C#)中操作SQLite数据库实例
asp.net(c#)ref,out ,params的区别
asp.net(C#)防sql注入组件的实现代码
asp.net FCKeditor自定义非空验证
Asp.net TreeView来构建用户选择输入的方法 推荐
asp.net(C#)函数对象参数传递的问题
Asp.net中的GridView导出遇到的两个问题和解决方法
asp.Net 中获取一周第一天,一月第一天等实现代码
asp.net MaxLengthValidator 最大长度验证控件代码
C# 通用文件上传类
asp.net 自定义控件实现无刷新上传图片,立即显示缩略图,保存图片缩略图

ASP.NET 中的 递归法提升密码穷举算法性能


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-11-03   浏览: 45 ::
收藏到网摘: n/a

在Google中查询“密码穷举算法”,可以得到大约5千个的结果,提供了一个C的算法实例。本文不想再重复拷贝这些实例代码,如果需要的兄弟可以在Google上搜索获得。本人在研读这些代码后,觉得可以使用递归以提升该算法的性能。 惭愧的紧,本人对C代码就好像对上海话一样,能听懂一点,却说不溜。一句话,半调子。因此本文使用了VB.NET语言,希望大家可以理解。VB嘛,更好懂。 下面提供了两段代码,使用了相同的声明。 Friend Delegate Sub CallBack(ByVal Password As String) ' 密码输出回调 Private Const PStartLen As Integer = 1 Private Const PMaxLen As Integer = 6 ' 生成密码的最大长度 Private PDict() As Char = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz".ToCharArray ' 密码词典 第一段是C代码的一个VB.NET翻版: ' 翻版 Friend Sub MakePass_General(ByVal Cnn As CallBack) Dim PDictLen As Long = Len(PDict) ' 获得密码词典长度 Dim CPass(PMaxLen - 1) As String ' 将生成的密码 Dim PLen As Integer For PLen = PStartLen To PMaxLen ' 密码长度 Dim Array(PMaxLen - 1) As Integer ' 密码词典下标 Dim bNext As Boolean = True While bNext Dim i, j As Integer For i = 0 To PLen - 1 CPass(i) = PDict(Array(i)) Next Cnn.Invoke(String.Join("", CPass)) ' 密码输出 For j = PLen - 1 To 0 Step -1 ' 密码指针进位 Array(j) += 1 If Array(j) < PDictLen Then Exit For Else Array(j) = 0 If (j = 0) Then bNext = False End If Next End While Next End Sub 第二段代码,使用了递归法进行了优化: ' 递归法密码穷举算法 Friend Sub MakePass_Recursion(ByVal Cnn As CallBack) Dim PLen As Integer For PLen = PStartLen To PMaxLen ' 密码长度 Dim CPass(PLen - 1) As String ' 将生成的密码 MakePass_Recursion(Cnn, CPass) Next End Sub Private Sub MakePass_Recursion(ByVal Cnn As CallBack, ByRef CPass() As String, Optional ByVal ID As Integer = 0) Dim i As Integer For i = 0 To PDict.Length - 1 CPass(ID) = PDict(i) If ID = CPass.Length - 1 Then Cnn.Invoke(String.Join("", CPass)) ' 密码输出 Else MakePass_Recursion(Cnn, CPass, ID + 1) End If Next End Sub 代码很简单,勿虚多言。对两段代码进行了测试,使用递归法优化后的密码穷举算法较常规的算法提高了大约1倍的速度。 班门弄斧,让高手们见笑了。请多指教。