Freeswitch常见问题

2023-07-20 14:17:09 浏览数 (1)

FreeSwitch下配置DID的方法

首先介绍下什么是DID? 翻译为中文为“直接向内拨号”,该服务是由电话公司提供的,它使用户能够直接拨打PBX或VOIP系统中的分机号码,而无需求助于总机或自动话务系统。

现在要实现这样一个功能 - 通过手机或座机拨打一个号码(例如:01088888888),可以直接联系到VOIP系统(FreeSwitch系统)的1008这个用户。如下图所示:

手机/座机 -------------------> 01088888888 ---------------> VOIP系统 ----------------> 1008

分两步实现:

(1) 配置网关

在 confsip_profilesexternal 中添加一个XML文件,名为:gw-DID.xml。内容如下:

代码语言:javascript复制
   <include>
       <gateway name="gw-DID">
           <param name="realm" value="27.54.226.74"/>  // sip         provider 提供的服务器IP
           <param name="username" value="88888888"/>// sip provider 提供的DID账号
           <param name="password" value="12345678"/> // sip provider 提供的DID账号密码
           <param name="proxy" value="27.54.226.74"/>  // sip provider 提供的服务器IP
           <param name="register" value="true"/>
           <param name="expire-seconds" value="600"/>
           <param name="ping" value="30"/>
           <param name="sip-trace" value="true"/>
       </gateway>
   </include>

(2)配置拨码计划

在 confdialplan 中修改 public.xml,添加如下内容:

代码语言:javascript复制
<extension name="sipprovider">
  <condition field="destination_number" expression="^88888888$">
    <action application="transfer" data="1008 XML default"/>
  </condition>
</extension>

通过 FS_CLI 输入 reloadxml 即可。


通过FreeSwitch同时呼叫多个用户

通过FreeSwitch可以对多个终端进行呼叫,依据振铃顺序不同,可以分为:同振 和 顺振 。

同振是指多个终端同时振铃;顺振是指多个终端顺序振铃。

下面实现如下应用, 某用户拨叫 2000 这个接入号码,希望 1000 和 1001 同时振铃,其中任一个接听来话,另一个停止振铃。

(1) 在 confdialplandefault.xml中添加如下内容,

代码语言:javascript复制
<extension name="group_dial_sim">
  <condition field="destination_number" expression="^2000$">
    <action application="bridge" data="sofia/internal/1000@192.168.0.183,sofia/sip/1001@192.68.0.183"/>
  </condition>
</extension>

在 FS_CLI.exe 中运行 reloadxml 即可。

下面实现如下应用, 某用户拨叫 2000 这个接入号码,希望 1000 和 1001 顺序振铃,其中任一个接听来话,另一个停止振铃。

(2)在 confdialplandefault.xml中添加如下内容,

代码语言:javascript复制
<extension name="group_dial_seq">
  <condition field="destination_number" expression="^2000$">
    <action application="bridge" data="sofia/internal/1000@192.168.0.183|sofia/sip/1001@192.68.0.183"/>
  </condition>
</extension>

在 FS_CLI.exe 中运行 reloadxml 即可。


在FreeSwitch中修改主叫显示名称

如果你想通过你的IP话机呼叫其他用户的时候,在对方话机显示能标识你的名称,在FreeSwitch中该怎么配置?

需求:

1000 和 1001 分别是两部话机,1000时张三的话机,1001是李四的话机。若1000发起呼叫,需要在对方话机上显示“zhangsan”;若1001发起呼叫,需要在对方话机上显示“lisi”.

配置:

进入 confdirectorydefault*.xml

(1) 编辑 1000.xml ,找到 <variable name="effective_caller_id_name" value="1000"/>,修改为 <variable name="effective_caller_id_name" value="zhangsan"/>;

(2) 编辑 1000.xml ,找到 <variable name="effective_caller_id_name" value="1001"/>,修改为 <variable name="effective_caller_id_name" value="lisi"/>;

