?
- 环境配置
服务器 ?centos?6.9 (64bit)
Java ?jdk1.8
Freeswitch ?1.6.15~64bit ( 64bit)
Freeswitch路径 /usr/local/freeswitch(下述步骤全部以全路径为主)
- 配置步骤
- 修改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" 表示该接口返回拨号方案信息
?
- 动态配置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信息
?
备注:
- 模版文件内容
- 注册失败的模版
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(); // 加一个空行(结束行)
}
- 使用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将根据我们返回的拨号方案进行匹配判断是否符合,若不符合则会挂断呼叫。
如果本文档对您产生了帮助,请评论、点赞或者留言告诉我们哦。