要使用PHP控制FreeSWITCH服务器,您需要创建一个脚本,该脚本可以与FreeSWITCH的WebSocket API或Socket服务器通信
安装FreeSWITCH:确保您已经在服务器上安装了FreeSWITCH。如果尚未安装,请参阅官方文档以获取有关安装和配置的详细信息:https://freeswitch.org/wiki/Download_FreeSWITCH
启用WebSocket API:在FreeSWITCH中启用WebSocket API。编辑/usr/local/etc/freeswitch/freeswitch.conf
文件,取消以下行的注释:
mod_websocket = yes
然后重启FreeSWITCH服务器以应用更改:
sudo systemctl restart freeswitch
freeswitch_control.php
的新PHP脚本,并使用以下示例代码作为起点:<?php
// FreeSWITCH WebSocket服务器地址
$ws_host = "ws://localhost:8021";
// FreeSWITCH用户名和密码
$ws_user = "your_username";
$ws_pass = "your_password";
// 创建WebSocket连接
$ws = new WebSocket("ws://{$ws_host}");
// 连接到FreeSWITCH
if (!$ws->connect()) {
die("连接失败: {$ws->error}");
}
// 登录到FreeSWITCH
$login_response = $ws->send(json_encode([
"api",
"login",
"user" => $ws_user,
"password" => $ws_pass
]));
if ($login_response->status != 200) {
die("登录失败: {$login_response->data}");
}
// 发送命令到FreeSWITCH
$call_response = $ws->send(json_encode([
"api",
"originate",
"endpoint" => "your_endpoint",
"app" => "your_app",
"caller_id" => "your_caller_id"
]));
if ($call_response->status != 200) {
die("呼叫失败: {$call_response->data}");
}
// 输出响应数据
echo "呼叫创建成功: {$call_response->data}";
// 关闭WebSocket连接
$ws->close();
?>
请确保将your_username
、your_password
、your_endpoint
、your_app
和your_caller_id
替换为您的FreeSWITCH设置中的相应值。
php freeswitch_control.php
此脚本将连接到FreeSWITCH服务器,登录并使用WebSocket API发起呼叫。您可以根据需要修改此脚本以执行其他操作,例如挂断呼叫、发送DTMF信号等。
注意:在生产环境中使用WebSocket API时,请确保正确配置防火墙和网络设置,以允许从PHP服务器到FreeSWITCH服务器的通信。