背景
(1)使用webrtc作为音视频处理引擎
(2)sip作为信令传递sdp
(3)复用原来webrtc原来的接口和流程
(4)以webrtc加sip的方式实现voip终端功能
兼容方案需要解决的问题点
- rtp和rtcp端口复用
sip通常是rtp和rtcp端口分开,并且rtcp端口号是在rtp上加一。而webrtc两者默认是复用的,为了兼容需要独立开来
- sdp兼容
webrtc生成的sdp很多信息是sip终端无法识别的,需要删除或者替换,如:c=IN IP4 0.0.0.0中的IP地址需要替换成设备实际的地址
- stun ping
webrtc会进行连通性检查即发生stun ping,如果对方没有回复默认连接不可用,无法建立P2P连接
- dtls功能
sip终端不支持dtls功能,需要禁用
- savp
关闭DTLS功能默认使用savp,对应的源码如下:
SetSdesPolicy(dtls_enabled ? cricket::SEC_DISABLED : cricket::SEC_ENABLED); 兼容需要关闭该功能
- ICE框架相关问题
webrtc默认使用ice框架,sdp中会包含candidate、ice-ufrag、ice-pwd。candidate包含P2P连接信息,必不可少,但是sip终端不是所有都支持,需要做兼容处理,处理方法为:不包含candidate则主动添加, ice-ufrag和ice-pwd同理
其他坑:
webrtc的接口不能调用多次,但是拨号是可以连续点击多次的,这点需要加保护,比如说加个状态机非忙状态下才可以拨号