密码破译 C++
在网上找的但是超时了,我也不知道这个题目怎么做。#include#define N 1100int len[N];int main() {int i,j,sum,n,s,flag;while(scanf("%d",&n)!=EOF) {scanf("%d",&s);for(i=0;i
word文件打开密码破解三步法
1、用简单的方法:
首先创建一个word文档,使用窗体保护的方式保护文档,工具->保护文档->Check“仅允许在文档中进行此类编辑”->Choose“填写窗体”,此时会弹出一个密码框,输入2次密码(我这里选择123作为word文件密码),这样,该文档就已经被保护起来了。
然我们来破解它,打开刚才创建的word文档,文件->另存为->选择HTML格式,存为一个HTML文档,用记事本打开该HTML文件,搜索"",你会看到5BCEcf7A的字样(如果你的密码是用的123的话)。
接着我们用UltraEdit或其他类似的工具打开最初受保护的Word文档,搜索7ACFCE5B,搜索到后,都用8个0来代替,存盘。
此时的Word文档的密码就被清空了,你就可以自己取消文档保护了,密码就不用输入了,按个回车了事。
2、用编程的方法:
下面来看一看程序的具体编制过程。程序采用VB编程实现,需要机器安装有VB应用程序及MicrosoftOffice组件。打开VB,新建一个VB工程,取名Proc_Word,将启动窗体命名为FrmMain,选择“工程”菜单中的“引用”,在“引用”对话框中选择“MicrosoftWord8.0ObjectLibrary”(这一步很重要,你必须选择这一ActiveX部件,否则代码不能正确运行,顺便说一句,如果安装的是Office2000,那么应该选择“MicrosoftWord9.0ObjectLibrary”)。同时在“工程”菜单中“部件”对话框中选择添加“MicrosoftWindowscommoncontrols-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属性分别设置成“文件打开”、“系统退出”。以上就把各控件的属性设置完了,接着编写代码也就不是什么难事儿了。
下面就是全部的源程序,适当的注释有助于大家理解程序。你还可以通过设置断点来跟踪密码生成部分,看看程序编制的原理。
PrivateSubcmdopendoc_Click()
DimwdAsNewWord.Application
DimstrpathAsString
DimpassAsString
DimJ,K,Pass_longASInteger
DimMax_num,Min_num,IAsLong
strpath=File1.Path&"\"&File1.FileName
OnErrorResumeNext
程序开始
Pass_long=Val(Text2.Text)
Max_num=10^Val(Text2.Text)
Min_num=10^(Val(Text2.Text)-1)
Flag=0
ForK=0ToPass_long-1
Max_num=10^(Pass_long-K)
Min_num=10^(Pass_long-(K+1))
ForJ=0ToPass_long-1
cmdopendoc.MousePointer=11
ForI=IIf(Pass_long-K=1,0,Min_num)+JToMax_numStepPass_long
Text1.Text=pass
Text1.Refresh
pass=String(K,"0")&I
Flag=wd.Documents.Open(FileName:=strpath,passworddocument:=pass)
如果解密成功,打开文档,显示密码,退出过程
IfFlag<>0Then
Label1.Caption="文档密码"
Label1.Refresh
Text1.Text=pass
wd.Visible=True
cmdopendoc.MousePointer=0
ExitSub
EndIf
NextI
NextJ
NextK
MsgBox"密码位数不对,请重新输入"
EndSub
PrivateSubcmdquit_Click()
EndSub
PrivateSubDir1_Change()
File1.Path=Dir1.Path
EndSub
PrivateSubDrive1_Change()
Dir1.Path=Drive1.Drive
EndSub
PrivateSubFile1_DblClick()
Callcmdopendoc_Click
EndSub
几点说明:
需要说明的是,穷举法解密对系统资源的耗用是十分惊人的,在解密的过程中最好不要运行其他应用程序。针对其巨大的资源耗用量,我在程序中采用了一个小技巧,那就是用密码位数作为循环的步长进行刺探。也就是说如果你的密码是3位的话,那么程序将依次尝试100、103、106……997、101、104……998、102、105……999结束,加快了查找密码的速度(东渐:其实大家可以动手算一算,到底是快了许多,还是快了一点,还是根本没有提高速度^_^)。
该程序在Win98/NT+VB6.0环境下测试通过,我只是随便试了一个5位数密码,在PⅡ300、128MB内存的机器上,10分钟左右即可解开。
怎么用VB编写一个破译三位密码的软件
private sub form_load() do dim a as single, b as single, c as single, p as single, s as single a = val(inputbox("请输入三角形第1条边长")) if a = -1 then exit do b = val(inputbox("请输入三角形第2条边长")) if b = -1 then exit do c = val(inputbox("请输入三角形第3条边长")) if c = -1 then exit do p = (a + b + c) / 2 if a >= p or b >= p or c >= p then msgbox "不能构成三角形" else s = sqr(p * (p - a) * (p - b) * (p - c)) msgbox "面积为" & s end if loop end end sub