46 lines
No EOL
1.3 KiB
Perl
Executable file
46 lines
No EOL
1.3 KiB
Perl
Executable file
source: https://www.securityfocus.com/bid/7169/info
|
|
|
|
A weakness has been reported in the encryption scheme used by ProtWare HTML Guardian. Specifically, the encryption scheme implemented obfuscates data using a simple bit shifting technique, making it trivial for attackers to reverse.
|
|
|
|
Administrators may be relying on a false sense of security by implementing the protection supplied by HTML Guardian.
|
|
|
|
Although it has not been confirmed, it is possible that this issue affects the latest release of HTML Guardian. Earlier versions may also be affected.
|
|
|
|
#!/usr/bin/perl
|
|
#
|
|
# Written by rain_song
|
|
#
|
|
# input file should only contain the main "encrypted" string, which is the 2nd
|
|
# javascript variable in the HTML source code.
|
|
#
|
|
|
|
if( $#ARGV != 0 )
|
|
{
|
|
print "\nWritten by rain_song";
|
|
print "\nUsage: $0 input_file\n";
|
|
print "\tinput_file should only contain 2nd JS variable of HTML page (it\n";
|
|
print "\t is the biggest variable)\n\n";
|
|
exit( 0 );
|
|
}
|
|
|
|
open( INPUT, "<$ARGV[0]" ) or die;
|
|
|
|
$encrypted = <INPUT>;
|
|
close( INPUT );
|
|
$length = length($encrypted);
|
|
|
|
$string1 = substr( $encrypted, 0, $length/2 );
|
|
$string2 = substr( $encrypted, $length/2, $length-1 );
|
|
|
|
$i = 0;
|
|
while( $i < length($string1) )
|
|
{
|
|
$decrypted .= substr( $string1, $i, 1 ) . substr( $string2, $i, 1 );
|
|
$i++;
|
|
}
|
|
|
|
$decrypted =~ s/\\/\@\@/g;
|
|
$decrypted =~ s/\'/\`/g;
|
|
$decrypted =~ s/qg/\r\n/g;
|
|
|
|
print $decrypted; |