佳丽云

英雄无敌3-WoG中文站

 找回密码
 英雄注册|Register
查看: 2480|回复: 0

Excel密码保护的解除方法与解除原理

[复制链接]
  • TA的每日心情
    慵懒
    2017-1-2 15:59
  • 签到天数: 10 天

    连续签到: 1 天

    [LV.3]火元素使者

    714

    回帖

    6万

    金币

    2

    精华

    论坛嘉宾

    黄帝

    Rank: 9Rank: 9Rank: 9

    积分
    2131

    退役版主社区QQ达人

    QQ
    发表于 2007-7-19 23:45:58 | 显示全部楼层 |阅读模式
      Excel弹出“您试图更改的单元格或图表受保护,因而是只读的。若要修改受保护单元格或图表,请先使用‘撤消工作表保护’命令(在‘审阅’选项卡的‘更改’组中)来取消保护。可能会提示您输入密码。”窗口,如图1。<br /><p align="center"><a href="http://soft.yesky.com/TLimages/picview/?/imagelist/2007/199/718k3m35d389.jpg" target="_blank"><img src="http://soft.yesky.com/imagelist/2007/199/718k3m35d389s.jpg" border="0" alt="" /></a></p>  出现这种情况,应该怎么解决呢?经过研究,找到了两种破解Excel工作表保护码的方法。<br /><p align="left"><b>  一、VBA宏代码破解法:</b></p>  第一步:打开该文件,先解除默认的“宏禁用”状态,方法是点击工具栏下的“选项”状态按钮,打开“Microsoft <a href="http://soft.yesky.com/office/" target="_blank">Office</a>安全选项”窗口,选择其中的“启用此内容”,“确定”退出(图2);<br /><p align="center"><a href="http://soft.yesky.com/TLimages/picview/?/imagelist/2007/199/6mh4wa26180a.jpg" target="_blank"><img src="http://soft.yesky.com/imagelist/2007/199/6mh4wa26180as.jpg" border="0" alt="" /></a></p>  再切换到“视图”选项卡,点击“宏”→“录制宏”,出现“录制新宏”窗口,在“宏名”定义一个名称为:PasswordBreaker(图3),点击“确定”退出;<br /><p align="center"><img src="http://soft.yesky.com/imagelist/2007/199/c8904m025h9k.jpg" border="0" alt="" /></p>  第二步:再点击“宏”→“查看宏”,选择“宏名”下的“PasswordBreaker”并点击“编辑”,打开“Microsoft Visual Basic”[wiki]编辑器[/wiki],用如下内容替换右侧窗口中的所有代码:<br />  Sub PasswordBreaker()<br />  Dim i As Integer, j As Integer, k As Integer<br />  Dim l As Integer, m As Integer, n As Integer<br />  Dim i1 As Integer, i2 As Integer, i3 As Integer<br />  Dim i4 As Integer, i5 As Integer, i6 As Integer<br />  On Error Resume Next<br />  For i = 65 To 66: For j = 65 To 66: For k = 65 To 66<br />  For l = 65 To 66: For m = 65 To 66: For i1 = 65 To 66<br />  For i2 = 65 To 66: For i3 = 65 To 66: For i4 = 65 To 66<br />  For i5 = 65 To 66: For i6 = 65 To 66: For n = 32 To 126<br />  ActiveSheet.Unprotect Chr(i) &amp; Chr(j) &amp; Chr(k) &amp; _<br />  Chr(l) &amp; Chr(m) &amp; Chr(i1) &amp; Chr(i2) &amp; Chr(i3) &amp; _<br />  Chr(i4) &amp; Chr(i5) &amp; Chr(i6) &amp; Chr(n)<br />  If ActiveSheet.ProtectContents = False Then<br />  MsgBox &quot;One usable password is &quot; &amp; Chr(i) &amp; Chr(j) &amp; _<br />  Chr(k) &amp; Chr(l) &amp; Chr(m) &amp; Chr(i1) &amp; Chr(i2) &amp; _<br />  Chr(i3) &amp; Chr(i4) &amp; Chr(i5) &amp; Chr(i6) &amp; Chr(n)<br />  ActiveWorkbook.Sheets(1).Select<br />  Range(&quot;a1&quot;).FormulaR1C1 = Chr(i) &amp; Chr(j) &amp; _<br />  Chr(k) &amp; Chr(l) &amp; Chr(m) &amp; Chr(i1) &amp; Chr(i2) &amp; _<br />  Chr(i3) &amp; Chr(i4) &amp; Chr(i5) &amp; Chr(i6) &amp; Chr(n)<br />  Exit Sub<br />  End If<br />  Next: Next: Next: Next: Next: Next<br />  Next: Next: Next: Next: Next: Next<br />  End Sub<br />  第三步:再点击“宏”→“查看宏”,选择“宏名”下的“PasswordBreaker”并点击“执行”,密码就现形了(图4)。<br /><p align="center"><a href="http://soft.yesky.com/TLimages/picview/?/imagelist/2007/199/274itfhvtw1c.jpg" target="_blank"><img src="http://soft.yesky.com/imagelist/2007/199/274itfhvtw1cs.jpg" border="0" alt="" /></a></p>  第四步:切换“审阅”选项卡,点击“撤消工作表保护”,然后输入密码即可解除锁定。<br /><p align="left"><b>  二、软件破解法</b></p>  有许多专门为破解Excel各种密码而制作的软件,Excel Key与Advanced Office Password Recovery就是其中的佼佼者。它们的使用方法简单且破解速度极快。<br />  1. Excel Key<br />  下载(下载地址:<a href="http://www.mydown.com/soft/183/183131.html" target="_blank">http://www.mydown.com/soft/183/183131.html</a>)安装完后运行软件,点击工具栏“Recovery”按钮,找到要破解的文件,软件马上就可以解出密码了(图5)。<br /><p align="center"><img src="http://soft.yesky.com/imagelist/2007/199/qsp8u9q96b7v.jpg" border="0" alt="" /></p>  2. Advanced Office Password Recovery<br />  下载(下载地址:<a href="http://www.mydown.com/soft/utilitie/security/268/410768.shtml" target="_blank">http://www.mydown.com/soft/utilitie/security/268/410768.shtml</a>)安装完后运行软件,点击工具栏“Open File”按钮,打开要破解的Excel文件,马上就可以看到解出的密码了(图6)。<br /><p align="center"><a href="http://soft.yesky.com/TLimages/picview/?/imagelist/2007/199/t302fb2ptu7m.jpg" target="_blank"><img src="http://soft.yesky.com/imagelist/2007/199/t302fb2ptu7ms.jpg" border="0" alt="" /></a></p>  可以看出,用以上方法读出的密码完全不同,但它们确实均可以解除该工作表的密码保护,这实在是个有趣的问题。<br />  在网上查找了许久,终于找到比较圆满的解释答案:<br />  当Excel工作表采用密码保护时,就会生成一个16位(双字节)长hash值。当输入密码进行验证时,真正进行比较的就是这个hash值。事实上,有很多不同的密码都可以生成同样的hash值。<br />  大家可以试试:<br />  当你用“test”(不含双引号)作为Excel工作表保护密码,你同样可以用“zzyw”(同样不含双引号)这个密码进行解锁。怎么样,神奇吧?
    ahome_bigavatar:guest
    ahome_bigavatar:welcomelogin
    您需要登录后才可以回帖 登录 | 英雄注册|Register

    本版积分规则

    捐赠
    关注我们,英3Mod一网打尽!

    WoG中文站 ( 辽B2-20210485-10 )|辽公网安备 21128202000228 号

    GMT+8, 2024-5-15 20:00 , Processed in 0.400958 second(s), 14 queries , Gzip On, File On.

    Powered by Discuz! X3.4

    Copyright © 2004-2022, Beijing Second Sight Technology Co., LTD.

    快速回复 返回顶部 返回列表