你好,游客 登录 注册 搜索
背景:
阅读新闻

破解Word密码

[日期:2018-02-26] 来源:  作者: [字体: ]

  工作繁忙难免产生意外,比如对重要的word文档加密之后却把密码忘得一干二净,这几乎会发生在每个人的身上。这时你可能会焦急万分,不过我劝你不要太紧张,有空来程序谷坐坐,一定会有好的答案的。下面我们就来看看?#20204;?#20030;法暴力破解Word密码的程序,?#27604;唬?#20026;了简单起见,程序只针对密码是数字的情况做了处理,字符型的密码与此类似,不再多说了。

  一、引言

  大家都知道,office家族跟VB有千?#23458;?#32533;的联系,Microsoft Office组件中的所有应用程序都内建有VBA,这样就可以通过VB或VBA操作 Word 应用程序中的对象,?#20204;?#20030;测试的办法达到?#19968;?#20002;失密码的目?#27169;?#38750;常简单吧!

  二、实现过程

  下面来看一看程序的具体编制过程。程序采用VB编程实现,需要机器安装有VB应用程序及Microsoft Office组件。打开VB,新建一个VB 工程,取名Proc_Word,将启动窗体命名为FrmMain,选择“工程”菜单中的“引用?#20445;?#22312;“引用”对话框中选择 “Microsoft Word8.0 Object Library?#20445;?#36825;一步很重要,你必须选择这一ActiveX部件,否则代码不能正确运行,顺便说一句,如果安装的是Office2000,那么应该选择 “Microsoft Word9.0 Object Library?#20445;?#21516;时在“工程”菜单中?#23433;?#20214;”对话框中选择添加“Microsoft Windows common controls -2.5 (sp2)?#20445;?#20197;便在窗体设计中可以使用微调控件。

  好了,现在可以动手编制程序了。在刚才FrmMain窗体的左侧添加一个框架控件,并在此控件内加入一个驱动器列表框、一个目录列表框和一个文件列表框控件。在FrmMain窗体的右下侧添加两个命令按钮,在右上侧添加三个标签控件、两个文本框控件和一个微调控件,你可以参?#20960;?#22270;来设计。接着,将框架的Caption属性设置成“请选择需要破译的Word文档?#20445;?#20445;持目录列表框、驱动器列表框、文件列表框、文本框、微调控件缺省名称不变;将文件列表框的Pattern属性设置成“*.DOC?#20445;?#30446;的是只显示目录下的 Word文件;将第一个标签控件Caption属性设置成?#26696;?#31243;序破译八位以下纯数字组合Word文档密码?#20445;?#23558;第二个标签Caption属性设置成“解密进?#21462;保?#23558;第三个标签Caption属性设置成“请选择破译密码位数?#20445;?#23558;第二个文本框的Text属性设置成“4?#20445;?#36825;是缺省密码位数;将微调按钮的 BuddyControl属性设置成Text2就能和第二个文本框关联,BuddyProperty 改成Text,Max、Min属性分别设置成“8”和“1?#20445;?#34920;示最长密码位数和最短密码位数,将Wrap属性设置成True,将Increment属性设置成“1?#20445;?#20197;便每单击一次加1或减1;将两个命令按钮的名称分别改成 “cmdopendoc”和“cmdquit?#20445;珻aption属性分别设置成“文件打开”、“系统?#39034;觥薄?#20197;上就把各控件的属性设置完了,接着编写代码也就不是什么难事儿了。

  下面就是全部的源程序,适当的注释有助于大家理解程序。你还可以通过设置?#31995;?#26469;跟踪密码生成部分,看看程序编制的原理。

  Private Sub cmdopendoc_Click()

  Dim wd As New Word.Application

  Dim strpath As String

  Dim pass As String

  Dim J, K, Pass_long As Integer

  Dim Max_num, Min_num, I As Long

  strpath = File1.Path & "\" & File1.FileName

  On Error Resume Next

  '程序开始

  Pass_long = Val(Text2.Text)

  Max_num = 10 ^ Val(Text2.Text)

  Min_num = 10 ^ (Val(Text2.Text) - 1)

  Flag = 0

  For K = 0 To Pass_long - 1

  Max_num = 10 ^ (Pass_long - K)

  Min_num = 10 ^ (Pass_long - (K + 1))

  For J = 0 To Pass_long - 1

  cmdopendoc.MousePointer = 11

  For I = IIf(Pass_long - K = 1, 0, Min_num) + J To Max_num Step Pass_long

  Text1.Text = pass

  Text1.Refresh

  pass = String(K, "0") & I

  Flag = wd.Documents.Open(FileName:=strpath, passworddocument:=pass)

  '如果解密成功,打开文档,显示密码,?#39034;?#36807;程

  If Flag <> 0 Then

  Label1.Caption = "文档密码"

  Label1.Refresh

  Text1.Text = pass

  wd.Visible = True

  cmdopendoc.MousePointer = 0

  Exit Sub

  End If

  Next I

  Next J

  Next K

  MsgBox "密码位数不对,请重新输入"

  End Sub

  Private Sub cmdquit_Click()

  End

  End Sub

  Private Sub Dir1_Change()

  File1.Path = Dir1.Path

  End Sub

  Private Sub Drive1_Change()

  Dir1.Path = Drive1.Drive

  End Sub

  Private Sub File1_DblClick()

  Call cmdopendoc_Click

  End Sub

  三、几点?#24471;?

  需要?#24471;?#30340;是,穷举法解密对系统资源的耗用是十分惊人?#27169;?#22312;解密的过程中最好不要运行其他应用程序。针对其巨大的资源耗用量,我在程序中采用了一个小技巧,那就是用密码位数作为循环的步长进行刺探。也就是说如果你的密码是3位的话,那么程序将?#26469;?#23581;试100、103 、106……997、 101、104……998、102、105……999结束,加快了查找密码的速度(东渐: 其实大家可以动手算一算,到底是快了许多,还是快了一点,还是根本没有提高速度^_^)。

  该程序在Win98/NT+VB6.0环境下测试通过,笔者随便试了一个5位数密码,在PⅡ300、128MB内存的机器上,10分钟左右即可解开。?#27604;唬?#31243;序并不十分完善,比如还可以加入解密过程中的中断,以及中断后解密进度的保存等,有兴趣的读者可以自己加以完善。



本文《破解Word密码》的网址是http://www.mkqeb.com/n41387c22.aspx

收藏 推荐 打印 | 录入:admin | 阅读:
相关新闻       wps 
本文评论   查看全部评论 (0)
表情: 表情 姓名: 字数
点评:
       
评论声明
  • 尊重网?#31995;?#24503;,遵守中华人民共和国的各项有关法律法规
  • 承担一切因您的行为而直接或间接导致的民事或刑事法律责任
  • 本站管理人员有权保留或?#22659;?#20854;管辖留言中的?#25105;?#20869;容
  • 本站有权在网站内转载或引用您的评论
  • 参与本评论即表明您已经阅读并接受上述条款
利物浦足球俱乐部图片
卡利亚里羽绒服2409055 热血羽毛球mg试玩 广岛三箭vs大阪樱花直播 云南时时彩开奖码 ag真人视讯厅外挂 尖子和八5手彩金 今天比特币暴涨 pc蛋蛋计划软件手机版 足球比分网即时比分中国 诈金花真实游戏 专业的彩票走势图 时时彩计划软件五星 我的世界籽岷优酷自频道 荒野行动plus时装 无限法则有手机版吗 龙族幻想五个职业