用磁盘编辑工具打开Access 2000 所建的数据库,在库文件的地址00000042处开始的40个字节是Access 2000库的密码位。如果一个未加密的库,这40个字节原始数据依次为:29 77 EC 37 F2 C8 9C FA 69 D2 28 E6 BC 3A 8A 60 FB 18 7B 36 5A FE DF B1 D8 78 13 43 60 23 B1 33 9B ED 79 5B 3D 39 7C 2A 。当你给数据库设置了密码后,这40个字节就变成了密钥。因此,要破解密码而不需保持原库的密码,只要将00000042 处开始的40个字节还原成原始数据就行了。要做到这一点,你可用磁盘编辑工具或将以下所附的程序稍加修改,把以上所列40个数据填到00000042开始处。
若要由程序中打开,命令如下:Set DB = OpenDatabase(DatabaseName, False, False, "Pwd=密码")实例:Dim db As DatabaseSet db = OpenDatabase("C:\db1.mdb", False, False, "Pwd=1")若要使用 Data 控件,设定方法如下:1、设定 DatabaseName 属性 (MDB文件名称 / 含路径)2、设定 Connect 属性,将预设的字串 "Access" 改成 "Pwd=密码" (不含双引号)3、设定 RecordSource 属性2、使用 ADO 命令打开MDB文件:在使用 ADODC 或 DataEnvironment 设定好之后,直接利用属性窗口修改 ConnectionString 属性(附属于 ADODC) 或 ConnectionSource 属性,修改的方法是在属性之后增加以下参数:Jet OLEDB:Database Password=密码除了ADODC 及 DataEnvironment 之外, 直接使用 ADO 控件来打开含有密码的 mdb MDB文件,设定参数的方法也是相同的。 3、压缩加了密码的MDB文件:CompactDatabase DBEngine.CompactDataBase "原MDB文件", "新MDB文件", , , "pwd=密码"实例例如:DBEngine.CompactDatabase "C:\Db1.mdb", "C:\Db2.mdb", , , "pwd=1" 4、修复加了密码的MDB文件: RepairDatabase 不必理会MDB文件设定的密码!欢迎分享,转载请注明来源:内存溢出
评论列表(0条)