您的位置:首页 > 编程语言 > PHP开发

asterisk 使用php脚本连接oralce数据库 通过AMI端口实现预拨号(批量外呼)

2011-06-27 17:07 1161 查看
1. cat /var/www/html/pre_dial.php

<?php
$server='10.236.22.116';
$port='5038';
$errstr='登陆失败';
$timeout=1;
$socket = fsockopen($server,$port, $errno, $errstr, $timeout); //连接服务器
if( $socket == false) { die ($errno.':'.$errstr); }
fputs($socket, "Action: login/r/n"); //登录
fputs($socket, "Username: admin/r/n"); //用户名
fputs($socket, "Secret: admin/r/n/r/n");//密码

if ($conn=OCILogon("kai","fjelite","linux"))
{ echo "SUCCESS ! Connected to database/n";
}
else
{echo "Failed :-( Could not connect to database/n";}
$stmt = OCIParse($conn,"select tel,area from hkh_tel where dial_mark= 0 ");//解析
OCIDefineByName($stmt,"TEL",&$TEL);//绑定
OCIDefineByName($stmt,"AREA",&$AREA);//绑定
OCIExecute($stmt);//执行语句
while
(
OCIFetch($stmt))
{

fputs($socket, "Action: Originate/r/n");
fputs($socket, "Channel: Local/$AREA$TEL@user/r/n");
fputs($socket, "CallerID: 10016/r/n");//来电显示的号码
fputs($socket, "WaitTime: 30/r/n");//等待被叫应答振铃时间
fputs($socket, "Exten: queue1/r/n");
fputs($socket, "Context: user/r/n");
fputs($socket, "Priority: 1/r/n");
fputs($socket, "Async: yes/r/n/r/n" );
$wrets=fgets($socket,128);

if (empty($TEL))
{
$p_num = '0';
}
else
{
$p_num = $TEL;
}
{
echo "TEL:".$TEL;
echo $p_num;
}
$Sql = " update hkh_tel set dial_mark=1 where tel= $p_num ";
$upd=OCIParse($conn,$Sql);
$result=OCIExecute($upd, OCI_DEFAULT);
if (!$result)
{
OCIRollback($conn);//不成功则回滚
OCIFreeStatement($upd); //释放资源
}

}

OCICommit($conn);//如果都成功则提交
OCIFreeStatement($stmt);//释放资源

OCILogoff($conn);
?>

2. /usr/bin/php /var/www/html/pre_dial.php

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: