freeswitch mysql 怎么玩

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了freeswitch mysql 怎么玩相关的知识,希望对你有一定的参考价值。

将压缩包解压到你想存放mysql的位置;
如:E:\\tools_package\\mysql-5.6.16-winx64;将E:\\tools_package\\mysql-5.6.16-winx64\\bin配在win7系统的path全局变量,在任何目录下都能使用mysql命令!
参考技术A freeswitch是一款强大的voip服务器,可以语音和视频。但是它默认是采用/directory文件夹下的xml来配置用户的,对于整合到现有系统或者使用数据库保存用户信息的系统都是非常不方便的,所以,本文主要描述一种方法,解决freeswitch用户整合的问题。!

freeswitch 使用外部directory 代替磁盘xml文件


大家都知道,FreeSWITCH默认是从磁盘中xml文件,决定系统中有哪些用户的。


对于一个常规的信息系统,用户信息都是存储在数据库中。


以下非常简单的演示了,FreeSWITCH中的用户如何使用数据库注册。



准备工作:

一套LAMP或LNMP环境

编译FreeSWITCH 的mod_xml_curl 模块



Apache + php7 + MySQL 5.7 中的php脚本

根据实际情况,修改相关参数

[email protected]/var/www/html$ cat chunli_test.php
<?php
/*
 * 作者:李春利
 * 功能:演示接收FreeSWITCH注册请求,连接到远程MySQL数据库检索用户密码,返回XML文件
 * 备注:PHP 7.0 版本程序,注意MySQL函数发生了变化

 * MySQL数据库表快速创建:
CREATE DATABASE IF NOT EXISTS `freeswitch`  DEFAULT CHARACTER SET utf8;
USE `freeswitch`;                          
DROP TABLE IF EXISTS `authentication`;     
CREATE TABLE `authentication` (            
    `user_name` varchar(100) NOT NULL,       
    `user_password` varchar(100) NOT NULL    
) ENGINE=InnoDB DEFAULT CHARSET=utf8;      
INSERT INTO `authentication` VALUES (‘lao_wang‘,‘tiger‘),(‘1234‘,‘4321‘),(‘chunli‘,‘chunli‘),(‘1030‘,‘123456‘),(‘1019‘,‘1234‘),(‘2222‘,‘12345678‘);
 */

$user   = $_POST[‘user‘];
$domain = $_POST[‘domain‘];
$password = "";

$db_host = "172.16.66.111";
$db_user = "root";
$db_pwd  = "root";
$db_name = "freeswitch";

function getlink($db_host,$db_user,$sb_pwd,$db_name)
{
    $link=mysqli_connect($db_host,$db_user,$sb_pwd);
    if(!$link)
    {
        echo"MySQL数据库连接失败\n";
        exit();
    }
    if(!mysqli_select_db($link,$db_name))
    {
        echo"MySQL 数据库选择失败\n";
        exit();
    }
    mysqli_query($link, "setnames utf8");

    return $link;
}


$link=getlink($db_host,$db_user,$db_pwd,$db_name);
$result=mysqli_query($link, "select user_password  from authentication where user_name = ‘${user}‘");

if(mysqli_num_rows($result) > 0)
{
    while($row=$result->fetch_row())
    {  
        foreach($row as $key=>$val)
        {  
            $password = $val;
        }  
    }  
    $result->free(); 
}
else
{
    echo"查无此人{$user}\n";
    exit();
}
mysqli_close($link);
?>
<document type="freeswitch/xml">
  <section name="directory">
    <domain name="<?php echo $domain;?>">
      <params>
        <param name="dial-string" value="{presence_id=${dialed_user}@${dialed_domain}}${sofia_contact(${dialed_user}@${dialed_domain})}"/>
      </params>
      <groups>
        <group name="default">
          <users>
            <user id="<?php echo $user; ?>">
              <params>
                <param name="password" value="<?php echo $password; ?>"/>
                </params>
              <variables>
                <variable name="user_context" value="default"/>
              </variables>
            </user>
          </users>
        </group>
      </groups>
    </domain>
  </section>
</document>
[email protected]/var/www/html$



编译FreeSWITCH 相关模块

[[email protected] ~]# iptables -F

[[email protected] ~]# iptables -X



编译mod_xml_curl,默认不编译

[[email protected] 01_install]# vim freeswitch-1.6.17/modules.conf 
将
#xml_int/mod_xml_curl
改为
xml_int/mod_xml_curl

编译 ./configure && make && make mod_xml_curl-install
具体你的configure怎么设置的,自己加上原先的参数。


使FreeSWITCH自动加载mod_xml_curl

[[email protected] freeswitch]# vim ./autoload_configs/modules.conf.xml
将
    <!-- <load module="mod_xml_curl"/> -->
改为
	<load module="mod_xml_curl"/>
	


修改FreeSWITCH用户注册的方式,HTTP优先,如果请求失败了,再到本地磁盘找xml文件

[[email protected] freeswitch]# vim autoload_configs/xml_curl.conf.xml
<configuration name="xml_curl.conf" description="cURL XML Gateway">
  <bindings>
    <binding name="directory">
       <param name="gateway-url" value="http://172.16.20.17/chunli_test.php" bindings="directory"/>
    </binding>
  </bindings>
</configuration>


修改拨号计划,添加通话路由

[[email protected] freeswitch]# vim dialplan/default.xml 
<condition field="destination_number" expression="^(10[01][0-9]|1234|lao_wang)$">




启动FreeSWITCH

一个SIP 使用 (‘lao_wang‘,‘tiger‘),注册

一个SIP 使用(‘1234‘,‘4321‘), 注册


互相拨打电话,试试





调错技巧:

按F8,打开 debug级别日志。



拨打电话,打不通,如果出现以下情况,说明HTTP请求是失败的,检查php脚本的ip,user,password参数

2017-06-29 01:21:40.705900 [WARNING] mod_voicemail.c:3487 Can‘t find user [[email protected]]



如果出现以下情况,说明HTTP请求被拒绝,tcpdump 查看发来的包结构。

2017-06-29 00:22:38.681206 [WARNING] mod_xml_curl.c:294 CURL returned error:[52] Server returned nothing (no headers, no data)


用户1234 拨打 lao_wang

技术分享



lao_wang的电话显示1234来电了

技术分享







本文出自 “李春利” 博客,请务必保留此出处http://990487026.blog.51cto.com/10133282/1943403

以上是关于freeswitch mysql 怎么玩的主要内容,如果未能解决你的问题,请参考以下文章

centos 7.2配置 FreeSwitch X-Lite

怎么查看freeswitch版本

freeswitch中挂断时间怎么获取

Freeswitch 怎么配置 Proxy Media 和 bypass 模式

freeswitch怎么进行视屏通话的配置

在lua脚本中怎么用freeswitch.session