https://www.workerman.net/web-sender
下載源碼解壓后運行 start_for_win.bat 如果提示不成功,就把php路徑配置到環境變量中去即可
運行后打開瀏覽器輸入 域名:2123/ 這是消息接收頁面
主要js代碼
<script> $(document).ready(function () { // 連接服務端 var socket = io('http://'+document.domain+':2120'); // 連接后登錄 socket.on('connect', function(){ socket.emit('login', '77777'); }); // 后端推送來消息時 socket.on('new_msg', function(msg){ $('#content').html('收到消息:'+msg); $('.notification.sticky').notify(); }); // 后端推送來在線數據時 socket.on('update_online_count', function(online_stat){ $('#online_box').html(online_stat); }); }); </script>
要想給這個77777用戶發送消息其實只需要在瀏覽器中打開鏈接
格式:推送接口url:http://demos.workerman.net:2121/?type=publish&to=uid&content=content
其中to為接收消息的uid,如果傳空則向所有人推送消息 content 為消息內容
案例:
http://wk.com:2121/?type=publish&content=456789&to=77777
用這個例子測試后,接收頁面就會收到推送消息了,就是這么簡單,
如果要用到實際代碼中:只需要拼接這個url,吧發送的uid跟內容拼接在一起,然后拼接到url中,使用curl函數執行這條url就可以發送成功:
場景:
當給某個人發送消息,打開聊天窗口時,點擊發送內容,在發送的方法里同時使用下面的方法,執行一下 拼接好的url即可
后端調用api向任意用戶推送:
<?php // 指明給誰推送,為空表示向所有在線用戶推送 $to_uid = ""; // 推送的url地址,使用自己的服務器地址 $push_api_url = "http://workerman.net:2121/"; $post_data = array( "type" => "publish", "content" => "這個是推送的測試數據", "to" => $to_uid, ); $ch = curl_init (); curl_setopt ( $ch, CURLOPT_URL, $push_api_url ); curl_setopt ( $ch, CURLOPT_POST, 1 ); curl_setopt ( $ch, CURLOPT_HEADER, 0 ); curl_setopt ( $ch, CURLOPT_RETURNTRANSFER, 1 ); curl_setopt ( $ch, CURLOPT_POSTFIELDS, $post_data ); curl_setopt ($ch, CURLOPT_HTTPHEADER, array("Expect:")); $return = curl_exec ( $ch ); curl_close ( $ch ); var_export($return);
官方文檔:文檔地址:根目錄下的web目錄中index.html 是接收文檔
根目錄下的start_io.php 是推送消息文檔,
WEB消息推送框架
web-msg-sender是一款web長連接推送框架,采用PHPSocket.IO開發,基於WebSocket長連接通訊,如果瀏覽器不支持WebSocket則自動轉用comet推送。 通過后台推送消息,消息可以即時推送到客戶端,非輪詢,實時性非常好,性能很高。
- 多瀏覽器支持
- 支持針對單個用戶推送消息
- 支持向所有用戶推送消息
- 長連接推送(websocket或者comet),消息即時到達
- 支持在線用戶數實時統計展示
- 支持在線頁面數實時統計展示
- 支持跨域推送
下載
PHPSocket.IO開發手冊
PHPSocket.IO開發手冊Demo:
效果1:接收消息頁面:http://demos.workerman.net/web-sender/
推送接口url:http://demos.workerman.net:2121/?type=publish&to=uid&content=content
其中to為接收消息的uid,如果傳空則向所有人推送消息 content 為消息內容
效果2:
見本頁面頁腳在線統計部分,支持實時的在線人數和在線頁面統計
安裝啟動
首先:參考手冊檢查/安裝workerman環境
1、下載:(下載web-msg-sender,並解壓縮到任意目錄
2、啟動:linux系統cd到到框架目錄里運行php start.php start -d
。windows系統進入到框架目錄里雙擊start_for_win.bat文件啟動。
3、測試:瀏覽器訪問端口http://ip:2123或者http://域名:2123,例如 http://workerman.net:2123如圖:(如果無法訪問請檢查服務器防火牆,如果是雲服務器還要設置安全組)

前端測試:
<script src='http://cdn.bootcss.com/socket.io/1.3.7/socket.io.js'></script> <script> // 連接服務端,workerman.net:2120換成實際部署web-msg-sender服務的域名或者ip var socket = io('http://workerman.net:2120'); // uid可以是自己網站的用戶id,以便針對uid推送以及統計在線人數 uid = 123; // socket連接后以uid登錄 socket.on('connect', function(){ socket.emit('login', uid); }); // 后端推送來消息時 socket.on('new_msg', function(msg){ console.log("收到消息:"+msg); }); // 后端推送來在線數據時 socket.on('update_online_count', function(online_stat){ console.log(online_stat); }); </script>
后端調用api向任意用戶推送:
<?php // 指明給誰推送,為空表示向所有在線用戶推送 $to_uid = ""; // 推送的url地址,使用自己的服務器地址 $push_api_url = "http://workerman.net:2121/"; $post_data = array( "type" => "publish", "content" => "這個是推送的測試數據", "to" => $to_uid, ); $ch = curl_init (); curl_setopt ( $ch, CURLOPT_URL, $push_api_url ); curl_setopt ( $ch, CURLOPT_POST, 1 ); curl_setopt ( $ch, CURLOPT_HEADER, 0 ); curl_setopt ( $ch, CURLOPT_RETURNTRANSFER, 1 ); curl_setopt ( $ch, CURLOPT_POSTFIELDS, $post_data ); curl_setopt ($ch, CURLOPT_HTTPHEADER, array("Expect:")); $return = curl_exec ( $ch ); curl_close ( $ch ); var_export($return);