分析freeswitch返回403 Forbidden的原因
扫描二维码
随时随地手机看文章
1、SIP协议的相关知识
403 Forbidden通常表示服务器理解请求,但拒绝执行,常见原因包括认证失败、权限不足、IP地址被阻止等。(最后找到是因为构造的HA2生成的MD5码导致认证失败)2、解析SIP响应
在Go中处理SIP消息需要解析收到的响应,提取相关的头部字段。根据每一个消息头字段逐一排查。如何查看SIP消息的具体内容REGISTER请求的结构,以及服务器返回的401和403响应的各个字段。特别是要注意WWW-Authenticate头中的参数,如realm、nonce、qop等,这些在生成认证响应时非常关键。- 如果qop是"auth",则response = MD5(HA1:nonce:nc:cnonce:qop:HA2)
- 如果qop未指定,则response = MD5(HA1:nonce:HA2)
- qop是"auth",所以需要包括nonce计数器、客户端nonce以及qop值。所以正确的response计算应该包含这些参数
具体实现:
设置过滤器,在过滤器中输入sip进行过滤,找到相关的SIP请求和响应。然后,重点分析401和403响应的细节,比如头部信息、认证参数是否正确。比如nonce、cnonce、nc的值是否符合规范,或者哈希计算是否正确。需要指导他们在Wireshark中对比正常和异常的请求,查看Authorization头中的各个参数是否正确。网络通信问题
Go程序通过UDP发送和接收数据,需要正确读取服务器的响应,并处理可能的超时或网络错误。NAT或防火墙导致的连接问题,虽然返回的是403,但实际可能是服务器没有正确接收到认证请求,或者客户端的Contact地址不可达。这时候需要检查SIP消息中的Via和Contact头部,确认地址和端口是否正确,是否被服务器接受。
3、Wireshark分析403 Forbidden全流程
(1)加载抓包文件
打开Wireshark → File → Open → 选择抓包文件设置显示过滤器(快速定位SIP流量):
sip || udp.port == 5060或者sip
(2)定位关键SIP事务
A.典型403错误流程

B.关键帧分析
- 初始REGISTER请求
Via: SIP/2.0/UDP 192.168.0.0:5060;branch=z9hG4bKd4e5f6a7
Max-Forwards: 70
From: <sip:1000@192.168.0.1>;tag=abcd1234
To: <sip:1000@192.168.0.1>
Call-ID: a1b2c3d4@192.168.0.0
CSeq: 1 REGISTER
Contact: <sip:1000@192.168.0.0:5060;transport=udp>
- 检查要点:
Contact头是否包含正确的客户端地址
CSeq是否从1开始递增
- 401 Unauthorized响应
Via: SIP/2.0/UDP 192.168.0.170:5060;received=192.168.0.170;branch=z9hG4bKd4e5f6a7;rport=5060
WWW-Authenticate: Digest realm="192.168.0.31", nonce="5e8f7g6h", qop="auth", algorithm=MD5
- 确认参数完整性:
algorithm 是否为MD5
- 带认证的REGISTER请求
Authorization: Digest username="1000", realm="192.168.0.31",
nonce="5e8f7g6h", uri="sip:192.168.0.31",
response="d41d8cd98f00b204e9800998ecf8427e",
algorithm=MD5, qop=auth, nc=00000001,
cnonce="d4e5f6a7b8c9d0e1"

- 403 Forbidden响应
nonce、cnonce、nc的值是否符合规范,或者哈希计算是否正确。需要指导他们在Wireshark中对比正常和异常的请求,查看Authorization头中的各个参数是否正确。
- MD5的计算
ha2 := md5Hex(fmt.Sprintf("REGISTER:sip:%s:%d",freeswitchIP,freeswitchPort)))
response := md5Hex(fmt.Sprintf("%s:%s:%s:%s:%s:%s",ha1, nonce, nc, cnonce, "auth", ha2))