1. 將對應的excel 另存為excel97-2003工作簿(*.xls),假設另存后的文件名為【目標.xls】
2.關閉 【目標.xls】文件,一定要關閉
3. 新建一個excel文件,進入VBA編輯器界面,輸入下方的代碼:
Private Sub VBAPassword() '你要解保護的Excel文件路徑 Filename = Application.GetOpenFilename("Excel文件(*.xls & *.xla & *.xlt),*.xls;*.xla;*.xlt", , "VBA破解") If Dir(Filename) = "" Then MsgBox "沒找到相關文件,清重新設置。" Exit Sub Else FileCopy Filename, Filename & ".bak" '備份文件。 End If Dim GetData As String * 5 Open Filename For Binary As #1 Dim CMGs As Long Dim DPBo As Long For i = 1 To LOF(1) Get #1, i, GetData If GetData = "CMG=""" Then CMGs = i If GetData = "[Host" Then DPBo = i - 2: Exit For Next If CMGs = 0 Then MsgBox "請先對VBA編碼設置一個保護密碼...", 32, "提示" Exit Sub End If Dim St As String * 2 Dim s20 As String * 1 '取得一個0D0A十六進制字串 Get #1, CMGs - 2, St '取得一個20十六制字串 Get #1, DPBo + 16, s20 '替換加密部份機碼 For i = CMGs To DPBo Step 2 Put #1, i, St Next '加入不配對符號 If (DPBo - CMGs) Mod 2 <> 0 Then Put #1, DPBo + 1, s20 End If MsgBox "文件解密成功......", 32, "提示" Close #1 End Sub
3.運行上述代碼,會彈出文件選擇框,選擇【目標.xls】文件,等待一會兒,如果提示文件解密成功,則破解成功。
4.關閉這個新建的excel文件,去打開【目標.xls】文件,發現可以查看excel的VBA源代碼了