>  기사  >  백엔드 개발  >  Thinkphp는 AJAX 롱 폴링을 결합하여 PC 및 APP 푸시를 구현합니다.

Thinkphp는 AJAX 롱 폴링을 결합하여 PC 및 APP 푸시를 구현합니다.

不言
不言원래의
2018-05-08 11:23:342205검색

이 글은 주로 AJAX 롱 폴링과 결합하여 PC와 APP에 대한 푸시를 구현하는 데 사용됩니다. 이제는 모든 사람과 공유할 수 있습니다.

Foreword

주로 PC 및 APP 푸시를 구현하기 위해 AJAX 롱 폴링과 결합된 Thinkphp에 대한 관련 내용을 소개하겠습니다. 더 이상 고민하지 않고 자세한 소개를 살펴보겠습니다.

로직 구현

특정 작업(예: 새 공지 작성) 후 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;
}

푸시할 플래그를 감지 및 설계하고, 그렇지 않으면 오프라인 메시지를 자체 데이터 구조로 수정해야 합니다!

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(&#39;<li class="llt" data-ccid="&#39; + item.id + &#39;"><a href="{:url(" rel="external nofollow" admin/carloan/edit")}?id=&#39;+item.log_c_id+&#39;"><span class="label label-info"><i class="icon-bullhorn"></i></span><span class="message">&#39; + item.u_name + &#39;:&#39; + item.log_content + &#39;</span><span class="time"><span class="liveTime">&#39; + item.log_time + &#39;</span></span></a></li>&#39;);
    });
   }else{
   }
  }
 };
 //关键在这里,Ajax定时访问服务端,不断获取数据 ,这里是1秒请求一次。
 window.setInterval(function () {
  $.ajax(getting)
 }, 1000);

관련 권장사항:

비동기 이미지 전송 샘플 코드를 구현하기 위해 Thinkphp와 ajaxFileUpload를 결합한 자세한 설명

ThinkPHP와 ajax, Mysql을 결합하여 클라이언트 통신 기능 구현 코드 example_PHP 튜토리얼

위 내용은 Thinkphp는 AJAX 롱 폴링을 결합하여 PC 및 APP 푸시를 구현합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.