我使用Jain Sip遇到了一个奇怪的问题(今天下载版本Jain-sip-ri-1.2.2014.jar) . 我正在连接到PBX,用它做一些uaCSTA的东西 . Connection工作正常我也可以执行MakeCall命令等但是经过一段时间(~20分钟)后,Jain Sip Stack似乎不再调用processRequest方法了 . 似乎会话过期或ReInvites之间的超时并不重要 .
我跟踪了Wireshark的所有通信,所以我知道有一个请求 .
沟通是这样的 .
1. me -> PBX Request: INVITE sip:xxx CSTA RequestSystemStatus
2. me <- PBX Status: 100 Trying
3. me <- PBX Status: 200 Ok CSTA RequestSystemStatusResponse Normal
4. me -> PBX ACK sip:xxx
5. me -> PBX Request: INFO sip:xxx CSTA MonitorStart
6. me <- PBX Status: 200 Ok CSTA MonitorStartResponse
到现在一切都很好 . 经过一段时间后,我称之为监控设备(电话),因此集团电话将生成一个DeliveredEvent .
x. me <- PBX Request: INFO sip:xxx DeliveredEvent
此消息发送11次,然后发送11个消息
x. me <- PBX Request: BYE sip:xxx
那么为什么不调用processRequest方法呢?如果您需要更多信息来帮助我解决问题,请随时提出 .
1 回答
经过几个小时的调试,我终于找到了问题 . Windows防火墙阻止了UDP . UPD出现在我的Wire Shark Trace中,但从未被我的应用程序的Socket接收 .
发送UDP后,基础Internet协议等待响应,因为它是UDP,没有响应 . 但防火墙保持打开状态,直到IP生存时间到期 . 这就是它工作64秒的原因 .