【问题标题】:JSSIP WebRTC phone auto disconnect after 30 secondJSSIP WebRTC 电话 30 秒后自动断开连接
【发布时间】:2023-03-04 04:22:02
【问题描述】:

我已将JSSIPhttp://tryit.jssip.net/ 电话嵌入到我们的应用程序中,它使用Freeswitch 进行呼叫,除了呼叫之外的所有单词在 30 秒左右后断开连接,在浏览器 JS 控制台日志中我们看到如下,

Freeswitch 一侧,我看到来自JSSIP 电话的re-INVITE,当前Freeswitch 配置为bypass_media=true 模式。

JS控制台登录浏览器:

JsSIP:InviteServerTransaction Timer L expired for transaction z9hG4bK9mjrH9cZ6FHtK +30s
jssip.js:21403 JsSIP:Transport received WebSocket text message:

BYE sip:50hn96ps@h1bf3jcld769.invalid;transport=ws SIP/2.0
Via: SIP/2.0/WSS 10.20.20.212:7443;branch=z9hG4bKDSQUrNgDUKa5H
Max-Forwards: 70
From: "Satish" <sip:1003@10.20.20.212>;tag=6aQ2K8U19X09j
To: <sip:50hn96ps@h1bf3jcld769.invalid;transport=ws>;tag=5vuctmpuh3
Call-ID: 07a9b5e7-7d8e-1233-c2bf-2a1507b53463
CSeq: 75946179 BYE
User-Agent: FreeSWITCH-mod_sofia/1.4.18-3-1~64bit
Allow: INVITE, ACK, BYE, CANCEL, OPTIONS, MESSAGE, INFO, UPDATE, REGISTER, REFER, NOTIFY, PUBLISH, SUBSCRIBE
Supported: timer, path, replaces
Reason: Q.850;cause=96;text="MANDATORY_IE_MISSING"
Content-Length: 0


 +29s
jssip.js:21403 JsSIP:RTCSession receiveRequest() +12ms
jssip.js:21403 JsSIP:Transport sending WebSocket message:

SIP/2.0 200 OK
Via: SIP/2.0/WSS 10.20.20.212:7443;branch=z9hG4bKDSQUrNgDUKa5H
To: <sip:50hn96ps@h1bf3jcld769.invalid;transport=ws>;tag=5vuctmpuh3
From: "Satish" <sip:1003@10.20.20.212>;tag=6aQ2K8U19X09j
Call-ID: 07a9b5e7-7d8e-1233-c2bf-2a1507b53463
CSeq: 75946179 BYE
Supported: outbound
Content-Length: 0


 +0ms
jssip.js:21403 JsSIP:RTCSession session ended +1ms
jssip.js:21403 JsSIP:RTCSession close() +0ms
jssip.js:21403 rtcninja:RTCPeerConnection close() +0ms
jssip.js:21403 JsSIP:RTCSession close() | closing local MediaStream +7ms
jssip.js:21403 rtcninja:Adapter closeMediaStream() | calling stop() on all the MediaStreamTrack +1ms
jssip.js:21403 JsSIP:Dialog dialog 07a9b5e7-7d8e-1233-c2bf-2a1507b534635vuctmpuh36aQ2K8U19X09j deleted +1ms
jssip.js:21403 JsSIP:NonInviteServerTransaction Timer J expired for transaction z9hG4bKDSQUrNgDUKa5H +2ms
jssip.js:21403 rtcninja:RTCPeerConnection oniceconnectionstatechange() | iceConnectionState: closed +0ms
jssip.js:21403 rtcninja:RTCPeerConnection onsignalingstatechange() | signalingState: closed +1ms

更新:以上问题仅适用于 JSSIP 电话,它适用于 http://sipml5.org/ Webphone。

【问题讨论】:

    标签: javascript webrtc voip freeswitch jssip


    【解决方案1】:

    对于手机这是正常的,这可能是非活动应用的操作系统限制。

    对于 iOS 应用,网络活动超时约为 30 秒。以后这个app网络请求就不会发送了。

    对于 Android 应用,网络活动超时约为 30 秒到 3 分钟。

    但请注意关于WebRTC Communications Consent:

    实施必须至少每 30 次验证持续同意 秒

    【讨论】:

    • 正常是​​什么意思?所以 WebRTC 手机的续航时间永远不会超过 30 秒?
    • 为什么JSSIP电话在通话时发送re-INVITE?
    猜你喜欢
    • 2011-01-05
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多