美文网首页
Sock5代理协议详解

Sock5代理协议详解

作者: 倦飞知还 | 来源:发表于2018-06-14 12:02 被阅读0次

    第一步,客户端请求握手

    1.png
    • ver 代表协议版本占用一个字节 这里肯定是 : 5

    • nmethods 代表下一个字段专用的字节数量 这里不确定

    • methods 代表客户端拥有的加密方式占用1~255个字节都有可能,比如说0 代表不加密 1代表加密 2代表 另一种加密等

    第二步 代理服务器收到握手后返回

    2.png
    • ver 代表协议版本占用一个字节 这里肯定是 : 5
    • method代表代理服务器选择了一种握手方式

    第一步和第二步握手例子

    client --> 5 2 0 2 代表着 版本5 有两种握手方式 加密的和不加密的供代理选择

    proxy--> 5 0 代表着版本5 选择了不加密的协议方式

    或者是

    client--> 5 1 0 只有一种不加密的握手方式

    proxy--> 5 0 选择了不加密的握手方式

    上面的过程就叫做第一步握手连接,client 和proxy之间互相选择连接方式,如果client的所有握手方式proxy都不满足,则直接断开连接就好了

    第三步 客户端发送需要访问的IP和端口,以及协议

    3.png
    • cmd 字段,占用一个字节 1代表 想要tcp连接 3 代表想要udp连接

    • rsv 保留字,默认0

    • atyp 目标网络地址类型:1代表ip4,3代表域名,4代表ip

    • dst.addr 如果上一个字段是1 则这个字段是4位ip4地址

    如果是3 则这个字段第一个字节代表域名长度,紧跟其后的是域名

    如果是6 则这个字段16位ip6地址

    • dst.port 两个字节代表目的地端口

    第四步 代理服务器返回代理建立结果

    4.png
    • rep 代表proxy告诉应用程序处理的情况,0代表处理成功,否则可以直接断开连接了

    第三步和第四步握手举例

    有可能是这样的情况

    client--> 5 1 0 1 123 123 123 123 0 80 表示tcp连接 到123.123.123.123 的80 端口

    proxy-->5 0 0 1 0 0 0 0 0 0 代表着已经连接上了,并且将atype置1代表后面的是ip和端口 ,由于大多客户端的实现都会忽略后面的ip和端口,我们直接全写0

    这样握手就完成了。

    后续

    我们已经拿到了程序想要访问的地址和端口,我们新建一个socket 自己连接到ip和端口,然后一边接受应用程序发的数据,转发给网站,一遍接受网站返回的数据,转发给应用程序,这样达到了让他们俩通信的目的。

    相关文章

      网友评论

          本文标题:Sock5代理协议详解

          本文链接:https://www.haomeiwen.com/subject/lnaeeftx.html