socks5 mysql认证_socks5身份验证

上一篇,socks5简介的握手阶段,忽略了身份验证流程,这里来补充一下

身份验证方法选择

重现客户端发出第一帧:

+----+----------+----------+

|VER | NMETHODS | METHODS |

+----+----------+----------+

| 1 | 1 | 1 to 255 |

+----+----------+----------+

NMETHODS代表客户端支持的身份验证方法数量,METHODS代表客户端支持的身份验证方法,有多种:0x01:GSSAPI,0x02:账号密码认证。比如客户端只支持GSSAPI和账号密码认证两种方法,这里发送的数据就会是 0x05 0x02 0x01 0x02

代理服收到后,会回应

+----+--------+

|VER | METHOD |

+----+--------+

| 1 | 1 |

+----+--------+

常见METHOD:

0x00,代表不用身份验证的,即此代理服务任何人都可连接,客户端收到此回应直接进入“准备代理”阶段,不用走身份验证流程了

0xff,代表需要身份验证且无可用的验证方法,这时就算握手失败了,关闭连接

0x01,代表需要身份验证,验证方法为GSSAPI

0x02,代表需要身份验证,验证方法为账号密码方式

身份验证

这里假设客户端收到的是0x05 0x02,即账号密码验证方式

客户端立即发出账号密码验证方式的身份验证帧:

+----+------+----------+------+----------+

|VER | ULEN | UNAME | PLEN | PASSWD |

+----+------+----------+------+----------+

| 1 | 1 | 1 to 255 | 1 | 1 to 255 |

+----+------+----------+------+----------+

ULEN:账号长度 UNAME:账号 PLEN:密码长度 PASSWD:密码

代理服解出账号名和密码,进行验证,作出回应

+----+--------+

|VER | STATUS |

+----+--------+

| 1 | 1 |

+----+--------+

STATUS是0x00,代表验证成功,非0x00,代表鉴权失败,必须关闭连接

说明

引用

有疑问加站长微信联系(非本文作者)

5c5fbae790ec0313d6ee17e8b3dd9ba1.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值