首页 > 作文

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

更新时间:2023-04-07 15:32:18 阅读: 评论:0

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

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

三种思路:英语小短文带翻译

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

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

2、长连接方式

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

3、长连接+长轮询方式

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

在线客服系统

实现思路:

(1)咨询用户端发出问题,把问题存入数据库,把咨询内容显示到客服人员的聊天窗口中
(2)客服人员看到聊天窗口后,选择咨询用户,进行回复,然后把回复内容显示到客服人员窗口中

实现方法:

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

数据库信息:

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

项目结构图:

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

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

<?phptcookie('urname','admin');?><!doctype html><html><head>  <meta chart="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="choo(\''+ json.pos +'\');">' + json.pos + '</span>说:'+json.content+'</p>';    var old = document.getelementbyid('chatarea').innerhtml;    document.getelementbyid('chatarea').innerhtml = old + content;  }  //咨询人选择函数  function choo(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-ndmsg.php',true);    xhr.trequestheader('content-type','application/x-www-form-urlencoded');    xhr.onreadystatechange = function (){      if(this.readystat缱倦怎么念e == 4 && this.status == 200){        if(this.respontext == 'ok'){          //回复成功,把回复信息显示到聊天界面中          var content = '<p style="text-align:right">你回复'+ pos + ':'+respcontent+'</p>';          var old = document.getelementbyid('chatarea').innerhtml;          document.getelementbyid('chatarea').innerhtml = old + co作文 那一次我哭了ntent;          document.getelementbyid('respcontent').value = '';//给回复内容重新置空        }      }    }    var nddata = 'rec=' + pos + '&content='+respcontent;    xhr.nd(nddata);  }  </script><style>  #chatarea{    width:500px;    height:400px;    border:1px solid black;    overflow: scroll;  }</style></head><body>  <h1>客服功能——客服人员端</h1>  <h2>原理:iframe+长连接</h2&g形容教师的成语t;  <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-ndmsg.php)

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

<?php/** * 客服回复咨询人,咨询人咨询客服 * @author webbc */header('content-type:text/html;chart=utf-8');require('./conn.php');$rec = $_post['rec'];//咨询人变为接收者$pos = $_cookie['urname'];//客服人员变为发送者$respcontent = $_post['content'];//客服人员的回复内容$sql = "inrt 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;chart=utf-8');t_time_limit(0);//设置页面永久执行//ob_start();//打开输出缓存过了,就不需要使用此函数了//由于浏览器是根据内容大小才先显示,可以先显示4000个空白字符串让浏览器可以继续显示echo str_repeat(' ', 4000),"<br/>";ob_flush();flush();while(true){  //从数据库读取一条未读的咨询消息  require('./conn.php');  $sql = "lect * 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 t 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-ur.php):

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

<?php  tcookie('urname','ur'.rand(10000,99999));?><!doctype html><html><head>  <meta chart="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-ndmsg.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 tting = {    url:'16-kefu-ajax.php',    datatype:'json',    success:function(res){      $('<p style="text-align:left">客服对你说:'+res.content+'</p>').appendto($('#chatarea'));      var satisfactionfunc = function(){$.ajax(tting)};      window.ttimeout(func,1000);//延时1s后重新发送连接    }  }  $.ajax(tting);</script></html>

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

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

<?php/** * 通过ajax+长轮询实现反向ajax * @author webbc */t_time_limit(0);//不设置请求超时时间require('./conn.php');$rec = $_cookie['urname'];$sql = "lect * 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 t 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('u test;');mysql_query('t names utf8');?>

运行结果图:

本文发布于:2023-04-07 15:32:16,感谢您对本站的认可!

本文链接:https://www.wtabcd.cn/fanwen/zuowen/3823c9b3af58832b5aa0eeb47b1cfc4c.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

本文word下载地址:PHP使用反向Ajax技术实现在线客服系统详解.doc

本文 PDF 下载地址:PHP使用反向Ajax技术实现在线客服系统详解.pdf

标签:客服   人员   数据   方式
相关文章
留言与评论(共有 0 条评论)
   
验证码:
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图