FreeSWITCH 简单图形化界面52 - 拨号应用 Answer 介绍
- [00、 一个fs的web配置界面预览](#00、 一个fs的web配置界面预览)
- [01、 Web 配置界面预览](#01、 Web 配置界面预览)
- [02、 Web界面安装参考](#02、 Web界面安装参考)
- [FreeSWITCH 核心应用详解:mod_dptools: answer](#FreeSWITCH 核心应用详解:mod_dptools: answer)
-
- [1. 核心概念](#1. 核心概念)
-
- [1.1 什么是 Answer?](#1.1 什么是 Answer?)
- [1.2 为什么要显式 Answer?](#1.2 为什么要显式 Answer?)
- [2. 基本语法](#2. 基本语法)
- [3. 常见应用场景](#3. 常见应用场景)
-
- [3.1 播放音频或提示音](#3.1 播放音频或提示音)
- [3.2 构建 IVR 菜单](#3.2 构建 IVR 菜单)
00、 一个fs的web配置界面预览
对于需要通过图形化界面管理 FreeSWITCH 的场景,可直接访问以下 Web 配置界面。
01、 Web 配置界面预览
| 界面地址 | 备用地址 | 登录信息 |
|---|---|---|
| http://www.fspbx.cn/ | http://myfs.f3322.net:8020/ | 用户名:admin密码:admin |
02、 Web界面安装参考
若需自行部署 FreeSWITCH 图形化界面,包含 Docker、脚本、ISO 镜像三种安装方式,适配不同系统环境:
- 安装指南地址:https://blog.csdn.net/jia198810/article/details/137820796
- 核心安装方式概览:
- Docker 安装:快速部署;
- 脚本安装:适配 Almalinux、RockyLinux、Debian、Ubuntu 、欧拉等系统,提供一键安装命令,安装后需重启初始化;
- ISO 镜像安装:基于 Almalinux制作的镜像,刻录到 U 盘或光盘后可自动安装,适合全新服务器部署。
FreeSWITCH 核心应用详解:mod_dptools: answer
在 FreeSWITCH 的 Dialplan(拨号计划)中,answer 是一个看似简单,实则至关重要的应用。它的主要作用是将当前的通话通道(Call Leg)状态从"振铃(Ringing)"或"早期媒体(Early Media)"切换到"已接通(Answered)"状态。
本文将详细解析 answer 的用法、使用场景以及它对后续操作(如 bridge)的影响。
1. 核心概念
1.1 什么是 Answer?
当一个呼叫进入 FreeSWITCH 时,默认情况下,FreeSWITCH 只是接收了 INVITE 请求并返回 180 Ringing(振铃),但并没有真正"接通"这个呼叫。
执行 answer 应用,意味着 FreeSWITCH 向主叫方发送 200 OK 响应。这标志着 SIP 信令层面的通话建立完成,同时也开启了 双向媒体流(Duplex Audio) 通道。
1.2 为什么要显式 Answer?
很多初学者会疑惑:"我直接 bridge 不就行了吗?为什么要先 answer?"
虽然 bridge 应用内部会自动处理 B-Leg 的 Answer,但在以下情况中,必须 先执行 answer:
- 播放音频/提示音: 如果您需要在桥接之前向主叫方播放欢迎语、IVR 菜单或音乐,必须先 Answer。否则,RTP 通道未建立,主叫方听不到任何声音。
- 接收 DTMF: 任何需要用户按键(如
read或ivr应用)的操作,都必须在 Answer 之后进行。 - 执行特定逻辑: 某些应用或脚本需要通道处于"已接通"状态才能正常工作。
2. 基本语法
answer 应用非常简单,通常不需要任何参数。
xml
<action application="answer"/>
3. 常见应用场景
3.1 播放音频或提示音
这是最常见的场景。在播放文件之前,必须先接通呼叫。
示例:播放测试音
xml
<extension name="play_tone">
<condition field="destination_number" expression="^1234$">
<action application="log" data="INFO Playing test tone..."/>
<action application="answer"/> <!-- 关键步骤:接通呼叫 -->
<action application="sleep" data="1000"/> <!-- 等待 1 秒 -->
<!-- 播放 1004Hz 的测试音 -->
<action application="playback" data="tone_stream://v=-6;%(10000,100,1004);loops=1"/>
<action application="hangup"/> <!-- 播放完毕挂断 -->
</condition>
</extension>
3.2 构建 IVR 菜单
在进入 IVR 流程前,必须 Answer 以确保用户能听到语音提示并按键。
示例:简单的 IVR 入口
xml
<extension name="enter_ivr">
<condition field="destination_number" expression="^5555$">
<action application="answer"/>
<action application="playback" data="ivr/ivr-welcome_to_freeswitch.wav"/>
<action application="ivr" data="my_ivr_menu"/>
</condition>
</extension>
💗 2026年
🐂 祝君成功,好运连连,牛气冲天