运行时:
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地址返回(未指定)时,控制台将返回正确的信息。
所以我的系统管理员看了一下。似乎机器在端口5038上持有较旧的Asterisk进程。在杀死该进程并再次启动Asterisk后,AMI成功地能够检索到正确的信息。