這篇文章主要介紹了關於Thinkphp結合AJAX長輪詢實現PC與APP的推送,有著一定的參考價值,現在分享給大家,有需要的朋友可以參考一下
前言
本文主要介紹給大家介紹的Thinkphp結合AJAX長輪詢實作PC與APP推送的相關內容,分享出來供大家參考學習,話不多說,來一起看看詳細的介紹。
實作邏輯
某個操作(例如新公告)後,觸發同時推播訊息給APP或是移動WEB的所有使用者或指定使用者。
不論效能,總是有人會用到吧,實作如下(基於Thinkphp5訊息推播):
PHP長輪詢
##
/* * long轮询 API查询接口 */ public function id_log() { if (request()->isPost()) { $id = $this->param['id']; set_time_limit(0); $id_log = Db::name('table')->alias('c') ->join('table cc', 'c.youname=cc.youname', 'left') ->join('table a', 'cc.youname =a.youname ', 'left') ->join('table u', 'c.youname =u.youname ', 'left') ->field('') ->where('', $id) ->order('log_time desc') ->limit(1) ->select(); while (true) { if ($id_log) { $id_log_set = Db::name('table2') ->where('', $id) ->limit(1) ->setField('log_flag', '1'); $this->response($id_log); } $this->wrong(404100); usleep(2000); } }; }換上你自己的表格和相關的關聯欄位。
推播訊息建立方法
#
/** * 创建消息日志 触发操作方法 * @param string $log_content 日志内容 * @param string $log_type 日志类型 * @param int $log_c_id A用户ID * @param string $log_user B用户ID * @param string $log_admin PC * @param string $log_status * @return array */ function createLog($log_c_id, $log_type, $log_content, $log_admin, $log_user,$log_status) { $data = [ 'log_c_id' => $log_c_id, 'log_ip' => get_client_ip(), 'log_admin' => $log_admin, 'log_time' => date("Y-m-d H:i:s", time()), 'log_url' => get_url(), 'log_type' => $log_type, 'log_content' => $log_content, 'log_user' => $log_user, 'log_status'=>$log_status ]; $logadd = \think\Db::name('table')->insertGetId($data); return $logadd; }採用資料庫存訊息並偵測與設計flag的形式推,不然離線訊息就沒辦法推了,同樣的要修改成你自己的資料結構!
AJAX長輪詢
#
var getting = { url: '{:url("youapi/url")}', dataType: 'json', success: function (res) { $(".count").text($('.llt').children().size()); $(".llt").remove(); if(res.length!=null){ $.each(res, function (index, item) { $(".notification").append('<li class="llt" data-ccid="' + item.id + '"><a href="{:url(" rel="external nofollow" admin/carloan/edit")}?id='+item.log_c_id+'"><span class="label label-info"><i class="icon-bullhorn"></i></span><span class="message">' + item.u_name + ':' + item.log_content + '</span><span class="time"><span class="liveTime">' + item.log_time + '</span></span></a></li>'); }); }else{ } } }; //关键在这里,Ajax定时访问服务端,不断获取数据 ,这里是1秒请求一次。 window.setInterval(function () { $.ajax(getting) }, 1000);相關推薦:
詳解Thinkphp結合ajaxFileUpload實作非同步圖片傳輸範例程式碼
ThinkPHP結合ajax、Mysql實作的客戶端通訊功能程式碼範例_PHP教學
#
以上是Thinkphp結合AJAX長輪詢實作PC與APP的推送的詳細內容。更多資訊請關注PHP中文網其他相關文章!