搞了个简单群呼系统(asterisk+PHP)
弄了个简单群呼系统(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>

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

熱門話題

MySQL適合初學者使用,因為它安裝簡單、功能強大且易於管理數據。 1.安裝和配置簡單,適用於多種操作系統。 2.支持基本操作如創建數據庫和表、插入、查詢、更新和刪除數據。 3.提供高級功能如JOIN操作和子查詢。 4.可以通過索引、查詢優化和分錶分區來提升性能。 5.支持備份、恢復和安全措施,確保數據的安全和一致性。

可以通過以下步驟打開 phpMyAdmin:1. 登錄網站控制面板;2. 找到並點擊 phpMyAdmin 圖標;3. 輸入 MySQL 憑據;4. 點擊 "登錄"。

使用 Navicat Premium 創建數據庫:連接到數據庫服務器並輸入連接參數。右鍵單擊服務器並選擇“創建數據庫”。輸入新數據庫的名稱和指定字符集和排序規則。連接到新數據庫並在“對象瀏覽器”中創建表。右鍵單擊表並選擇“插入數據”來插入數據。

MySQL是一個開源的關係型數據庫管理系統。 1)創建數據庫和表:使用CREATEDATABASE和CREATETABLE命令。 2)基本操作:INSERT、UPDATE、DELETE和SELECT。 3)高級操作:JOIN、子查詢和事務處理。 4)調試技巧:檢查語法、數據類型和權限。 5)優化建議:使用索引、避免SELECT*和使用事務。

MySQL和SQL是開發者必備技能。 1.MySQL是開源的關係型數據庫管理系統,SQL是用於管理和操作數據庫的標準語言。 2.MySQL通過高效的數據存儲和檢索功能支持多種存儲引擎,SQL通過簡單語句完成複雜數據操作。 3.使用示例包括基本查詢和高級查詢,如按條件過濾和排序。 4.常見錯誤包括語法錯誤和性能問題,可通過檢查SQL語句和使用EXPLAIN命令優化。 5.性能優化技巧包括使用索引、避免全表掃描、優化JOIN操作和提升代碼可讀性。

可在 Navicat 中通過以下步驟新建 MySQL 連接:打開應用程序並選擇“新建連接”(Ctrl N)。選擇“MySQL”作為連接類型。輸入主機名/IP 地址、端口、用戶名和密碼。 (可選)配置高級選項。保存連接並輸入連接名稱。

在 Navicat 中執行 SQL 的步驟:連接到數據庫。創建 SQL 編輯器窗口。編寫 SQL 查詢或腳本。單擊“運行”按鈕執行查詢或腳本。查看結果(如果執行查詢的話)。

Navicat 連接數據庫時常見的錯誤及解決方案:用戶名或密碼錯誤(Error 1045)防火牆阻止連接(Error 2003)連接超時(Error 10060)無法使用套接字連接(Error 1042)SSL 連接錯誤(Error 10055)連接嘗試過多導致主機被阻止(Error 1129)數據庫不存在(Error 1049)沒有權限連接到數據庫(Error 1000)
