EXCEL工做表保护密码破解 宏撤销保护图文教程

今天获得一个任务,是破解一个excel工做表的保护密码。我觉的网上的教程都挺好的,主要一点是注意excel中没有工具这一栏,须要本身去寻找出相关项。html


用到的教程以下:
安全

添加相关工具项ide

点击excel最左上角的标志(花)——最下方的excel选项——自定义——选择开发工具项——添加须要的工具项如宏安全性、查看宏、录制宏、visual basic——点击肯定。工具

能够看到须要的工具项都已经在左上角出现了。oop


170832226.jpg

170834391.jpg


设置好工具栏宏,须要启用宏。开发工具

而后就下面就是按照教程来一步步操做便可。加密


1新建宏 录制新宏随便输入个名字如hong 点击“肯定”按钮url

171120428.jpg

171122206.jpg



2点击“中止录制”按钮或从菜单“中止录制”宏
spa

171224104.jpg


3选择刚才所建的宏而后点击“编辑”按钮,会弹出代码编写窗口3d

171403276.jpg


4填写代码将下面的代码所有复制必替换原来的字符,填写完毕后关闭该窗口

//这里十分感谢原做者,由于经实践,确实好用。

Public Sub 工做表保护密码破解()
Const DBLSPACE As String = vbNewLine & vbNewLine
Const AUTHORS As String = DBLSPACE & vbNewLine & _
"做者:圣天"
Const HEADER As String = "工做表保护密码破解"
Const VERSION As String = DBLSPACE & "版本 Version1.1.1"
Const REPBACK As String = DBLSPACE & ""
Const ZHENGLI As String = DBLSPACE &" XXXXXXX"
Const ALLCLEAR As String = DBLSPACE & "该工做簿中的工做表密码保护已所有解除!!" & DBLSPACE & "请记得另保存"_
& DBLSPACE & "注意:不要用在不当地方,要尊重他人的劳动成果!"
Const MSGNOPWORDS1 As String = "该文件工做表中没有加密"
Const MSGNOPWORDS2 As String = "该文件工做表中没有加密2"
Const MSGTAKETIME As String = "解密需花费必定时间,请耐心等候!" & DBLSPACE & "按肯定开始破解!"
Const MSGPWORDFOUND1 As String = "密码从新组合为:"& DBLSPACE & "$$" & DBLSPACE & _
"若是该文件工做表有不一样密码,将搜索下一组密码并修改清除"
Const MSGPWORDFOUND2 As String = "密码从新组合为:"& DBLSPACE & "$$" & DBLSPACE & _
"若是该文件工做表有不一样密码,将搜索下一组密码并解除"
Const MSGONLYONE As String = "确保为惟一的?"
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 InWorksheets
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
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, _
"$$", PWord1), vbInformation, HEADER
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 InWorksheets
'Attempt clearance with PWord1
w1.Unprotect PWord1
Next w1
On Error GoTo 0
ShTag = False
For Each w1 InWorksheets
'Checks for all clear ShTag triggered to 1 if not.
ShTag = ShTag Or w1.ProtectContents
Next w1
If ShTag Then
For Each w1 InWorksheets
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, _
"$$", PWord1), vbInformation, HEADER
'leverage finding Pword by trying on other sheets
For Each w2 InWorksheets
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 & ZHENGLI,vbInformation, HEADER
End Sub



6最后就来执行刚才所建的宏工具-宏-宏点击执行等带小段时间以后就能够看到效果了

171813454.jpg

相关文章
相关标签/搜索