通过 FS_CLI.exe 运行 reloadxml 即可。


FreeSwitch中修改注册用户的密码

在FreeSwitch系统中,所有用户的密码默认为 1234,该设置在 confvars.xml 中,如下所示:<X-PRE-PROCESS cmd="set" data="default_password=1234"/>

若需要修改默认密码的话,直接修改该处即可。

那用户的密码和默认密码怎么关联起来?请看下面的配置文件,以 用户 1000 为例,打开 confdirectorydefault1000.xml ,找到如下设置:

<param name="password" value="$${default_password}"/>,即可找到他们之间的联系。若需要修改某用户的密码,直接修改 value 值即可。

修改配置完成后,通过 FS_CLI.exe 运行 reloadxml 即可。


FreeSwitch中用户不经过认证即可注册成功

一般来说,FreeSwitch中的SIP 用户都需要通过用户名和密码进行认证后才能注册成功,并进行通话。若有特殊需要,也可以设置为无认证即可使用,具体设置如下 :

打开 confsip_profilesinternal.xml ,将如下两条设置去掉注释即可

代码语言:javascript复制
<param name="accept-blind-auth" value="true"/> 
<param name="suppress-cng" value="true"/> 

在 FS_CLI.exe 中运行 reloadxml 即可。


FreeSwitch中添加新组

FreeSwitch中默认有三个组,分别为:sales ,billing,support。 在 confdirectorydefault.xml 中可以查到。

注意: 在 FreeSwitch中,同一个用户可以在不同的分组中存在。官方解释如下 :

type="pointer" is a pointer so you can have the same user in multiple groups. It basically means to keep searching for the user in the directory.

若需要添加一个 名为 ZOO的新组,需要在 confdirectorydefault.xml 中,找到 <groups> 标签,然后添加如下内容即可,

代码语言:javascript复制
<group name="ZOO">
  <users>
    <user id="1005" type="pointer"/>
    <user id="1006" type="pointer"/>
    <user id="1007" type="pointer"/>
    <user id="1008" type="pointer"/>
    <user id="1009" type="pointer"/>
  </users>
</group>

在FS_CLI.exe 中输入 reloadxml,重新加载新的XML文件即可。


FreeSwitch中添加新用户

FreeSwitch 中默认配置了20个用户,分别是: 1000 到 1019。在 confdirectorydefault 目录下有每个用户的XML配置文件。

若想新添加一个用户,可以通过如下步骤进行:

(1)在/conf/directory/default/增加一个用户配置文件.如下所示:

代码语言:javascript复制
<include>
  <user id="1020">
    <params>
      <param name="password" value="$${default_password}"/>
      <param name="vm-password" value="1020"/>
    </params>
    <variables>
      <variable name="toll_allow" value="domestic,international,local"/>
      <variable name="accountcode" value="1020"/>
      <variable name="user_context" value="default"/>
      <variable name="effective_caller_id_name" value="Extension 1020"/>
      <variable name="effective_caller_id_number" value="1020"/>
      <variable name="outbound_caller_id_name" value="$${outbound_caller_name}"/>
      <variable name="outbound_caller_id_number" value="$${outbound_caller_id}"/>
      <variable name="callgroup" value="techsupport"/>
    </variables>
  </user>
</include>

(2) 修改拨号计划,以使得其他用户可以呼到他。如下所示:

在 confdialplandefault.xml中,修改 如下 语句 -:

<extension name="Local_Extension"><condition field="destination_number" expression="^(10[01][0-9])$">

为 :

<extension name="Local_Extension"><condition field="destination_number" expression="^(10[012][0-9])$">

(3) 在 FS_CLI.exe 中运行 reloadxml,即可生效。


FreeSwitch中配置网关的方法

在VOIP通信系统中,经常要用到网关。那么网关怎么和FreeSwitch在一起配合使用?

有如下需求:

有一虚拟运营商(即:SIP PROVIDER ),提供拨打外线的功能。从该处购买一 SIP 账号,具体配置信息如下:

