设为首页 收藏本站
查看: 625|回复: 0

[经验分享] 弄了个简单群呼系统(asterisk+PHP)

[复制链接]

尚未签到

发表于 2017-4-9 10:21:04 | 显示全部楼层 |阅读模式
  

先说下从 excel 中导入号码到数据库中去,然后从数据库中读取这些号码生成呼叫文件,进行呼叫即可

 

                                DSC0000.gif       DSC0001.gif



 

   源码如下:(注:操作excel的读取文件就没写上来)




<?php
/* 首先得把 文件上传的服务器中相应的位置,然后从该文件中读取号码到数据库中!
接着从数据库中读取这些号码,生成。call 文件 到 var/..out.  目录下 就可以呼叫了
*/

// 文件上传.........................................................................................................
if(is_uploaded_file($_FILES['upfile']['tmp_name'])){  //判断有新文件上传
$upfile=$_FILES["upfile"];        //上传文件的函数
$name = $upfile["name"];        // 获取文件名称
$type = $upfile["type"];        //文件类型
$size = $upfile["size"];        //文件大小
$tmp_name = $upfile["tmp_name"];   //临时文件位置
$error = $upfile["error"];       // 判断文件是否成功的参数,0代表成功,。。。
// 允许上传的文件类型
switch ($type)
{
case 'application/vnd.ms-excel' : $ok=1;  //只允许上传excel文件类型
break;
}
//判断是否成功
if($ok && $error=='0')
{
move_uploaded_file($tmp_name,'xls/'.'tel.xls');  //把上传的临时文件放到xls下
//读取上传后文件中的内容.........................................
require_once 'reader.php';                      //引入读取csv文件类
$data = new Spreadsheet_Excel_Reader();
$data->setOutputEncoding('utf-8');
$conn= mysql_connect('localhost','root','888888') or die("数据库连接失败");
mysql_query("set names 'utf-8'");//设置编码输出
mysql_select_db('asterisk'); //选择数据库
$data->read('xls/tel.xls');
for ($i = 2; $i <= $data->sheets[0]['numRows']; $i++)
{
$sql = "INSERT INTO tel VALUES(null,'".$data->sheets[0]['cells'][$i][1]."',0)";
$query=mysql_query($sql);
if($query)
{
}
}
}else
{
echo "<mce:script type="text/javascript"><!--
alert('上传失败,请检查文件格式!');window.top.location='file.php'
// --></mce:script>";
}
}
//.................................................................................................................end

//........从数据库中读取号码生成一个一个的.call呼叫文件............................................................................
if(isset($_POST['liji_tel']))   //立即呼叫。。这里还得完成流程呼叫完毕后。删除呼叫的号码
{
$con= mysql_connect('localhost','root','888888') or die("数据库连接失败");
mysql_query("set names 'utf-8'");//设置编码输出
mysql_select_db('asterisk'); //选择数据
$result=mysql_query("select * from tel where s_id=0");
while($rows=mysql_fetch_row($result))
{
$filename="$rows[1].call";
fopen($filename,"w+");
$somecontent_8001="channel: SIP/$rows[1]"."/n"."callerid: <haozi>"."/n"."MaxRetries: 2"."/n"."Context: default"."/n"."RetryTime: 10"."/n"."WaitTime: 10"."/n"."Extension: _x."."/n"."setvar: id=$rows[0]"."/n";
if (is_writable($filename)) {  
if (!$handle = fopen($filename, 'a')) { exit;}
if (fwrite($handle, $somecontent_8001)=== FALSE) {exit;}fclose($handle);
$kk="mv ".$filename." /var/spool/asterisk/outgoing/";
system($kk,$restult);}}
echo "<mce:script type="text/javascript"><!--
alert('已启用群呼!');window.top.location='file.php'
// --></mce:script>";
}
//..............end ............................................................................................................
?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text ml; charset=utf-8">
</head>
<body>
电话群呼(text):
<form action="" enctype="multipart/form-data" method="post" name="upform">  
<div align="center">
<table width="634" border="1">
<tr>
<td>选择要上传的号码文件:</td>
<td>上传文件:
<input name="upfile" type="file" /></td>
</tr>
<tr>
<td width="230"><label>
<input name="liji_tel" type="radio" value="1" checked="checked" />立即呼叫
</label></td>
<td width="388"><input name="submit" type="submit" value="执行" /></td>
</tr>
</table>
<br>  
</div>
</form>
</body>
</html>

 

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-362303-1-1.html 上篇帖子: PHP 中 json_encode, json_decode, serialize/unserialize 性能比较 下篇帖子: php中require和include的几点区别
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表