基于 Swoole 代理服务器
- HTTP 代理服务器,支持 HTTP/HTTPS,因为本质上是转发,所以上层数据对服务器是透明无感知的
- SOCKS 代理服务器,仅仅实现了SOCKS v5 TCP 无验证版本
- 仅供 swoole 学习之用,不保持稳定性,事实上只是为了实现功能而实现功能,正在整理思路中,欢迎 issue,请不要 PR,代码还在整理之中
- Github 地址
- 码云地址
- 求大神指教 MITM 中间攻击解密 HTTPS 内容
#以下内容来自 README
使用方法
git clone https://github.com/jhasheng/swoole-proxy
cd swoole-proxy
composer dump-autoload
php example/ss.php 启动socks server
php example/proxy.php 启动代理服务器
php example/ws.php 启动websocket server
当前连接数统计
访问地址 http://127.0.0.1:10004
,端口为代理监听端口
特性
HTTP 代理,可独立使用,支持HTTP/HTTPS,可使用二级代理(SOCKS5)
- [x] HTTP 反向代理
- [x] HTTPS 反向代理
- [x] 二级代理(SOCKS5,TCP 版,无身份验证版)
- [ ] MITM 中间人攻击,对 HTTPS 数据进行解密,对原理理解的不是很透彻,求高手指点
- [ ] 控制台日志输出优化
- [x] 添加当前链接数图表统计
- [x] 请求收集
http://127.0.0.1:10004/request.html
,需要启用 WebSocket Server
$proxy = new \SS\SwooleProxy();
// 二级代理
$proxy->setSocksServer('0.0.0.0:10005');
$proxy->listen(10004);
SOCKS 代理,可独立使用,TCP代理,介于应用层与传输层之间,不关心应用层使用的何种协议,理论上应用层协议都支持
- [x] SOCKS5 实现,未严格按
rfc1928
文档编写,后期完善 - [ ] UDP 支持,不打算支持
- [ ] 身份验证,后期加入
- [ ] SOCKS4
- [ ] SOCKS4a
- [ ] 数据传输加密
$ss = new \SS\SwooleServer();
$ss->start();
WebSocket Server,用于收集 http 代理请求
$proxy = new \SS\SwooleWebSocket();
$proxy->start();