如何用VB编写破译Word密码的程序?

说详细一点,我是新手.

如何破解word密码?

word数字密码破解软件下载:http://yxm02.go.nease.net/xz/zzrj/Wordpass.exe

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

一、引言

大家都知道,Office家族跟VB有千丝万缕的联系,Microsoft Office组件中的所有应用程序都内建有VBA,这样就可以通过VB或VBA操作Word 应用程序中的对象,用穷举测试的办法达到找回丢失密码的目的,非常简单吧!

二、实现过程

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

好了,现在可以动手编制程序了。在刚才FrmMain窗体的左侧添加一个框架控件,并在此控件内加入一个驱动器列表框、一个目录列表框和一个文件列表框控件。在FrmMain窗体的右下侧添加两个命令按钮,在右上侧添加三个标签控件、两个文本框控件和一个微调控件,你可以参考附图来设计。接着,将框架的Caption属性设置成“请选择需要破译的Word文档”;保持目录列表框、驱动器列表框、文件列表框、文本框、微调控件缺省名称不

暴力破解

将文件列表框的Pattern属性设置成“*.DOC”,目的是只显示目录下的 Word文件;将第一个标签控件Caption属性设置成“该程序破译八位以下纯数字组合Word文档密码”,将第二个标签Caption属性设置成“解密进度”,将第三个标签Caption属性设置成“请选择破译密码位数”;将第二个文本框的Text属性设置成“4”,这是缺省密码位数;将微调按钮的 BuddyControl属性设置成Text2就能和第二个文本框关联,BuddyProperty 改成Text,Max、Min属性分别设置成“8”和“1”,表示最长密码位数和最短密码位数,将Wrap属性设置成True,将Increment属性设置成“1”,以便每单击一次加1或减1;将两个命令按钮的名称分别改成 “cmdopendoc”和“cmdquit”,Caption属性分别设置成“文件打开”、“系统退出”。以上就把各控件的属性设置完了,接着编写代码也就不是什么难事儿了。

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

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)

’如果解密成功,打开文档,显示密码,退出过程

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

三、几点说明

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

该程序在Win98/NT+VB6.0环境下测试通过,笔者随便试了一个5位数密码,在PⅡ300、128MB内存的机器上,10分钟左右即可解开。当然,程序并不十分完善,比如还可以加入解密过程中的中断,以及中断后解密进度的保存等,有兴趣的读者可以自己加以完善。
温馨提示:内容为网友见解,仅供参考
无其他回答

如何用VB编写破译Word密码的程序?
程序采用VB编程实现,需要机器安装有VB应用程序及Microsoft Office组件。打开VB,新建一个VB工程,取名Proc_Word,将启动窗体命名为FrmMain,选择“工程”菜单中的“引用”,在“引用”对话框中选择 “Microsoft Word8.0 Object Library”(这一步很重要,你必须选择这一ActiveX部件,否则代码不能正确运行,...

使用VB编程,撤消word密码
'1.增加一个控制可恢复次数的变量,以限制对内存的无限制使用,以免造成内存溢出 '2.修正一个原代码错误,避免用户进行恢复时出错的问题 '对报纸上原程序存在错误的测试可以通过连续输入0123456789试验,'会发现撤销输入时是正确的,但恢复时就会出错,'虚线之间的内容是我新加的,加入这些代码后,本程序将...

VB的密码怎么破解啊
下面我们就来看看用穷举法暴力破解Word密码的程序,当然,为了简单起见,程序该程序在Win98\/NT+VB6.0环境下测试通过,笔者随便试了一个5位数密码,在

...用VB6.0给设计一个能直接打开已知密码的word文档的程序! 要求点击...
ap.documents.Open(FileName:="文件路径和名称", passworddocument:="密码")注意括号里面的冒号等于 或者写 dim ap as new word.application ap.documents.Open("文件路径和名称",,,"密码")写4个西文半角逗号就可以了 另外工程必须引用word的Object lib ...

vb编成校验WORD文档的数据~
全部代码如下,您需要先做好备份工作,然后选择需要处理的文本,在VBA中新建一个模块,输入代码,然后点“运行”即可:Public Sub RemoveRep()Const Splitter = "。" '此处是你每个数字的分隔符 Dim Src As String, Dest As String Dim Data() As String, EachData As Variant Dim NewData As ...

vb如何批量打开有固定相同密码的word文档
myPas = InputBox("请输入打开密码:")With Application.FileSearch .LookIn = myPath .FileType = msoFileTypeWordDocuments If .Execute > 0 Then For i = 1 To .FoundFiles.Count Set myDoc = Documents.Open(FileName:=.FoundFiles(i), Passworddocument:=myPas)Next End If End With Appl...

word中使用VBword中使用vba复制粘贴的所有方法
1.安装word 2.在VB开发环境里引入Office Word对象 3.在按钮中用CreateObject或New来产生一个word对象 4.调用该对象,直接实现替换等操作 5.如果不知道用什么语句,可以用word里的宏编辑器记录所进行的操作,把生成的vbA代码拷贝到vb环境中即可

word中使用VB
在Word中使用VB,可运行此宏:Sub中文字符前面都加Tab()宏代码如下:Dim Ch As String z = ActiveDocument.Characters.Count For s = z - 1 To 0 Step -1 E = s + 1 ActiveDocument.Range(Start:=s, End:=E).Select Ch = Selection chw = AscW(Ch)If chw 19967 And chw < 40705 ...

vb可以做一个根据不同情况自动修改Word文档的东西吗?
若需修改已存在的Word文档,VB也具备这一能力。这里的关键在于通过VB操作Word文档对象,进行内容更新、格式调整或添加新的元素。实现过程包括创建VB应用程序对象、指定其可见性并初始化一个新文档。随后,开发者可以编程实现添加文本、插入图表、应用样式等操作,以适应不同情况下的文档调整需求。另外值得注意...

WORD文档忘记密码肿么办?
http:\/\/www.hanzify.org\/index.php?Go=Show::List&ID=8444 就可以把office文档的密码很快找回来。就拿一个DOC文档做个演习。1、安装上AOPR后,启动它,点击“FileName”右侧的打开文件夹图标,选择需要进行破解的文件。2、“Type of attack”就使用默认的“Bruteforce attack”,然后是设置密码的长度...

相似回答