我使用wireshark将以下SIP INVITE数据报从Linphone转储到一个具有CR-LF换行符的文件:
INVITE sip:1002@172.16.76.21 SIP/2.0
Via: SIP/2.0/UDP 172.16.76.21:5060;rport;branch=z9hG4bK1936726928
From: <sip:1555@172.16.76.21>;tag=1350138383
To: <sip:1002@172.16.76.21>
Call-ID: 1393698667
CSeq: 20 INVITE
Contact: <sip:1555@172.16.76.20>
Content-Type: application/sdp
Allow: INVITE, ACK, CANCEL, OPTIONS, BYE, REFER, NOTIFY, MESSAGE, SUBSCRIBE, INFO
Max-Forwards: 70
User-Agent: Linphone/3.5.2 (eXosip2/3.6.0)
Subject: Phone call
Content-Length: 205
v=0
o=1555 1125 1125 IN IP4 172.16.76.21
s=Talk
c=IN IP4 172.16.76.21
t=0 0
m=audio 7078 RTP/AVP 8 0 101
a=rtpmap:8 PCMA/8000
a=rtpmap:0 PCMU/8000
a=rtpmap:101 telephone-event/8000
a=fmtp:101 0-11
我写了一个简单的Python脚本,它读取二进制文件,放入UDP数据报,并通过绑定到端口5060的套接字发送。当我把这个发送到运行用户代理的客户端时,我得到200 OK。当我试图把它发送到我们的SIP代理FreeSwitch时,我收到400 Bad Session Description。
当此消息最初由Linphone发送时,FreeSwitch的响应为200 OK。
显然FreeSwitch不能容忍他们。
这不是FreeSwitch的问题。正如@Stanislav在评论中所说,你的"内容长度"值是错误的。您的会话描述必须为"内容长度:213"。
这些行中的大多数都有额外的尾随空格。显然FreeSwitch不能容忍他们。删除尾部空间有效。
内容长度也是错误的。应该是213。