reGeorg的工具原理

首先先创建一个socket去运行,去连接想要连接的端口
reGeorgSocksProxy客户端与服务端的通讯是基于session来区分的,并不支持在指定的session下进行
socket_set_nonblock 设置socket为非阻塞
ob_end_clean()时缓冲区内容将被丢弃
socket_write($socket参数1,$msg参数2,$strlen参数3)
    作用:把数据写入套接字中
    返回值:成功返回字符串的字节长度,失败为false
      参数1:socket_create或者socket_accept的函数返回值
    参数2:字符串
    参数3:字符串的长度

![在这里插入图片描述](https://img-blog.csdnimg.cn/20190930075019336.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L1pDTVVDWlg=,size_16,color_FFFFFF,t_70在这里插入图片描述

在这里插入图片描述

建立连接的时候,将进行了socket转发收到的内容进行保存到Session的当中,然后在客户端发起READ的时候,再进行将要返回的保存在Session当中的内容进行输出,可以看到下面是有echo $readbuffer

在这里插入图片描述

最后的php forward功能,是通过php://input来做的,接收数据,然后保存在writebuffer当中

在这里插入图片描述

本地Python的处理方式

处理socket5的方式
客户端发送到socks5代理至少三个字节的请求,第一个字节一定为5
而如果是socks4,则第一个字节一定为4

在这里插入图片描述

第二个字节为使用多少种验证,第三个字节为验证模式代码.
如果要使用"USERNAME/PASSWORD",那么这三个字节为5 1 2,双方如果授权通过之后,就开始建立连接,连接由客户端发起,告诉Socks服务端客户端要访问哪个远程服务器,其中包含,远程服务器的地址和端口,地址可以是IPV4,IPV6,也可以是域名

在这里插入图片描述

代码中就是分版本进行处理socket5还是socket4

在这里插入图片描述

然后解析socket协议之后,进行发包转发

在这里插入图片描述

然后下面进行远程发包

在这里插入图片描述

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值