婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > PHP使用反向Ajax技術實現在線客服系統詳解

PHP使用反向Ajax技術實現在線客服系統詳解

熱門標簽:長春人工外呼系統服務商 怎么向銷售公司推銷外呼系統 江西手機自動外呼防封系統是什么 高德地圖標注家 廣州防封卡外呼系統多少錢一個月 哪里辦理400電話 外呼系統撥打暫時無法接通 廣東地市地圖標注 仁和怎么申請400開頭的電話

本文實例講述了PHP使用反向Ajax技術實現在線客服系統。分享給大家供大家參考,具體如下:

反向Ajax技術,又稱為服務器推技術,server push等。一般用于“在線客服”、“消息推送”、“即時通信”等功能中,比如新浪微博的私信功能,就是客戶端不斷的請求服務器并創建連接,去查看服務器有沒有返回的信息,建立連接比較浪費服務器資源,下面我將根據客戶端創建連接的不同性來介紹一下實現反向Ajax的三種思路。

三種思路:

1、間隔固定時間創建連接

這種方式就是按照固定時間不斷的去請求服務器,當創建第一個連接時,不管是否有數據返回,此次連接都會失效,然后隔一段時間發出第二個請求,不斷重復此動作,此法最浪費資源。

2、長連接方式

這種方式始終只創建一個連接,而這個連接不斷開,被稱為長時連接,以此不斷獲取服務器推送的數據,這種方式只創建一個連接,比第一種方法較好。

3、長連接+長輪詢方式

這種方式始終創建連接,而這個連接也是長時連接,但是如果獲得服務器推送的數據,此連接斷開,然后隔固定時間創建第二此連接,這種方式最好,新浪微博的私信功能用的就是這種方法。

在線客服系統

實現思路:

(1)咨詢用戶端發出問題,把問題存入數據庫,把咨詢內容顯示到客服人員的聊天窗口中
(2)客服人員看到聊天窗口后,選擇咨詢用戶,進行回復,然后把回復內容顯示到客服人員窗口中

實現方法:

此系統我采用上述思想中的第二種和第三種方式共同實現,咨詢用戶端采用第三種方式實現,客服人員端采用第二種方式實現。

數據庫信息:

mid:主鍵,pos表示發送人,rec表示接收人,isread表示是否已讀,content表示咨詢/回復內容。

項目結構圖:

客服人員界面(16-kefu-amdin.php):

此處采用長連接。頁面中主要有一個div,用于顯示聊天信息,還有一個隱藏的iframe標簽,這個iframe實現反向Ajax模型,用于發送長時連接,當服務器有數據時,服務器將調用comet()方法,此方法顯示咨詢內容,choose()方法是選擇咨詢人,resp()是回復方法,在這里會向16-kefu-sendmsg.php頁面發出ajax請求,向數據庫插入一條回復信息,回復成功后并顯示到聊天窗口中。

?php
setcookie('username','admin');
?>
!DOCTYPE html>
html>
head>
  meta charset="utf-8">
  meta http-equiv="X-UA-Compatible" content="IE=edge">
  title>客服功能——客服人員端/title>
  link rel="stylesheet" href="">
script>
  var xhr = new XMLHttpRequest();
  //服務器調用函數
  function comet(json){
    var content = 'p style="text-align:left">span onclick="choose(\''+ json.pos +'');">' + json.pos + '/span>說:'+json.content+'/p>';
    var old = document.getElementById('chatArea').innerHTML;
    document.getElementById('chatArea').innerHTML = old + content;
  }
  //咨詢人選擇函數
  function choose(pos){
    document.getElementById('postman').innerHTML = pos;
  }
  //客服人員回復函數
  function resp(){
    var respContent = document.getElementById('respContent').value;
    var pos = document.getElementById('postman').innerHTML;
    if(respContent == '' || pos == ''){
      alert('請重新選擇回復人或填寫回復內容');
      return;
    }
    //ajax提交請求
    xhr.open('POST','16-kefu-sendmsg.php',true);
    xhr.setRequestHeader('Content-Type','application/x-www-form-urlencoded');
    xhr.onreadystatechange = function (){
      if(this.readyState == 4  this.status == 200){
        if(this.responseText == 'ok'){
          //回復成功,把回復信息顯示到聊天界面中
          var content = 'p style="text-align:right">你回復'+ pos + ':'+respContent+'/p>';
          var old = document.getElementById('chatArea').innerHTML;
          document.getElementById('chatArea').innerHTML = old + content;
          document.getElementById('respContent').value = '';//給回復內容重新置空
        }
      }
    }
    var sendData = 'rec=' + pos + 'content='+respContent;
    xhr.send(sendData);
  }  
/script>
style>
  #chatArea{
    width:500px;
    height:400px;
    border:1px solid black;
    overflow: scroll;
  }
