隨著WEB2.0的流行,現在很多網站都流行使用“彈幕”這種形式來實現互動。
創新互聯公司主要從事網站制作、成都網站設計、網頁設計、企業做網站、公司建網站等業務。立足成都服務梁河,10余年網站建設經驗,價格優惠、服務專業,歡迎來電咨詢建站服務:028-86922220
彈幕(barrage),中文流行詞語,原意指用大量或少量火炮提供密集炮擊。大量以字幕彈(dàn)出形式顯示的評論同時在屏幕上飄過的現象也被稱為彈幕。
作為PHPer的我們,看到現在各種網站都有酷炫的彈幕飛過,我們是不是也想給自己的網站加入彈幕功能呢?
首先彈幕的后端其實說白了和公共聊天室的后端原理十分相似,都是一個客戶端發送消息給服務端,服務端再將收到的消息廣播給其他的客戶端。對于后端來說他們幾乎沒區別,區別就在于前端。
好在我們有一個前端彈幕插件,這個插件是一個jquery插件,github地址:,基本上會使用jquery語法,看看示例代碼就可以傻瓜化使用。
前端已經有了解決方案,但是后端呢?前端如何與后端通訊?用傳統的ajax輪詢嗎?不行,這樣效率太低,想想各大火爆的直播平臺都是同一時間幾萬人在線,幾千人同時發彈幕,如果靠ajax輪詢一個php接口的話服務器會吃不消的。且彈幕消息存儲方案略顯復雜,有人問為什么要存儲呢?因為ajax使用的HTTP協議是無狀態協議,A客戶端和B客戶端之間對于服務器來說沒有任何標志,如果服務器要確保A客戶端和B客戶端分別在兩次請求的時候服務器只返回這兩個客戶端沒有獲取過的彈幕消息,那么服務器端就必須使用一個緩存來標識某某客戶端看過哪條彈幕消息。綜上所述ajax可以實現小規模的彈幕通信方案,但是很麻煩。
好在最新的HTML5中加入了WebSocket協議,我們可以通過WebSocket這種基于HTTP協議之上的即時通信協議來替代ajax這種傳統的我問你答的老舊通信模式。而我們是PHPer,對于我們這種只懂PHP的人該如何編寫WebSocket服務端呢?好在我們又得知PHP有一個Swoole擴展,我們在PHP語言中使用它可以很方便的構建一個WebSocket服務端。
關于Swoole的介紹可以參照他的官網,下面引用官網對它的一段簡短的介紹。
PHP的異步、并行、高性能網絡通信引擎,使用純C語言編寫,提供了PHP語言的異步多線程服務器,異步TCP/UDP網絡客戶端,異步MySQL,異步Redis,數據庫連接池,AsyncTask,消息隊列,毫秒定時器,異步文件讀寫,異步DNS查詢。 Swoole內置了Http/WebSocket服務器端/客戶端、Http2.0服務器端。
Swoole可以廣泛應用于互聯網、移動通信、企業軟件、云計算、網絡游戲、物聯網(IOT)、車聯網、智能家居等領域。 使用PHP+Swoole作為網絡通信框架,可以使企業IT研發團隊的效率大大提升,更加專注于開發創新產品。
先別被Swoole這么多的功能嚇到了。我們先關注這里面的重點Swoole內置了Http/WebSocket服務器端/客戶端意味著我們可以通過它構建WebSocket的服務端。看到這里我們是不是就急急忙忙去拿官網的WebSocket服務端代碼做測試呢?不,Swoole是一個PHP擴展,意味著我們還得去安裝它。是不是直接去下載so文件然后在php.ini中加入extension=swoole.so就可以了呢?還不是,我們先去看看Swoole擴展的依賴,這也是我們使用任何語言的任何外部包,外部模塊,外部擴展最先要了解的問題。
參考官網:環境依賴
僅支持Linux,FreeBSD,MacOS,3類操作系統
Linux內核版本2.3.32以上
PHP5.3.10以上版本,包括PHP7
gcc4.4以上版本或者clang
cmake2.4+,編譯為libswoole.so作為C/C++庫時需要使用cmakePHP版本依賴
swoole僅支持PHP5.3.10或更高版本,建議使用PHP5.4+swoole不依賴php的stream、sockets、pcntl、posix、sysvmsg等擴展。PHP只需安裝最基本的擴展即可意味著我們Windows下是無法使用這個擴展了(其實可以借助cygwin在win下使用swoole,但是考慮到我們使用swoole擴展就是為了性能,也為了熟悉以后的生產環節部署做準備,強烈推薦在linux下開發),那么我們把開發環境轉移到Linux下進行吧。
接著還要求Linux內核版本為2.3.32以上,PHP為5.3.10以上,那么我們就用最新的CentOS吧,這個版本的yum安裝的php直接就是PHP7最新版,根本無需考慮其他問題,當然你喜歡圖形界面,用Ubuntu也可以。其他的基本上最新的Linux發行版都是符合版本要求的。
接著我們便來安裝這個擴展,推薦使用PECL來安裝,只需要一條pecl install swoole
即可,非常方便。當然你要編譯安裝,具體步驟請參考安裝完擴展之后在命令行下輸入
php -m
檢查,如果有swoole那么說明安裝成功了。
接下來就正式開始我們的編碼旅程了。
開始編碼旅程之前我們先看看最基礎的效果原型是什么樣子沒錯就是這個樣子,兩個瀏覽器之前完全獨立使用Websocket連接服務端,因此對于服務端來說這兩個瀏覽器就相當于兩個完全處在不同機器上的客戶端。
效果看完了就開始來講代碼吧。
我們先看看官網的WebSocket服務端示例代碼。
$serv = new Swoole\Websocket\Server("127.0.0.1", 9502);$serv-on('Open', function($server, $req) {echo "connection open: ".$req-fd;
});
$serv-on('Message', function($server, $frame) {echo "message: ".$frame-data;
$server-push($frame-fd, json_encode(["hello", "world"]));});
$serv-on('Close', function($server, $fd) {echo "connection close: ".$fd;
});
$serv-start();
我們看到這個代碼的第一行先是new了一個WebSocket服務端對象,并且在構造方法中的第一個參數指定了服務端監聽的IP,第二個參數指定了服務端監聽的端口。然后使用on方法為每一個事件設置了回調函數,最后一行start方法正式開始運行服務端。
這種寫法非常像Javascript里面的異步調用,這也是Swoole中的事件驅動異步非阻塞特性,正因為是這種特性,每一個獨立的事件(請求)會在服務端接收到之后分別異步處理,他們之間無需互相等待,這也是Swoole性能高的原因所在。
我們來分別剖析一下每一個事件的含義。
$serv-on('Open', function($server, $req) {echo "connection open: ".$req-fd;
});
顧名思義,Open表示打開一個新的鏈接,并且在事件觸發之后echo出連接上服務端的客戶端id,該客戶端唯一id為回調函數第二個參數中的fd字段。這也是服務端區分客戶端的唯一id。
$serv-on('Message', function($server, $frame) {echo "message: ".$frame-data;
$server-push($frame-fd, json_encode(["hello", "world"]));});
同樣顧名思義,Message表示消息到達服務端的事件,并且在事件觸發之后echo出發送給服務端的數據,該數據為回調函數第二個參數的data字段。另外我們還看到它調用了$server-push,這是回調函數的第一個參數中的push方法,它是一個服務端給客戶的發送數據的方法,第一個參數為要發送的客戶端id,第二個為要發送的數據,這里的含義是向發給服務端消息的那個客戶端發送["hello", "world"]這個數組(方括號寫數組為PHP5.4的新特性,如果你是PHP5.3請使用傳統的array工廠函數生成數組)經過json序列化之后的數據。
$serv-on('Close', function($server, $fd) {echo "connection close: ".$fd;
});
最后一個事件Close更加容易理解,就是關閉事件,當然關閉的不是服務端,而是客戶端,可以理解為客戶端與服務端斷開連接的事件。回調函數中的代碼含義為echo出與服務端斷開連接的那個客戶端id。
基本的API都清楚了,下面就直接看代碼吧,短短二十行而已。
= new swoole_websocket_server("0.0.0.0", 1997);$server-on('open', function (swoole_websocket_server $server, $request) {echo "server: handshake success with fd{$request-fd}\n";//$request-fd 是客戶端id});
$server-on('message', function (swoole_websocket_server $server, $frame) {echo "receive from {$frame-fd}:{$frame-data},opcode:{$frame-opcode},fin:{$frame-finish}\n";//$frame-fd 是客戶端id,$frame-data是客戶端發送的數據//服務端向客戶端發送數據是用 $server-push( '客戶端id' , '內容')$data = $frame-data;
foreach($server-connections as $fd){
$server-push($fd , $data);//循環廣播
}
});
$server-on('close', function ($ser, $fd) {echo "client {$fd} closed\n";
});
$server-start();
這里最核心的廣播代碼其實還用到了一個之前沒有提到過的成員,也就是swoole_websocket_server對象的connections成員,這個成員中保存了所有已連接上該WebSocket服務端的fd,也就是客戶端id。因此我們只要在message事件中使用foreach遍歷該成員,循環將所有服務端收到的彈幕消息都發送給其他已連接上該服務端的客戶端即可。
后端講完了再講講前端吧。
前端代碼也不是很多 ws = new WebSocket("ws://192.168.1.107:1997");ws.onopen = function(){
console.log("握手成功");
ws.send('hello world!!!');
};
ws.onmessage = function(e){
console.log("message:" + e.data);
var time = jQuery('#danmu').data("nowtime") + 1;var text_obj = '{ "text":"' + e.data + '" , "color":"green" ,"size":"1","position":"0","time":"' + time + '" ,"isnew":" "}'; //構造加上了innew屬性的字符串danmu對象console.log(text_obj);
var new_obj = eval('(' + text_obj + ')'); //轉化為js對象jQuery('#danmu').danmu("add_danmu", new_obj); //向插件中添加該danmu對象};
ws.onerror = function(){
console.log("error");
};
核心代碼都在這里,使用new WebSocket("ws://192.168.1.107:1997")創建一個WebSocket客戶端連接對象,通過該對象的各種事件進行對應的操作,和服務端是不是很像?更多代碼解釋可以參考源代碼中的注釋,這里不做更多介紹。
看到這里相信作為一名PHPer的你也可以開發出屬于自己的彈幕系統了。這里展示的只是一個最基礎最原始的彈幕平臺。我們也了解到了使用PHP開發一個彈幕平臺需要涉及到的技術有WebSocket,Swoole擴展,甚至碰到了很多初級開發者平時不怎么接觸的工具,比如說PECL,比如說Linux。
其實PHP結合Swoole擴展還可以做很多事情,比如說對接各種家電,對接各種硬件接口實現在Web端實時控制家電,又比如說結合樹莓派做智能小車,通過web端進行遙控等等,各種新奇的玩法等你發現。誰說PHP只能做Web開發?PHP擁有了Swoole擴展其實能做的事情還有很多,Swoole就像他的宣傳標題一樣:重新定義PHP。
最好用php的擴展,swoole來寫,PHP底層對websocket的支持不是很好。用swoole建立長連接來推送彈幕
示范一下
a
href="#"
onclick='if(confirm("你確定要修改嗎?"))
{location.href="change.php";}'修改/a
當你點擊修改的時候,會跳出這個問你“確定修改”的對話框,你確定的話,自動跳到change.php執行代碼;否則在本頁面不動
order.php?detail=ID(2011072500001). $_GET['detail'] ;獲取ID,并安全處理后進行SQL語句執行。 之后將返回的SQL結果,顯示在HTML中,就可以嘞。
html
head
script ...
function send_request()
{
//ajax發送查找數據庫請求
//設置onready函數等待數據接收完成
//當數據接收完成,將div id="data_recv"/div之間的innerHtml設置為接受到的數據
//并顯示該div(初始化時設置為隱藏)
}
/script
/head
body
//搜索部分
div id="data_recv"
/div
/body
/html
......php文件
根據發送來的請求搜索數據庫,并生成相應的 html,然后echo 之
目前還沒有現成的套站程序,只有php源碼,你要會php的話可以自行制作,上面網站有php源碼
網站欄目:php結合數據庫實現彈幕,php彈幕技術
網頁鏈接:http://vcdvsql.cn/article42/hsohhc.html
成都網站建設公司_創新互聯,為您提供動態網站、網站制作、Google、外貿建站、云服務器、網站導航
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