星号AMI返回的数据不正确

时间:2019-03-15 01:56:46

标签: php sockets asterisk asteriskami

运行时:

asterisk*CLI>queue show <queue-name>

我从终端获得了预期的输出(在这种情况下,我期望在返回的信息中得到 A:2

但是当我通过同一服务器上的PHP套接字连接到AMI时,我会得到 A:0 (信息未正确填充)。

$data = '';
$socket = fsocketopen('127.0.0.1', '5038');

fputs($socket, "Action: Login\r\n");
fputs($socket, "UserName: username\r\n");
fputs($socket, "Secret: password\r\n\r\n");
fputs($socket, "Action: QueueStatus\r\n");
fputs($socket, "Action: Logoff\r\n\r\n");

while(!feof($socket)) {
    $data .= fread($socket, 8192);
}

fclose($socket);

$data = trim($data); // This string contains A:0 where I would expect A:2.

正在使用的AMI用户在manager.conf中具有正确的读取权限,并成功进行了身份验证。

[username]
secret = password
deny=0.0.0.0/0.0.0.0
permit=127.0.0.1/255.255.255.0
read = system,call,log,verbose,command,agent,user,all
write = system,call,log,verbose,command,agent,user,all

我的问题是,为什么AMI返回的信息与控制台返回的信息不同?

请注意,使用AMI运行时也会出现此问题:

asterisk*CLI>sip show peers

控制台返回正确的信息,而AMI为每个IP地址返回(未指定)

1 个答案:

答案 0 :(得分:0)

因此,我的系统管理员进行了查看。看来机器正在端口5038上保留较旧的Asterisk进程。杀死该进程并再次启动Asterisk后,AMI能够成功检索正确的信息。