当前位置:首页 > 通信技术 > 通信技术
[导读]在使用Go语言编写的SIP客户端程序向FreeSWITCH注册时,返回了403 Forbidden错误,但不知道具体原因。如何通过Wireshark分析抓包文件来找出原因。如何通过Wireshark分析SIP流程中的403错误,定位问题所在。

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全流程

分析freeswitch返回403 Forbidden的原因


(1)加载抓包文件

打开Wireshark → File → Open → 选择抓包文件
设置显示过滤器(快速定位SIP流量):
sip || udp.port == 5060或者sip

 (2)定位关键SIP事务

A.典型403错误流程

分析freeswitch返回403 Forbidden的原因


B.关键帧分析

  • 初始REGISTER请求
REGISTER sip:192.168.0.1 SIP/2.0
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>
  • 检查要点:
Via头中的branch参数是否以z9hG4bK开头
Contact头是否包含正确的客户端地址
CSeq是否从1开始递增
  • 401 Unauthorized响应
SIP/2.0 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
  • 确认参数完整性:
realm 是否与FreeSWITCH域名匹配

qop 是否包含auth
algorithm 是否为MD5
  • 带认证的REGISTER请求
   REGISTER sip:192.168.0.31 SIP/2.0
  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"
分析freeswitch返回403 Forbidden的原因

  •  403 Forbidden响应
    是否提取nonce,cnonce的值正确;计算的哈希值是否正确
nonce、cnonce、nc的值是否符合规范,或者哈希计算是否正确。需要指导他们在Wireshark中对比正常和异常的请求,查看Authorization头中的各个参数是否正确。
  • MD5的计算
ha1 := md5Hex(fmt.Sprintf("%s:%s:%s", sipUser,realm, password))
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))

声明:该篇文章为本站原创,未经授权不予转载,侵权必究。
换一批
延伸阅读

LED驱动电源的输入包括高压工频交流(即市电)、低压直流、高压直流、低压高频交流(如电子变压器的输出)等。

关键字: 驱动电源

在工业自动化蓬勃发展的当下,工业电机作为核心动力设备,其驱动电源的性能直接关系到整个系统的稳定性和可靠性。其中,反电动势抑制与过流保护是驱动电源设计中至关重要的两个环节,集成化方案的设计成为提升电机驱动性能的关键。

关键字: 工业电机 驱动电源

LED 驱动电源作为 LED 照明系统的 “心脏”,其稳定性直接决定了整个照明设备的使用寿命。然而,在实际应用中,LED 驱动电源易损坏的问题却十分常见,不仅增加了维护成本,还影响了用户体验。要解决这一问题,需从设计、生...

关键字: 驱动电源 照明系统 散热

根据LED驱动电源的公式,电感内电流波动大小和电感值成反比,输出纹波和输出电容值成反比。所以加大电感值和输出电容值可以减小纹波。

关键字: LED 设计 驱动电源

电动汽车(EV)作为新能源汽车的重要代表,正逐渐成为全球汽车产业的重要发展方向。电动汽车的核心技术之一是电机驱动控制系统,而绝缘栅双极型晶体管(IGBT)作为电机驱动系统中的关键元件,其性能直接影响到电动汽车的动力性能和...

关键字: 电动汽车 新能源 驱动电源

在现代城市建设中,街道及停车场照明作为基础设施的重要组成部分,其质量和效率直接关系到城市的公共安全、居民生活质量和能源利用效率。随着科技的进步,高亮度白光发光二极管(LED)因其独特的优势逐渐取代传统光源,成为大功率区域...

关键字: 发光二极管 驱动电源 LED

LED通用照明设计工程师会遇到许多挑战,如功率密度、功率因数校正(PFC)、空间受限和可靠性等。

关键字: LED 驱动电源 功率因数校正

在LED照明技术日益普及的今天,LED驱动电源的电磁干扰(EMI)问题成为了一个不可忽视的挑战。电磁干扰不仅会影响LED灯具的正常工作,还可能对周围电子设备造成不利影响,甚至引发系统故障。因此,采取有效的硬件措施来解决L...

关键字: LED照明技术 电磁干扰 驱动电源

开关电源具有效率高的特性,而且开关电源的变压器体积比串联稳压型电源的要小得多,电源电路比较整洁,整机重量也有所下降,所以,现在的LED驱动电源

关键字: LED 驱动电源 开关电源

LED驱动电源是把电源供应转换为特定的电压电流以驱动LED发光的电压转换器,通常情况下:LED驱动电源的输入包括高压工频交流(即市电)、低压直流、高压直流、低压高频交流(如电子变压器的输出)等。

关键字: LED 隧道灯 驱动电源
关闭