EXCEL VBAProject保护密码破解查看见过较详细的操作 下载本文

EXCEL VBA Project密码破解

过程可能有些繁琐,EXCEL工作表保护密码破解 方法:

1\\打开文件

2\\工具---宏----录制新宏---输入名字如:aa 3\\停止录制(这样得到一个空宏) 4\\工具---宏----宏,选aa,点编辑按钮

5\\删除窗口中的所有字符(只有几个),替换为下面的内容:(复制吧) 6\\关闭编辑窗口

7\\工具---宏-----宏,选AllInternalPasswords,运行,确定两次,等2分钟,再确定.OK,没有密码了!! 内容如下:

Public Sub AllInternalPasswords()

' Breaks worksheet and workbook structure passwords. Bob McCormick ' probably originator of base code algorithm modified for coverage

' of workbook structure / windows passwords and for multiple passwords '

' Norman Harker and JE McGimpsey 27-Dec-2002 (Version 1.1) ' Modified 2003-Apr-04 by JEM: All msgs to constants, and ' eliminate one Exit Sub (Version 1.1.1)

' Reveals hashed passwords NOT original passwords Const DBLSPACE As String = vbNewLine & vbNewLine Const AUTHORS As String = DBLSPACE & vbNewLine & _ \ \

Const HEADER As String = \ Const VERSION As String = DBLSPACE & \ Const REPBACK As String = DBLSPACE & \ \

Const ALLCLEAR As String = DBLSPACE & \ \ DBLSPACE & \ DBLSPACE & \

DBLSPACE & \ \ \ \

Const MSGNOPWORDS1 As String = \ \ Const MSGNOPWORDS2 As String = \ \

\

Const MSGTAKETIME As String = \ \

\

\ \

Const MSGPWORDFOUND1 As String = \ \

\ \ \

\ Const MSGPWORDFOUND2 As String = \ \ DBLSPACE & \ \

\ \

Const MSGONLYONE As String = \ \ ALLCLEAR & AUTHORS & VERSION & REPBACK Dim w1 As Worksheet, w2 As Worksheet

Dim i As Integer, j As Integer, k As Integer, l As Integer Dim m As Integer, n As Integer, i1 As Integer, i2 As Integer Dim i3 As Integer, i4 As Integer, i5 As Integer, i6 As Integer Dim PWord1 As String

Dim ShTag As Boolean, WinTag As Boolean

Application.ScreenUpdating = False With ActiveWorkbook

WinTag = .ProtectStructure Or .ProtectWindows End With ShTag = False

For Each w1 In Worksheets

ShTag = ShTag Or w1.ProtectContents Next w1

If Not ShTag And Not WinTag Then

MsgBox MSGNOPWORDS1, vbInformation, HEADER Exit Sub End If

MsgBox MSGTAKETIME, vbInformation, HEADER If Not WinTag Then

MsgBox MSGNOPWORDS2, vbInformation, HEADER Else

On Error Resume Next Do 'dummy do loop

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 With ActiveWorkbook

.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 .ProtectStructure = False And _ .ProtectWindows = False Then

PWord1 = Chr(i) & Chr(j) & Chr(k) & Chr(l) & _ Chr(m) & Chr(i1) & Chr(i2) & Chr(i3) & _ Chr(i4) & Chr(i5) & Chr(i6) & Chr(n)

MsgBox Application.Substitute(MSGPWORDFOUND1, _ \ Exit Do 'Bypass all for...nexts End If End With

Next: Next: Next: Next: Next: Next Next: Next: Next: Next: Next: Next Loop Until True On Error GoTo 0 End If

If WinTag And Not ShTag Then

MsgBox MSGONLYONE, vbInformation, HEADER Exit Sub End If

On Error Resume Next For Each w1 In Worksheets

'Attempt clearance with PWord1 w1.Unprotect PWord1 Next w1

On Error GoTo 0 ShTag = False

For Each w1 In Worksheets

'Checks for all clear ShTag triggered to 1 if not. ShTag = ShTag Or w1.ProtectContents Next w1

If ShTag Then

For Each w1 In Worksheets With w1

If .ProtectContents Then On Error Resume Next Do 'Dummy do loop

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 .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 Not .ProtectContents Then

PWord1 = Chr(i) & Chr(j) & Chr(k) & Chr(l) & _ Chr(m) & Chr(i1) & Chr(i2) & Chr(i3) & _ Chr(i4) & Chr(i5) & Chr(i6) & Chr(n)

MsgBox Application.Substitute(MSGPWORDFOUND2, _ \

'leverage finding Pword by trying on other sheets For Each w2 In Worksheets w2.Unprotect PWord1 Next w2

Exit Do 'Bypass all for...nexts End If

Next: Next: Next: Next: Next: Next Next: Next: Next: Next: Next: Next Loop Until True On Error GoTo 0 End If End With Next w1 End If

MsgBox ALLCLEAR & AUTHORS & VERSION & REPBACK, vbInformation, HEADER End Sub

如何破解VBAProject属性的保护密码 1、打开任一excel文件 2、在宏里粘贴下面的代码 3、运行下面的代码

4、选择需要破解密码的文件 5、点击“打开”

'移除VBA编码保护 Sub MoveProtect() Dim FileName As String

FileName = Application.GetOpenFilename(\文件(*.xls & *.xla&*.xlsx),*.xls;*.xla;*.xlsx\\破解\

If FileName = CStr(False) Then Exit Sub Else

VBAPassword FileName, False End If End Sub

'设置VBA编码保护 Sub SetProtect()

Dim FileName As String

FileName = Application.GetOpenFilename(\文件(*.xls & *.xla&*.xlsx),*.xls;*.xla;*.xlsx\\破解\

If FileName = CStr(False) Then Exit Sub Else

VBAPassword FileName, True End If End Sub

Private Function VBAPassword(FileName As String, Optional Protect As Boolean = False) If Dir(FileName) = \ Exit Function Else

FileCopy FileName, FileName & \ 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 = \

If GetData = \ Next

If CMGs = 0 Then

MsgBox \请先对VBA编码设置一个保护密码...\提示\ Exit Function End If

If Protect = False Then 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 \文件解密成功......\提示\ Else

Dim MMs As String * 5 MMs = \ Put #1, CMGs, MMs

MsgBox \对文件特殊加密成功......\提示\ End If Close #1 End Function

如果你是要破解EXCEL工作表保护密码,请按“EXCEL工作表保护密码破解”操作,若在录制宏时,要求输入VBAProject密码,请先按后面的“如何破解VBAProject属性的保护密码”破解VBAProject密码,然后再按“EXCEL工作表保护密码破解”操作即可。

如果你是要破解VBAProject属性的保护密码,请直接按后面的“如何破解VBAProject属性的保护密码”的步骤操作。