当前位置:首页 > 综合实例 > 列表

PHP使用反向Ajax技术实现在线客服系统详解

发布:smiling 来源: PHP粉丝网  添加日期:2021-11-29 10:49:10 浏览: 评论:0 

这篇文章主要介绍了PHP使用反向Ajax技术实现在线客服系统,简单描述了反向ajax的概念、原理及使用反向ajax实现在线客服的相关操作技巧,需要的朋友可以参考下。

本文实例讲述了PHP使用反向Ajax技术实现在线客服系统,分享给大家供大家参考,具体如下:

反向Ajax技术,又称为服务器推技术,server push等。一般用于“在线客服”、“消息推送”、“即时通信”等功能中,比如新浪微博的私信功能,就是客户端不断的请求服务器并创建连接,去查看服务器有没有返回的信息,建立连接比较浪费服务器资源,下面我将根据客户端创建连接的不同性来介绍一下实现反向Ajax的三种思路。

三种思路:

1、间隔固定时间创建连接

这种方式就是按照固定时间不断的去请求服务器,当创建第一个连接时,不管是否有数据返回,此次连接都会失效,然后隔一段时间发出第二个请求,不断重复此动作,此法最浪费资源。

PHP在线客服 Ajax在线客服

2、长连接方式

这种方式始终只创建一个连接,而这个连接不断开,被称为长时连接,以此不断获取服务器推送的数据,这种方式只创建一个连接,比第一种方法较好。

PHP在线客服 Ajax在线客服

3、长连接+长轮询方式

这种方式始终创建连接,而这个连接也是长时连接,但是如果获得服务器推送的数据,此连接断开,然后隔固定时间创建第二此连接,这种方式最好,新浪微博的私信功能用的就是这种方法。

PHP在线客服 Ajax在线客服

在线客服系统

实现思路:

(1)咨询用户端发出问题,把问题存入数据库,把咨询内容显示到客服人员的聊天窗口中

(2)客服人员看到聊天窗口后,选择咨询用户,进行回复,然后把回复内容显示到客服人员窗口中

实现方法:

此系统我采用上述思想中的第二种和第三种方式共同实现,咨询用户端采用第三种方式实现,客服人员端采用第二种方式实现。

数据库信息:

mid:主键,pos表示发送人,rec表示接收人,isread表示是否已读,content表示咨询/回复内容。

PHP在线客服 Ajax在线客服

项目结构图:

PHP在线客服 Ajax在线客服

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

此处采用长连接。页面中主要有一个div,用于显示聊天信息,还有一个隐藏的iframe标签,这个iframe实现反向Ajax模型,用于发送长时连接,当服务器有数据时,服务器将调用comet()方法,此方法显示咨询内容,choose()方法是选择咨询人,resp()是回复方法,在这里会向16-kefu-sendmsg.php页面发出ajax请求,向数据库插入一条回复信息,回复成功后并显示到聊天窗口中。

  1. <?php 
  2. setcookie('username','admin'); 
  3. ?> 
  4. <!DOCTYPE html> 
  5. <html> 
  6. <head> 
  7.   <meta charset="utf-8"
  8.   <meta http-equiv="X-UA-Compatible" content="IE=edge"
  9.   <title>客服功能——客服人员端</title> 
  10.   <link rel="stylesheet" href=""
  11. <script> 
  12.   var xhr = new XMLHttpRequest(); 
  13.   //服务器调用函数 
  14.   function comet(json){ 
  15.     var content = '<p style="text-align:left"><span onclick="choose(\''+ json.pos +'\');">' + json.pos + '</span>说:'+json.content+'</p>'
  16.     var old = document.getElementById('chatArea').innerHTML; 
  17.     document.getElementById('chatArea').innerHTML = old + content; 
  18.   } 
  19.   //咨询人选择函数 
  20.   function choose(pos){ 
  21.     document.getElementById('postman').innerHTML = pos; 
  22.   } 
  23.   //客服人员回复函数 
  24.   function resp(){ 
  25.     var respContent = document.getElementById('respContent').value; 
  26.     var pos = document.getElementById('postman').innerHTML; 
  27.     if(respContent == '' || pos == ''){ 
  28.       alert('请重新选择回复人或填写回复内容'); 
  29.       return
  30.     } 
  31.     //ajax提交请求 
  32.     xhr.open('POST','16-kefu-sendmsg.php',true); 
  33.     xhr.setRequestHeader('Content-Type','application/x-www-form-urlencoded'); 
  34.     xhr.onreadystatechange = function (){ 
  35.       if(this.readyState == 4 && this.status == 200){ 
  36.         if(this.responseText == 'ok'){ 
  37.           //回复成功,把回复信息显示到聊天界面中 
  38.           var content = '<p style="text-align:right">你回复'+ pos + ':'+respContent+'</p>'
  39.           var old = document.getElementById('chatArea').innerHTML; 
  40.           document.getElementById('chatArea').innerHTML = old + content; 
  41.           document.getElementById('respContent').value = '';//给回复内容重新置空 
  42.         } 
  43.       } 
  44.     } 
  45.     var sendData = 'rec=' + pos + '&content='+respContent; 
  46.     xhr.send(sendData); 
  47.   }   
  48. </script> 
  49. <style> 
  50.   #chatArea{ 
  51.     width:500px; 
  52.     height:400px; 
  53.     border:1px solid black; 
  54.     overflow: scroll; 
  55.   } 
  56. </style> 
  57. </head> 
  58. <body> 
  59.   <h1>客服功能——客服人员端</h1> 
  60.   <h2>原理:iframe+长连接</h2> 
  61.   <div id="chatArea"
  62.   </div> 
  63.   <iframe width="0" height="0" frameborder="0" name="frame" src="./16-kefu-iframe.php"></iframe> 
  64.   <p>咨询人:<span id="postman"></span></p> 
  65.   <p><textarea id="respContent"></textarea></p> 
  66.   <p><input type="button" value="回复" onclick="resp();" /></p> 
  67. </body> 
  68. </html> 

