一、问题现象
在 FreeSWITCH 的 Python 脚本开发场景中,执行 bridge桥接通话之前,开发人员通常会通过 session\.execute\(\&\#34;set\&\#34;, \&\#34;ringback=/path/to/ringing\.wav\&\#34;\) 指令配置自定义回铃音。
实际运行中出现异常问题:被叫方已经接听电话,主叫方依旧持续听到振铃音,延迟数秒后振铃音才会自动消失,影响通话体验,不符合正常通话交互逻辑。
二、根本原因分析
很多开发者误以为设置 ringback 变量后,系统会自动跟随通话状态启停振铃音,实际原理并非如此:
单纯配置 ringback 通道变量,仅作用是告知 FreeSWITCH:呼叫处于振铃阶段时,播放指定音频文件。该变量只负责启动振铃音,没有自动停止的逻辑。
FreeSWITCH 默认不会主动监测被叫接听状态、不会自动切断振铃音。若无额外配置,振铃音频会按照本地播放逻辑执行,直到音频播放完毕,这就造成了被叫接听后,主叫仍能听到几秒振铃音的bug。
三、专业解决方案
在 bridge 桥接指令的通道变量中,添加 execute\_on\_media=stop\_ringback 配置。
配置原理
execute\_on\_media 是媒体触发指令,当系统检测到被叫方返回媒体流(SIP 200 OK 携带SDP信息,代表被叫已接听),会自动执行 stop\_ringback 命令,强制终止回铃音播放,做到接听瞬间切断振铃,无延迟、无杂音。
四、正确代码示例(拨号计划)
优化后可用配置
xml
<action application="bridge" data="{execute_on_media=stop_ringback}sofia/internal/10086@proxy"/>
五、开发避坑关键点
-
ringback 权责划分:仅控制振铃音开始播放,无自动停止逻辑,必须搭配停止指令使用;
-
组合指令用法 :
execute\_on\_media+stop\_ringback是官方最优组合,依靠媒体流检测实现精准启停; -
禁止错误写法 :不要在Python ESL脚本中使用
playback模拟振铃,该方式无法识别被叫接听状态,必然出现振铃残留问题。
六、总结
在FreeSWITCH桥接通话场景下,自定义回铃音出现接听后振铃残留,核心问题是缺少媒体触发停止机制。只需在bridge通道变量中加入execute\_on\_media=stop\_ringback,即可监听被叫媒体流、瞬时停止振铃,完美解决该兼容性问题。该方案适配Python ESL脚本、拨号计划等全部FreeSWITCH开发场景,简单稳定、无额外性能消耗。
标签:FreeSWITCH、振铃控制、stop_ringback、桥接、媒体检测、execute_on_media、Python ESL
本文转载自:原文链接:技术分享