Asterisk提供了一个挂机处理程序,用于处理呼叫结束、挂机之后的操作。下面是一个使用AGI脚本的示例程序,当呼叫挂断后会记录一个日志信息:
#!/usr/bin/php -q
$unique_id = $agi->request['agi_uniqueid']; $callerid = $agi->request['agi_callerid']; $agi->verbose("Hangup: uniqueid=$unique_id callerid=$callerid");
$log_file = "/var/log/asterisk/hangup_handler.log"; $log_message = strftime("%Y-%m-%d %H:%M:%S") . " Call ended: uniqueid=$unique_id callerid=$callerid\n"; file_put_contents($log_file, $log_message, FILE_APPEND); ?>
将hangup_handler.php文件保存在Asterisk服务器的某个目录下。
在Asterisk的extensions.conf配置文件中添加以下代码:
[default] exten => h,1,AGI(/path/to/hangup_handler.php)
其中/path/to/hangup_handler.php是hangup_handler.php文件的完整路径。
保存并重启Asterisk服务。
当呼叫结束、挂机后,hangup_handler.php脚本会自动执行并将日志信息记录到/var/log/asterisk/hangup_handler.log文件中。