用户名:user

密码: pass

服务器IP:100. 100.100.100

想通过和该SIP PROVIDER 对接实现拨打外线功能。即:0 要拨打的号码,就送到该SIP PROVIER (说明:此时的 SIP PROVIDER 相当于一网关)。

解决方法:

1)添加一个网关

在 confsip_profilesexternal 中添加一个名为GW_TEST.xml 的文件,内容如下:

代码语言:javascript复制
<gateway name="GW_TEST">
  <param name="realm" value="100. 100.100.100"/>
  <param name="username" value="user"/>
  <param name="password" value="pass"/>
</gateway>

(2) 新建一个拨码计划

在 confdialplandefault 中新建一个名为 call_gw_test.xml 的文件 ,内容如下:

代码语言:javascript复制
<include>
  <extension name="call out">
    <condition field="destination_number" expression="^0(d )$">
      <action application="bridge" data="sofia/gateway/GW_TEST/$1"/>
    </condition>
  </extension>
</include>

(3) 通过 FS_CLI.exe 运行 reloadxml ,即可生效。


FreeSwitch中的录像功能和播放录像功能

FreeSwitch 系统中的录像功能 和 播放录像功能,系统都默认提供。

按默认配置,通过IP电话拨打9193,即可录像;通过IP电话拨打9194即可播放录像。

同时,我测试了一种有趣的用法,描述如下:

(1) 1000 呼叫 9193 并且发送视频;

(2) 1001 呼叫 9194 ,可以看到 1000 上传的视频,但非实时;

(3) 1002 呼叫 9194, 可以看到 1000 上传的视频,但非实时。

这样看来,一个点播系统,FreeSwitch 默认就支持!稍加改造,就可以变为一套视频直播系统。实现上述功能的配置文件在 confdialplandefault.xml 中,如下所示:

[录像]

代码语言:javascript复制
<extension name="video_record">
  <condition field="destination_number" expression="^9193$">
    <action application="answer"/>
    <action application="record_fsv" data="/tmp/testrecord.fsv"/>
  </condition>
</extension>

[播放录像]

代码语言:javascript复制
<extension name="video_playback">
  <condition field="destination_number" expression="^9194$">
    <action application="answer"/>
    <action application="play_fsv" data="/tmp/testrecord.fsv"/>
  </condition>
</extension>

FreeSwitch的录音功能

一般电话系统都可以将本系统内的语音通话录制下来,FreeSwitch 系统中也可以进行语音录制。

需求: 录制系统中的所有通话。

实现:

(1)建立一个文件夹 freeswitch/recordings/archive/ ,用来存储录音文件;

(2)修改拨码计划,打开 confdialplandefault.xml

找到下面的语句:

<extension name="Local_Extension">

<condition field="destination_number" expression="^(10[01][0-8])$">

在其下,添加:

代码语言:javascript复制
<action application="set" data="RECORD_TITLE=Recording ${destination_number} ${caller_id_number} ${strftime(%Y-%m-%d %H:%M)}"/>  

                     <action application="set" data="RECORD_COPYRIGHT=(c) 2011"/>  

                     <action application="set" data="RECORD_SOFTWARE=FreeSWITCH"/>

                     <action application="set" data="RECORD_ARTIST=FreeSWITCH"/> 

                     <action application="set" data="RECORD_COMMENT=FreeSWITCH"/> 

                     <action application="set" data="RECORD_DATE=${strftime(%Y-%m-%d %H:%M)}"/>  

                     <action application="set" data="RECORD_STEREO=true"/>

    <action application="record_session" data="$${base_dir}/recordings/archive/${strftime(%Y-%m-%d-%H-%M-%S)}_${destination_number}_${caller_id_number}.wav"/>

(3)在 FS_CLI.EXE 中运行 reloadxml 或 按 F6 即可生效。

查询 FreeSwitch 支持的音频文件格式,可以在 FS_CLI.exe 中运行 show file 命令。


FreeSwitch播放语音文件

上一篇介绍了 FreeSwitch 的录音功能,若想回放这些录音,是否可以实现?或者说,通过 FreeSwitch ,是否可以直接播放语音文件?

FreeSwitch 中有一个 playback 的 application ,可以播放语音文件。

具体用法如下:

(1)播放本地文件

<action application="set" data="playback_terminators=none"/>

<action application="playback" data="sounds/soundfile.wav"/>

(2)播放远程服务器上的文件

<action application="playback" data="${http_get(http://myserver.yo/media/hello_world.wav)}"/>


FreeSwitch中的会议功能(1)

FreeSwitch 默认支持会议功能,有如下特点:

1) 不需要创建一个会议室的操作,只需要通过 conference 拨码计划就可以实现;

(2) 会议室不真正存在, 直到有人呼入为止;

(3) 会议功能很强大,能实现灵活控制。

这样讲太学术化,来点直观的,步骤如下:

(1) 运行 FREESWITCH 服务器程序;

(2) 注册 1000、1001、1002三部IP话机;

(3) 通过 1000 呼叫 3000,通话建立后, 1000 将听到一段保持音乐;

(4) 通过 1001 呼叫 3000,通话建立后, 1001将能听到1000的声音,1000也能听到1001的声音;

(5) 通过 1002 呼叫 3000,通话建立后, 1002将能听到 1000 和 1001的声音,1001能听到1000和1002的声音,1000也能听到 1001 和 1002 的声音。

那 3000 这个号码是怎么来的? 请看 confdialplandefault.xml 中的内容,如下所示:

代码语言:javascript复制
<extension name="nb_conferences">
  <condition field="destination_number" expression="^(30d{2})$">
    <action application="answer"/>
    <action application="conference" data="$1-${domain_name}@default"/>
  </condition>
</extension>

FreeSwitch中的会议功能(2)

FreeSwitch 提供了一些控制会议成员行为的方法,罗列如下:

(1)Talk volume: The volume of the audio the caller sends (that is, gain control).

与会成员讲话的音量控制;

(2)Listen volume: The volume of the audio the caller hears.

与会成员收听语音的音量控制;

(3)Energy threshold: The minimum energy level of the audio from the caller to be considered talking. Raising the energy level will cut down on background noise when a participant is in a noisy environment.

语音门限控制 。

具体用法,可以查看:confautoload_configsconsole.conf.xml ,内容如下:

代码语言:javascript复制
<caller-controls>
  <group name="default"><control action="mute" digits="0"/>             // 静音
      <control action="deaf mute" digits="*"/>      // 解除静音
      <control action="energy up" digits="9"/>     // 增加门限
      <control action="energy equ" digits="8"/>   // 
      <control action="energy dn" digits="7"/>     // 降低门限
      <control action="vol talk up" digits="3"/>     // 提高讲话音量 
      <control action="vol talk zero" digits="2"/>  // 讲话音量设置为0
      <control action="vol talk dn" digits="1"/>     // 降低讲话音量
      <control action="vol listen up" digits="6"/>  // 提高收听音量
      <control action="vol listen zero" digits="5"/> // 收听音量设置为0
      <control action="vol listen dn" digits="4"/>    // 降低收听音量 
      <control action="hangup" digits="#"/>           // 退出会议
   </group>
</caller-controls>

FreeSwitch中的会议功能(3)

FreeSwitch中可以设置主持人以及会议密码。设置了主持人后,可以影响会议的开展;设置了会议密码后,与会成员必须输入正确密码才能入会。

主持人对会议的影响主要体现在以下两个方面:

(1)直到主持人入会后,会议才开始;

(2)主持人退出会议后,会议才结束。

那怎么设置主持人?方法如下:

<action application="conference" data="$1@default"/> // 未设置主持人

<action application="conference" data="$1@default flags{moderator}"/> // 设置了主持人

如何设置会议密码?方法如下:

<action application="conference" data="$1@default 1234"/> // 设置入会密码为 1234

如何既设置主持人,又设置会议密码?方法如下:

<action application="conference" data="$1@default 1234 flags{moderator}"/>


FreeSwitch中的会议功能(4)

FreeSwitch 是否支持视频会议?答案是 支持的!

FreeSwitch 默认只支持与会成员看到当前“嗓门最大”的那个人的视频。

在实际应用中,当讲话人改变时,视频会切换,但切换的时候,视频会有马赛克现象。此问题期待高手解决!

场景描述如下:

三个用户 1000、1001、1002 都注册到同一台服务器。

(1)1000 呼叫 3000,进入会议,同时发送自己的视频,1000 可以看到自己;

(2)1001 呼叫 3000,进入会议,可以看到 1000 的视频。若1001也发送自己的视频,双方看到的视频是当前讲话声音大的一方的视频;

(3)1002 呼叫 3000,进入会议,可以看到当前讲话一方的视频。若 1002 也发送自己的视频,三方看到的视频是当前讲话声音大的一方的视频。

再扩展下思维,能否让 FreeSwitch 实现融屏功能,实现与会各方都能彼此看到自己!那FreeSwitch就更强大了。以下是几个相关的资源简介:

(1)BigBluebutton 这个视频会议项目中用到了 FreeSwitch, 项目主页: http://www.bigbluebutton.org/ 。但对视频的处理只是转发各路视频,没有实现融屏合成一路视频推送到各方显示。

(2)openvcs 是一个开源的 SIP MCU 实现,项目主页:http://code.google.com/p/openvcs/ 。 在 Windows 下实现了融屏的原型设计,但在效率以及并发处理方面,还有许多需要完善的地方。但提供了一个开发 SIP MCU 的思路,这个是很有价值的。


FreeSwitch中的会议功能(5)

邀请手机用户或座机用户入会: 在 FS_CLI.EXE 中运行 类似 conference <conf-id> dial Sofia/gateway/xyz/1234567890 即可。


FreeSwitch中的音乐保持功能

Music on hold(MOH) ,即:音乐保持,在一般电话系统中都存在。FreeSwitch也支持该功能,并且保持音乐可配置。 FreeSwitch默认的配置中,用户通过某IP话机拨打 9664 ,呼叫建立后,就可以听到保持音乐。 查看当前系统中音乐文件的路径,可以通过 FS _CLI.EXE 运行 show_local_stream 来显示。 如果你想修改默认的保持音乐,可以自己添加一些好听的音乐进来,方法如下: (1)在 soundsmusic 新建一个文件夹 MOH_TEST,并拷贝音乐文件进去(WAV文件):

(2)在 confautoload_configslocal_stream.conf.xml 中添加如下内容:

代码语言:javascript复制
<directory name="moh_test" path="$${sounds_dir}/music/MOH_TEST">
  <param name="rate" value="8000"/>
  <param name="shuffle" value="true"/>
  <param name="channels" value="1"/>
  <param name="interval" value="20"/>
  <param name="timer-name" value="soft"/>
</directory>

(3) 在 confvars.xml 中添加如下内容,

<X-PRE-PROCESS cmd="set" data="moh_test=local_stream://MOH_TEST"/>

(4) 在 confdialplandefault 中添加一个名为 moh_test_call.xml 的文件,内容如下:

代码语言:javascript复制
<include>
   <extension name="moh_test_call">
     <condition field="destination_number" expression="^96646$"/>
        <action application"playback" data="${moh_test}"/>
     </condition>
   </extension>
</include>

(5)改变了默认的音乐文件后,需要重新加载 mod_local_stream 模块,在 FS_CLI.exe 中运行 reload mod_local_stream 即可生效。

(6)在 FS_CLI.EXE 中运行 reloadxml 或 按F6,即可生效。

通过某一IP 话机拨打 96646 后,即可听到你自己设置的保持音乐。

0 人点赞