发送咨询/回复消息(16-kefu-sendmsg.php)

主要是接受信息,把数据写入到数据库中

  1. <?php 
  2. /** 
  3.  * 客服回复咨询人,咨询人咨询客服 
  4.  * @author webbc 
  5.  */ 
  6. header('Content-type:text/html;charset=utf-8'); 
  7. require('./conn.php'); 
  8. $rec = $_POST['rec'];//咨询人变为接收者 
  9. $pos = $_COOKIE['username'];//客服人员变为发送者 
  10. $respContent = $_POST['content'];//客服人员的回复内容 
  11. $sql = "insert into msg (pos,rec,content) values ('$pos','$rec','$respContent')"
  12. echo mysql_query($sql) ? 'ok':'fail'
  13. ?> 

客户人请求咨询信息(16-kefu-iframe.php)

主要功能是保持连接永不断开,然后不断的从数据库读取一条未读的咨询消息,如果有消息,先设置该消息为已读,返回js脚本,影响iframe的父窗体

  1. <?php 
  2. /** 
  3.  * 通过iframe来实现反向Ajax 
  4.  * @author webbc 
  5.  */ 
  6. header('Content-type:text/html;charset=utf-8'); 
  7. set_time_limit(0);//设置页面永久执行 
  8. //ob_start();//打开输出缓存过了,就不需要使用此函数了 
  9. //由于浏览器是根据内容大小才先显示,可以先显示4000个空白字符串让浏览器可以继续显示 
  10. echo str_repeat(' ', 4000),"<br/>"
  11. ob_flush(); 
  12. flush(); 
  13. while(true){ 
  14.   //从数据库读取一条未读的咨询消息 
  15.   require('./conn.php'); 
  16.   $sql = "select * from msg where rec = 'admin' and isread = 0 limit 0,1"
  17.   $result = mysql_query($sql); 
  18.   $msg = mysql_fetch_assoc($result); 
  19.   //如果有消息 
  20.   if(!emptyempty($msg)){ 
  21.     //设置该消息为已读 
  22.     $sql = 'update msg set isread = 1 where mid = '.$msg['mid']; 
  23.     mysql_query($sql); 
  24.     $json = json_encode($msg);//把数组转换为json数据 
  25.     //返回js脚本,影响iframe的父窗体 
  26.     echo '<script>'
  27.     echo 'parent.window.comet(',$json,');'
  28.     echo '</script>'
  29.     ob_flush();//强制让php返回给apache 
  30.     flush();//强制让web服务器返回给浏览器 
  31.   } 
  32.   sleep(1);//隔1s循环查1次 
  33. ?> 

咨询人员界面(16-kefu-user.php):

此处采用长连接+长轮询的方式。当页面加载就发出一条ajax请求,如果该请求有数据返回,则显示到聊天窗口中,延时1s后重新发送请求,如果点击咨询,就发出ajax请求将咨询内容写入数据库中。

  1. <?php 
  2.   setcookie('username','user'.rand(10000,99999)); 
  3. ?> 
  4. <!DOCTYPE html> 
  5. <html> 
  6. <head> 
  7.   <meta charset="utf-8"
  8.   <meta http-equiv="X-UA-Compatible" content="IE=edge"
  9.   <title>客服功能——客服人员端</title> 
  10.   <link rel="stylesheet" href=""
  11. <script src="http://libs.baidu.com/jquery/1.7.2/jquery.min.js"></script> 
  12. <script> 
  13. //咨询方法 
  14. function ask(){ 
  15.   var askContent = $('#askContent').val(); 
  16.   if(askContent == ''){ 
  17.     alert('请输入咨询内容'); 
  18.     return ; 
  19.   } 
  20.   $.post('./16-kefu-sendmsg.php',{rec:'admin',content:askContent},function(res){ 
  21.     if(res == 'ok'){ 
  22.       $('<p style="text-align:right">你对客服说:'+askContent+'</p>').appendTo($('#chatArea')); 
  23.       $('#askContent').val(''); 
  24.     } 
  25.   }); 
  26. </script> 
  27. <style> 
  28.   #chatArea{ 
  29.     width:500px; 
  30.     height:400px; 
  31.     border:1px solid black; 
  32.     overflow: scroll; 
  33.   } 
  34. </style> 
  35. </head> 
  36. <body> 
  37.   <h1>客服功能——用户端</h1> 
  38.   <h2>原理:ajax+长连接+长轮询</h2> 
  39.   <div id="chatArea"
  40.   </div> 
  41.   <p><textarea id="askContent"></textarea></p> 
  42.   <p><input type="button" value="咨询" onclick="ask();" /></p> 
  43. </body> 
  44. <script> 
  45.   //长连接+长轮询 
  46.   var setting = { 
  47.     url:'16-kefu-ajax.php'
  48.     dataType:'json'
  49.     success:function(res){ 
  50.       $('<p style="text-align:left">客服对你说:'+res.content+'</p>').appendTo($('#chatArea')); 
  51.       var func = function(){$.ajax(setting)}; 
  52.       window.setTimeout(func,1000);//延时1s后重新发送连接 
  53.     } 
  54.   } 
  55.   $.ajax(setting); 
  56. </script> 
  57. </html> 

咨询人请求回复信息界面(16-kefu-ajax.php):

通过ajax+长轮询实现反向Ajax。请求数据,获取数据后,将数据置为已读,然后返回,结束本次连接。

  1. <?php 
  2. /** 
  3.  * 通过ajax+长轮询实现反向Ajax 
  4.  * @author webbc 
  5.  */ 
  6. set_time_limit(0);//不设置请求超时时间 
  7. require('./conn.php'); 
  8. $rec = $_COOKIE['username']; 
  9. $sql = "select * from msg where rec = '$rec' and isread = 0 limit 0,1"
  10. while(true){ 
  11.   $result = mysql_query($sql); 
  12.   $msg = mysql_fetch_assoc($result); 
  13.   //如果有客服人员的回复信息 
  14.   if(!emptyempty($msg)){ 
  15.     //把该信息置为已读 
  16.     $sql = "update msg set isread = 1 where mid = ".$msg['mid']; 
  17.     mysql_query($sql); 
  18.     echo json_encode($msg);//返回json数据 
  19.     exit();//如果此次连接获取数据,就结束本次连接 
  20.   } 
  21.   sleep(1);//隔一秒循环1次 
  22. ?> 

数据库连接文件(conn.php):

  1. <?php 
  2. $conn = mysql_connect('localhost','root','1234'); 
  3. mysql_query('use test;'); 
  4. mysql_query('set names utf8'); 
  5. ?> 

运行结果图:

PHP在线客服 Ajax在线客服

这里写图片描述

Tags: PHP在线客服 Ajax在线客服

分享到: