当前位置: 代码迷 >> PHP >> 搞了个简单群呼系统(asterisk+PHP)
  详细解决方案

搞了个简单群呼系统(asterisk+PHP)

热度:610   发布时间:2016-04-29 00:44:49.0
弄了个简单群呼系统(asterisk+PHP)

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

?

?? ? ? ? ? ? ? ? ? ? ? ? ? ? ???? ??


?

?? 源码如下:(注:操作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>
?