Excel密碼保護的解除方法與解除原理

Excel密碼保護的解除方法與解除原理

來源:天極網 發佈時間:2009-07-27 [評論 ]

[an error occurred while processing this directive]

 

  Excel彈出“您試圖更改的單元格或圖表受保護,因而是隻讀的。若要修改受保護單元格或圖表,請先使用‘撤消工作表保護’命令(在‘審閱’選項卡的‘更改’組中)來取消保護。可能會提示您輸入密碼。”窗口,如圖1。

  出現這種情況,應該怎麼解決呢?經過研究,找到了兩種破解Excel工作表保護碼的方法。

  一、VBA宏代碼破解法:

  第一步:打開該文件,先解除默認的“宏禁用”狀態,方法是點擊工具欄下的“選項”狀態按鈕,打開“Microsoft Office安全選項”窗口,選擇其中的“啓用此內容”,“確定”退出(圖2);

  再切換到“視圖”選項卡,點擊“宏”→“錄製宏”,出現“錄製新宏”窗口,在“宏名”定義一個名稱爲:PasswordBreaker(圖3),點擊“確定”退出;

  第二步:再點擊“宏”→“查看宏”,選擇“宏名”下的“PasswordBreaker”並點擊“編輯”,打開“Microsoft Visual Basic”編輯器,用如下內容替換右側窗口中的所有代碼:

  Sub PasswordBreaker()
  Dim i As Integer, j As Integer, k As Integer
  Dim l As Integer, m As Integer, n As Integer
  Dim i1 As Integer, i2 As Integer, i3 As Integer
  Dim i4 As Integer, i5 As Integer, i6 As Integer
  On Error Resume Next
  For i = 65 To 66: For j = 65 To 66: For k = 65 To 66
  For l = 65 To 66: For m = 65 To 66: For i1 = 65 To 66
  For i2 = 65 To 66: For i3 = 65 To 66: For i4 = 65 To 66
  For i5 = 65 To 66: For i6 = 65 To 66: For n = 32 To 126
  ActiveSheet.Unprotect Chr(i) & Chr(j) & Chr(k) & _
  Chr(l) & Chr(m) & Chr(i1) & Chr(i2) & Chr(i3) & _
  Chr(i4) & Chr(i5) & Chr(i6) & Chr(n)
  If ActiveSheet.ProtectContents = False Then
  MsgBox "One usable password is " & Chr(i) & Chr(j) & _
  Chr(k) & Chr(l) & Chr(m) & Chr(i1) & Chr(i2) & _
  Chr(i3) & Chr(i4) & Chr(i5) & Chr(i6) & Chr(n)
  ActiveWorkbook.Sheets(1).Select
  Range("a1").FormulaR1C1 = Chr(i) & Chr(j) & _
  Chr(k) & Chr(l) & Chr(m) & Chr(i1) & Chr(i2) & _
  Chr(i3) & Chr(i4) & Chr(i5) & Chr(i6) & Chr(n)
  Exit Sub
  End If
  Next: Next: Next: Next: Next: Next
  Next: Next: Next: Next: Next: Next
  End Sub

  第三步:再點擊“宏”→“查看宏”,選擇“宏名”下的“PasswordBreaker”並點擊“執行”,密碼就現形了(圖4)。

  第四步:切換“審閱”選項卡,點擊“撤消工作表保護”,然後輸入密碼即可解除鎖定。

二、軟件破解法

  有許多專門爲破解Excel各種密碼而製作的軟件,Excel Key與Advanced Office Password Recovery就是其中的佼佼者。它們的使用方法簡單且破解速度極快。

  1. Excel Key

  下載(下載地址:http://www.mydown.com/soft/183/183131.html)安裝完後運行軟件,點擊工具欄“Recovery”按鈕,找到要破解的文件,軟件馬上就可以解出密碼了(圖5)。

  2. Advanced Office Password Recovery

  下載(下載地址:http://www.mydown.com/soft/utilitie/security/268 /410768.shtml)安裝完後運行軟件,點擊工具欄“Open File”按鈕,打開要破解的Excel文件,馬上就可以看到解出的密碼了(圖6)。

點擊放大此圖片

  可以看出,用以上方法讀出的密碼完全不同,但它們確實均可以解除該工作表的密碼保護,這實在是個有趣的問題。

  在網上查找了許久,終於找到比較圓滿的解釋答案:

  當Excel工作表採用密碼保護時,就會生成一個16位(雙字節)長hash值。當輸入密碼進行驗證時,真正進行比較的就是這個hash值。事實上,有很多不同的密碼都可以生成同樣的hash值。

  大家可以試試:

  當你用“test”(不含雙引號)作爲Excel工作表保護密碼,你同樣可以用“zzyw”(同樣不含雙引號)這個密碼進行解鎖。怎麼樣,神奇吧?

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章