/style>
/head>
body>
  h1>客服功能——客服人員端/h1>
  h2>原理:iframe+長連接/h2>
  div id="chatArea">
  /div>
  iframe width="0" height="0" frameborder="0" name="frame" src="./16-kefu-iframe.php">/iframe>
  p>咨詢人:span id="postman">/span>/p>
  p>textarea id="respContent">/textarea>/p>
  p>input type="button" value="回復" onclick="resp();" />/p>
/body>
/html>

發送咨詢/回復消息(16-kefu-sendmsg.php)

主要是接受信息,把數據寫入到數據庫中

?php
/**
 * 客服回復咨詢人,咨詢人咨詢客服
 * @author webbc
 */
header('Content-type:text/html;charset=utf-8');
require('./conn.php');
$rec = $_POST['rec'];//咨詢人變為接收者
$pos = $_COOKIE['username'];//客服人員變為發送者
$respContent = $_POST['content'];//客服人員的回復內容
$sql = "insert into msg (pos,rec,content) values ('$pos','$rec','$respContent')";
echo mysql_query($sql) ? 'ok':'fail';
?>

客戶人請求咨詢信息(16-kefu-iframe.php)

主要功能是保持連接永不斷開,然后不斷的從數據庫讀取一條未讀的咨詢消息,如果有消息,先設置該消息為已讀,返回js腳本,影響iframe的父窗體

?php
/**
 * 通過iframe來實現反向Ajax
 * @author webbc
 */
header('Content-type:text/html;charset=utf-8');
set_time_limit(0);//設置頁面永久執行
//ob_start();//打開輸出緩存過了,就不需要使用此函數了
//由于瀏覽器是根據內容大小才先顯示,可以先顯示4000個空白字符串讓瀏覽器可以繼續顯示
echo str_repeat(' ', 4000),"br/>";
ob_flush();
flush();
while(true){
  //從數據庫讀取一條未讀的咨詢消息
  require('./conn.php');
  $sql = "select * from msg where rec = 'admin' and isread = 0 limit 0,1";
  $result = mysql_query($sql);
  $msg = mysql_fetch_assoc($result);
  //如果有消息
  if(!empty($msg)){
    //設置該消息為已讀
    $sql = 'update msg set isread = 1 where mid = '.$msg['mid'];
    mysql_query($sql);
    $json = json_encode($msg);//把數組轉換為json數據
    //返回js腳本,影響iframe的父窗體
    echo 'script>';
    echo 'parent.window.comet(',$json,');';
    echo '/script>';
    ob_flush();//強制讓php返回給apache
    flush();//強制讓web服務器返回給瀏覽器
  }
  sleep(1);//隔1s循環查1次
}
?>

咨詢人員界面(16-kefu-user.php):

此處采用長連接+長輪詢的方式。當頁面加載就發出一條ajax請求,如果該請求有數據返回,則顯示到聊天窗口中,延時1s后重新發送請求,如果點擊咨詢,就發出ajax請求將咨詢內容寫入數據庫中。

?php
  setcookie('username','user'.rand(10000,99999));
?>
!DOCTYPE html>
html>
head>
  meta charset="utf-8">
  meta http-equiv="X-UA-Compatible" content="IE=edge">
  title>客服功能——客服人員端/title>
  link rel="stylesheet" href="">
script src="http://libs.baidu.com/jquery/1.7.2/jquery.min.js">/script>
script>
//咨詢方法
function ask(){
  var askContent = $('#askContent').val();
  if(askContent == ''){
    alert('請輸入咨詢內容');
    return ;
  }
  $.post('./16-kefu-sendmsg.php',{rec:'admin',content:askContent},function(res){
    if(res == 'ok'){
      $('p style="text-align:right">你對客服說:'+askContent+'/p>').appendTo($('#chatArea'));
      $('#askContent').val('');
    }
  });
}
/script>
style>
  #chatArea{
    width:500px;
    height:400px;
    border:1px solid black;
    overflow: scroll;
  }
/style>
/head>
body>
  h1>客服功能——用戶端/h1>
  h2>原理:ajax+長連接+長輪詢/h2>
  div id="chatArea">
  /div>
  p>textarea id="askContent">/textarea>/p>
  p>input type="button" value="咨詢" onclick="ask();" />/p>
/body>
script>
  //長連接+長輪詢
  var setting = {
    url:'16-kefu-ajax.php',
    dataType:'json',
    success:function(res){
      $('p style="text-align:left">客服對你說:'+res.content+'/p>').appendTo($('#chatArea'));
      var func = function(){$.ajax(setting)};
      window.setTimeout(func,1000);//延時1s后重新發送連接
    }
  }
  $.ajax(setting);
