前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >freeswitch之SIP动态注册及动态配置拨号方案

freeswitch之SIP动态注册及动态配置拨号方案

原创
作者头像
qzlink.com
修改2020-04-23 17:54:43
3.5K0
修改2020-04-23 17:54:43
举报

本文档描述freeswitch的动态配置SIP账户,以及动态修改拨号方案的问题。

一、 环境配置

服务器 centos 6.9 (64bit)

Java jdk1.8

Freeswitch 1.6.15~64bit ( 64bit)

Freeswitch路径 /usr/local/freeswitch(下述步骤全部以全路径为主)

二、 配置步骤

1、 修改freeswitch配置信息

修改文件配置文件xml_curl.conf.xml

若为默认配置,最好清空哦:

echo ""> /usr/local/freeswitch/conf/autoload_configs/xml_curl.conf.xml

修改文件

vim /usr/local/freeswitch/conf/autoload_configs/xml_curl.conf.xml

修改内容为:

<configuration name="xml_curl.conf" description="XML Gateway">

<bindings>

<binding name="directory ">

<param name="gateway-url" value="http://localhost:8080/directory" bindings="directory"/>

</binding>

<binding name="dialplan ">

<param name="gateway-url" value="http://localhost:8080/dial" bindings="dialplan"/>

</binding>

</bindings>

</configuration>

其中

gateway-url 为javaWeb的接口地址

bindings="directory" 表示该接口返回注册信息

bindings="dialplan" 表示该接口返回拨号方案信息

2、 动态配置SIP信息

修改好配置文件后,freeswitch获取验证sip注册信息时,将调用接口:directory来进行获取注册信息

创建sip表:

CREATE TABLE `sip` (

`id` int(11) NOT NULL AUTO_INCREMENT,

`user` varchar(11) DEFAULT NULL COMMENT '用户名',

`pwd` varchar(11) DEFAULT NULL COMMENT '密码',

`creat_at` datetime DEFAULT NULL,

PRIMARY KEY (`id`)

) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8;

创建注册接口/directory,如下

1、根据参数action参数判断用户的动作信息,获取参数中的sip帐号信息

2、根据sip帐号信息,从数据库查询相应的用户信息

3、用户为空时直接返回注册失败的xml

4、用户不为空时生成注册的xml信息

5、使用sip信息,参数:sip_to_host(ip地址)以及数据库中获取的密码信息:pwd,进行md5加密,加密失败时返回注册失败的xml信息

6、生成参数map,调动方法:replaceArgsNew,或者使用beel工具类,根据模版生成注册的xml信息

备注:

1、 模版文件内容

2、 注册失败的模版

3、工具类:replaceArgsNew

public static String replaceArgsNew(String template, Map<String, String> data) {

// sb用来存储替换过的内容,它会把多次处理过的字符串按源字符串序 存储起来。

StringBuffer sb = new StringBuffer();

try {

Pattern pattern = Pattern.compile("\\$\\{(.+?)\\}");

Matcher matcher = pattern.matcher(template);

while (matcher.find()) {

String name = matcher.group(1);// 键名

String value = (String) data.get(name);// 键值

if (value != null) {

value = value.replace("\\", "\\\\\\");

value = value.replace("$", "\\$");

matcher.appendReplacement(sb, value);

}

}

matcher.appendTail(sb);

} catch (Exception e) {

e.printStackTrace();

}

return sb.toString(); // 加一个空行(结束行)

}

3、 使用beel工具类处理模版信息时,项目需要导入jar包:antlr4-runtime-4.7.1.jar,beetl-core-2.2.3.jar,按需配置

3、动态配置拨号方案

修改好配置文件后,freeswitch获取验证sip注册信息时,将调用接口:dial来进行获取注册信息

创建拨号方案表

CREATE TABLE `dial_tab` (

`id` int(11) NOT NULL,

`call_prefix` varchar(6) DEFAULT NULL COMMENT '被叫前缀',

`gateway` varchar(20) DEFAULT NULL COMMENT '网关名称',

`tranfer_prefix` varchar(6) DEFAULT NULL COMMENT '转接前缀',

`call_number` varchar(20) DEFAULT NULL COMMENT '主叫号码',

`creat_at` datetime DEFAULT NULL,

PRIMARY KEY (`id`)

) ENGINE=MyISAM DEFAULT CHARSET=utf8;

创建拨号方案接口:dial

本接口使用beel工具类,根据模版生成拨号方案信息,模版文件:dial.xml

其中参数:

call_prefix 为前缀判断规则,当被叫号码符合相应表达式时才会允许使用该拨号拨号按方案:^ (.*)$,允许所有号码使用该拨号方案,^91(.*)$,允许被叫前缀为91的被叫号码使用该拨号方案。

effective_caller_id_number 为透传参数信息,即即被叫显示的来电号码,可忽略该参数,未设置该参数时,默认为真实主叫号码,本代码默认设置为来电号码。

Data 转接参数信息。

Freeswitch呼出时,或者收到呼入信息时,会调用接口:dial获取拨号方案信息,

获取参数:

Hunt-Caller-ID-Number 主叫号码

Caller-Destination-Number 被叫号码

variable_sip_contact_host 呼叫ip,即呼叫方的ip地址,可用作ip判断处理。

1、判断被叫号码是否是SIP帐号,若是SIP帐号,转接到指定的SIP帐号信息。

参数:call_prefix设置为空,允许所有号码通过

参数:effective_caller_id_number,设置为来电号码

参数:转接信息:data设置为:"user/"+variable_sip_to_user,即为呼叫SIP帐号:123456时,为:user/12345,也可设置为:user/$1,表示为,默认被叫号码,即主叫键入的被叫号码,

2、当被叫帐号不是sip帐号时,获取拨号方案列表信息。

表dial_tab参数:call_number,用于判断主叫是否为指定的号码,循环判断,若与主叫号码相同,即为某一指定主叫呼入时,转送到指定的落地网关上

表dial_tab参数:call_prefix,即为被叫前缀信息,即设定的呼叫规则,当被叫的前缀为指定值时,才可使用该呼叫规则,

转接到网关时,转接信息:data为:"sofia/gateway/"+gateway+"/"+tranfer_prefix+"$1";

其中参数:gateway,为相应的落地网关名称,

参数:tranfer_prefix,为转接到落地网关时,送的前缀信息,

参数:$1,为默认的被叫信息,注意,当存在前缀规则call_prefix时,freeswitch将自动去除相应的前缀信息,即呼叫被叫:9118860233225,设定前缀规则:call_prefix为91时,$1表示:18860233225

3、当根据主叫信息,没有在拨号方案表:dial_tab中获取拨号方案信息时,则循环查询拨号方案列表,根据被叫前缀,即call_prefix,来获取相应的拨号方案信息,根据拨号方案信息,转接到指定的网关即可。

4、上述描述的为多个拨号方案列表的情况,我们可根据拨号方案表中的信息,自由设定返回相应的拨号方案给freeswitch,当只有一个拨号方案时,我们可直接返回即可,freeswitch将根据我们返回的拨号方案进行匹配判断是否符合,若不符合则会挂断呼叫。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档