1

我正在研究像软件(.bat 文件)这样的蛮力攻击,它将尝试使用一些预定义的密码提取文件。我的算法是这样的: -

"C:\Program Files\WinRAR\WinRAR.exe" x -inul -ppassword1 "path to my rar file" 
if %ERRORLEVEL% GEQ 1 GOTO try2
GOTO exit

:try2
"C:\Program Files\WinRAR\WinRAR.exe" x -inul -ppassword2 "path to my rar file" 
if %ERRORLEVEL% GEQ 1 GOTO try3
GOTO exit

:try3
"C:\Program Files\WinRAR\WinRAR.exe" x -inul -ppassword3 "path to my rar file" 
if %ERRORLEVEL% GEQ 1 GOTO try4
GOTO exit

像这样。在 10% 的情况下,一切都按照我的预期工作。

在正常情况下,即手动提取(不是用我的软件),我发现:即使密码错误,某些 rar 文件也会开始提取,当提取即将完成时,它会显示错误消息“文件损坏或密码错误” 。在这种情况下,我的软件面临一个很大的问题 => 它会多次提取同一个文件,因为 ERRORLEVEL 为 0(直到提取即将完成)。有没有办法修改这样的 rar 文件,这样它就不会以错误的密码开始提取。或者,在提取开始时检测错误代码的任何方法(不在提取结束时)。

4

1 回答 1

2

我无法帮助您解决 WinRAR 问题,但我可以帮助您解决 Batch 方法:

@echo off
setlocal EnableDelayedExpansion

for %%p in (password1 password2 ... passwordEtc
            passwordN passwordM) do (
   "C:\Program Files\WinRAR\WinRAR.exe" x -inul -p%%p "path to my rar file" 
   if !ERRORLEVEL! EQU 0 GOTO exit
)
echo Unable to extract after tried all paswords...
于 2014-01-14T17:51:39.997 回答