/script>
/html>

咨詢人請求回復信息界面(16-kefu-ajax.php):

通過ajax+長輪詢實現反向Ajax。請求數據,獲取數據后,將數據置為已讀,然后返回,結束本次連接。

?php
/**
 * 通過ajax+長輪詢實現反向Ajax
 * @author webbc
 */
set_time_limit(0);//不設置請求超時時間
require('./conn.php');
$rec = $_COOKIE['username'];
$sql = "select * from msg where rec = '$rec' and isread = 0 limit 0,1";
while(true){
  $result = mysql_query($sql);
  $msg = mysql_fetch_assoc($result);
  //如果有客服人員的回復信息
  if(!empty($msg)){
    //把該信息置為已讀
    $sql = "update msg set isread = 1 where mid = ".$msg['mid'];
    mysql_query($sql);
    echo json_encode($msg);//返回json數據
    exit();//如果此次連接獲取數據,就結束本次連接
  }
  sleep(1);//隔一秒循環1次
}
?>

數據庫連接文件(conn.php):

?php
$conn = mysql_connect('localhost','root','1234');
mysql_query('use test;');
mysql_query('set names utf8');
?>

運行結果圖:

更多關于PHP相關內容可查看本站專題:《PHP+ajax技巧與應用小結》、《PHP網絡編程技巧總結》、《PHP基本語法入門教程》、《php面向對象程序設計入門教程》、《php字符串(string)用法總結》、《php+mysql數據庫操作入門教程》及《php常見數據庫操作技巧匯總》

希望本文所述對大家PHP程序設計有所幫助。

您可能感興趣的文章:
  • 反向Ajax 30分鐘快速掌握
  • 基于PHP技術開發客服工單系統
  • php 微信公眾平臺開發模式實現多客服的實例代碼
  • PHP+Mysql+Ajax實現淘寶客服或阿里旺旺聊天功能(前臺頁面)
  • PHP+jquery+ajax實現即時聊天功能實例
  • 發布一個迷你php+AJAX聊天程序[聊天室]提供下載
  • Ajax PHP JavaScript MySQL實現簡易無刷新在線聊天室
  • 值得分享的php+ajax實時聊天室
  • PHP+mysql+ajax輕量級聊天室實現方法詳解
  • 基于javascript、ajax、memcache和PHP實現的簡易在線聊天室

標簽:濮陽 梅河口 海北 廈門 湘西 黔東 文山 惠州

