SonicWall TZ210 расшифровывает файл exp

У меня есть файл резервной копии Sonicwall TZ210, но я потерял пароль администратора.

Файл резервной копии.exp, есть ли способ расшифровать его с помощью Windows PC?

2 ответа

Это не полное решение, а начало. В Linux вы можете использовать это для декодирования дампа:

base64 -d your-backup.exp | sed 's/&/\n/g'

Или используйте этот Perl Script:

#!/usr/bin/perl
use strict;
use MIME::Base64;

local($/) = undef; # slurp

my $decoded = decode_base64(<STDIN>);
$decoded =~ s/&/\n/gms;
print $decoded;

Вы найдете строку пароля и, возможно, сможете перебором его с Джоном Потрошителем ( http://www.openwall.com/john/). Здесь нет более легкого пути.

Сценарий PowerShell может декодировать файл в читаемый текст в системе Windows, но, как отмечено в другом ответе, это не относится к расшифровке пароля:

Function SonicWall_Exp2Txt ($Exp)
{
  $Txt = $Exp -ireplace ".exp$", ".txt"
  # Create temporary file names.
  $Tmp = "." + $(get-date -uformat %s) + "."
  $TmpTxt = $Txt -replace ".txt$", $($Tmp + ".txt")
  $TmpExp = $TmpTxt -replace ".txt$", ".exp"
  # Show input/output file names while processing.
  Write-Host $("`n" + $Exp + "`n--> " + $Txt)
  # Remove two "&" characters at the end of an .exp file before decoding it.
  ( Get-Content $Exp ) -replace ".{2}$" |
    Out-File -Encoding default -FilePath $TmpExp
  # certutil.exe -decode /?
  # Usage:
  #   CertUtil [Options] -decode InFile OutFile
  #   Decode Base64-encoded file
  # Note:
  #   certutil.exe aborts if OutFile already exists.
  & certutil.exe -decode $TmpExp $TmpTxt
  # Reformat the decoded file with line breaks to make it more readable.  It
  # is also possible to recode the output file with Out-File -Encoding set
  # to unicode, utf7, utf8, utf32, ascii, bigendianunicode, default, or oem.
  ( Get-Content $TmpTxt ) -replace '\&', "`n" |
    Out-File -Encoding utf8 -FilePath $Txt
  # Remove the temporary files.
  Remove-Item $TmpExp
  Remove-Item $TmpTxt
}

# Get-ChildItem returns a scalar if one .exp file exists or an array if more
# than one .exp file is present.  Force $Files to an array value to avoid
# error if only one file exists as scalars do not have a Count method.
#
$Files = @( Get-ChildItem "." -Filter "*.exp" )
For ($Loop=0; $Loop -lt $Files.Count; $Loop++)
{
  SonicWall_Exp2Txt $Files[$Loop].FullName
}

Пример вызова, когда скрипт сохраняется как exp2txt.ps1:

powershell.exe -NoLogo -ExecutionPolicy bypass -Command exp2txt.ps1 <NUL

Атрибуция: эта тема вдохновила вышеупомянутый скрипт, который был написан для того, чтобы потенциально облегчить выявление различий в файлах сохранения.

Другие вопросы по тегам