巨人網絡通訊聲明:本文標題《PHP使用反向Ajax技術實現在線客服系統詳解》,本文關鍵詞  PHP,使用,反向,Ajax,技術,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《PHP使用反向Ajax技術實現在線客服系統詳解》相關的同類信息!
  • 本頁收集關于PHP使用反向Ajax技術實現在線客服系統詳解的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    激情综合色综合久久综合| 中文字幕中文字幕一区| 久久婷婷国产综合精品青草| 亚洲自拍偷拍图区| 欧美日韩午夜在线| 日韩一区精品字幕| 91国偷自产一区二区使用方法| 国产亚洲美州欧州综合国| 久久国产三级精品| 国产丝袜美腿一区二区三区| 不卡的看片网站| 亚洲六月丁香色婷婷综合久久 | 精品在线免费观看| 日韩美女在线视频 | 99久久久免费精品国产一区二区| 国产精品嫩草影院com| 麻豆精品久久精品色综合| 日本在线不卡一区| 一区二区欧美国产| 欧美精品一区二区三区在线| 亚洲丝袜美腿综合| 欧美日韩久久一区二区| 日本美女视频一区二区| 久久久无码精品亚洲日韩按摩| 国产高清在线精品| 亚洲理论在线观看| 久久一区二区视频| 欧美三日本三级三级在线播放| 麻豆国产欧美日韩综合精品二区| 国产精品高清亚洲| 欧美va在线播放| 色噜噜夜夜夜综合网| 丝袜a∨在线一区二区三区不卡 | 国产日产欧美一区二区视频| 色婷婷久久久久swag精品| 日本亚洲欧美天堂免费| 国产精品久久久久aaaa樱花| 在线播放视频一区| av在线不卡观看免费观看| 日韩精品1区2区3区| 亚洲老妇xxxxxx| 国产三级精品三级在线专区| 欧美丰满美乳xxx高潮www| 奇米一区二区三区| 亚洲人成在线观看一区二区| 久久欧美中文字幕| 日韩视频免费直播| 欧美日韩综合在线免费观看| 91在线视频网址| 国产久卡久卡久卡久卡视频精品| 亚洲精品综合在线| 欧美国产成人在线| 久久人人爽人人爽| 精品久久人人做人人爰| 国产日韩成人精品| 久久久久久电影| 精品国产成人系列| 日韩欧美激情一区| 日韩精品一区二区在线观看| 欧美美女一区二区在线观看| 91国产视频在线观看| 91美女片黄在线| 色综合色狠狠综合色| 成人app在线观看| 99在线精品一区二区三区| 成人高清免费观看| 制服丝袜中文字幕亚洲| 91搞黄在线观看| 在线观看成人小视频| 欧美这里有精品| 制服丝袜亚洲色图| 日韩女优毛片在线| 制服丝袜亚洲播放| 久久久不卡影院| 国产亚洲精品bt天堂精选| www一区二区| 久久久久久99精品| 中文字幕av一区二区三区高| 国产精品美女久久久久高潮| 亚洲免费电影在线| 午夜欧美视频在线观看| 精品一区二区三区视频在线观看| 久久av资源网| 成人毛片在线观看| 欧美色区777第一页| 日韩三级视频中文字幕| 国产亚洲精品福利| 亚洲午夜精品在线| 午夜精品福利一区二区三区蜜桃| 中文字幕国产一区| 亚洲综合网站在线观看| 欧美a级一区二区| 免费成人在线观看| 麻豆成人久久精品二区三区小说| 亚洲福中文字幕伊人影院| 国产精品二三区| 亚洲国产一区二区三区青草影视| 亚洲女人****多毛耸耸8| 亚洲成a人片综合在线| 奇米在线7777在线精品| 国产宾馆实践打屁股91| 99久精品国产| 欧美一卡二卡三卡四卡| 久久一区二区三区四区| 亚洲一区二区av电影| 美女看a上一区| 国产乱码精品一区二区三区忘忧草 | 欧美极品美女视频| 亚洲国产一区二区视频| 免费观看30秒视频久久| 久久av中文字幕片| 欧美亚洲国产一区二区三区va | www.欧美.com| av电影在线观看完整版一区二区| 欧美伊人精品成人久久综合97| 777亚洲妇女| 国产精品免费免费| 国产高清在线精品| 色屁屁一区二区| 欧美日韩国产三级| 亚洲人亚洲人成电影网站色| 五月婷婷另类国产| 成人av网址在线| 国产日韩欧美一区二区三区乱码 | 日韩精品高清不卡| 韩国一区二区视频| 欧美午夜片在线观看| 日韩精品一区二区三区中文精品| 一区二区中文视频| 国产精品一卡二卡| 欧洲av一区二区嗯嗯嗯啊| 成人黄页毛片网站| 欧美日韩国产一二三| 久久中文娱乐网| 国内精品写真在线观看| 91视视频在线直接观看在线看网页在线看 | www.亚洲免费av| 欧美大尺度电影在线| 亚洲国产精品久久人人爱蜜臀| 国产一区二区三区高清播放| 日韩欧美精品三级| 五月开心婷婷久久| 欧美三级韩国三级日本一级| 亚洲午夜久久久| 成人av在线电影| 国产精品日日摸夜夜摸av| 成人一区二区三区视频在线观看 | 3751色影院一区二区三区| 自拍偷拍国产精品| 国产iv一区二区三区| 国产精品家庭影院| 国产精品99久久久久久有的能看| 日韩欧美aaaaaa| 国产成人一区在线| 久久免费视频一区| 精品一区二区免费在线观看| 久久久久高清精品| 国产成人精品免费在线| 亚洲欧洲性图库| 久久综合九色综合97_久久久| 午夜精品福利一区二区三区蜜桃| 高清beeg欧美| 国产精品久久久久毛片软件| 成人午夜又粗又硬又大| 久久久久国产成人精品亚洲午夜| 国产成人精品综合在线观看| 日韩毛片视频在线看| 成人a级免费电影| 午夜成人免费视频| 日韩精品资源二区在线| 国产盗摄女厕一区二区三区 | 亚洲一区在线观看网站| 91精品中文字幕一区二区三区| 日韩激情视频在线观看| 久久亚洲精华国产精华液| 在线观看视频一区| 日本欧洲一区二区| 精品久久久影院| 欧美系列在线观看| 精品一区二区影视| 国产精品久久久爽爽爽麻豆色哟哟 | 国产精品成人网| 欧美大度的电影原声| eeuss国产一区二区三区| 亚洲一区二区三区四区在线观看 | 日韩一区二区三区免费看| 久久97超碰国产精品超碰| √…a在线天堂一区| 国产精品久久久久精k8| 91天堂素人约啪| 国产在线视视频有精品| 亚洲精品videosex极品| 日韩精品专区在线| 欧美一区二区在线播放| 成人av网在线| 国产成人激情av| 国产精品一区二区果冻传媒| 亚洲精品欧美在线| 亚洲成人免费av| 中文字幕字幕中文在线中不卡视频|