PHP+Mysql+Ajax实现淘宝客服或阿里旺旺聊天功能(前台页面)


Posted in PHP onJune 16, 2017

首先来看一下我已经实现的效果图:

消费者页面:(本篇随笔)

(1)会显示店主的头像

(2)当前用户发送信息显示在右侧,接受的信息,显示在左侧

PHP+Mysql+Ajax实现淘宝客服或阿里旺旺聊天功能(前台页面)

店主或客服页面:(下一篇随笔)

(1)在左侧有一个列表 ,会显示所有与店主对话的顾客;该列表可以移动;有新消息时会提示;也可以清空该聊天记录

(2)点击列表里的顾客进入右边的对话框界面,显示与该顾客的聊天信息

PHP+Mysql+Ajax实现淘宝客服或阿里旺旺聊天功能(前台页面)

 在实现功能之前,来说一下我用到的两张表:

PHP+Mysql+Ajax实现淘宝客服或阿里旺旺聊天功能(前台页面)

 解释一下:bkid在此处没有用到;isok列是用来判断消息是否已读,未读为0;

现在,来说一下步骤:(分前台和后台两部分)

在这篇随笔中我们首先来说一下前台页面是如何实现的:(李四登录)

PHP+Mysql+Ajax实现淘宝客服或阿里旺旺聊天功能(前台页面)

用session存取一下lisi;便于后面从user表中取数据

1、布局页面代码以及读取数据代码:

<!--中间内容-->
 <div id="zhongjian">
  <div id="kuangjia" style="height: 550px;width: 620px; margin: 0px auto;border: 1px solid gainsboro;background-color: white;">
   <div id="neirong" style="height: 400px;width: 600px;">
    <div style="height: 100px;width: 620px;background-image: url(../img/bj4.jpg);">
  //取店主用户名,显示店主的头像和姓名<br><?php
   $uid = $_SESSION["uid"];  
   $sql = "select * from users where uid='zhangsan'";
   $arr = $db->query($sql);
   foreach($arr as $v)
   {    
   echo "
   <div style='height:100px;float:left;width:100px;float:left;'>
    <div style='border:2px solid grey;height:84px;width:84px;margin:7px auto; border-radius:10px;overflow:hidden'>
    <img src='{$v[6]}' height='80px' width='80px'/>
    </div>
    </div>
    <div style='height:100px;width:500px;float:left;'>
    <div style='height:50px;width:500px;text-align:left;line-height:50px'>
     亲爱的店主
    </div>   
     <div style='height:50px;width:500px;text-align:left;'>个性签名:
     <input type='text' placeholder='不读书怎么对得起今天!' style='width:280px'>        
    </div>
    </div>
    "; 
   }   
   ?>
   </div>
   <div style="height: 300px;width: 620px;overflow: auto;overflow-x:hidden ;"><br>         //获取session里存取的uid;
    <?php
     $uid = $_SESSION["uid"];     
     $sql3 = "select * from users where uid='{$uid}'";
         $arr3 = $db->query($sql3);<br>//从对话表里读取店主张三和李四所有的对话信息,并按对话时间顺序排序
     $sql2="select * from duihua where uid='{$uid}' or jsid='{$uid}' order by dhtime";     
     $arr2= $db->query($sql2);
     foreach($arr2 as $n)
     {<br>        //如果是店主,则信息要显示在左侧
     if($n[2]=='zhangsan')
     {
     echo "<div style='height:100px;width:600px;'>
     <div style='height:100px;width:250px;float:left'>
      <div style='height:20px;width:250px;font-size:13px;padding-left:20px'>
        {$n[6]}</div>
      <div style='height:80px;width:50px;float:left'>
       <div style='height:50px;width:50px;margin:0px auto; border-radius:90px;overflow:hidden;'>
        <img src='{$v[6]}' height='50px' width='50px'/>
       </div>
      </div>
      <div style='min-height:40px;width:200px;float:left;background-color:cornflowerblue; border-bottom-right-radius: 10px;border-top-right-radius: 10px;border-top-left-radius: 40px;border-bottom-left-radius: 40px;'>
       <p style='padding-left:20px; line-height:40px'>
        {$n[4]}</p>        
      </div>     
     </div></div>";
     } <br>//如果是李四,则显示在右侧    
     if($n[2]==$uid)
     {            
     echo "<div style='height:100px;width:600px;margin-right:20px'>
     <div style='height:100px;width:250px; float:right'>
      <div style='height:20px;width:250px;font-size:13px;padding-right:20px'>
        {$n[6]}</div>
      <div style='height:80px;width:50px;float:right'>
       <div style='height:50px;width:50px;margin:0px auto; border-radius:90px;overflow:hidden;'>
        <img src='{$arr3[0][6]}' height='50px' width='50px'/>
       </div>
      </div>
      <div style='min-height:40px;width:200px;float:right;background-color:pink; border-bottom-left-radius: 10px;border-top-left-radius: 10px;border-top-right-radius: 40px;border-bottom-right-radius: 40px;'>
       <p style='padding-left:20px; line-height:40px'>
        {$n[4]}</p>        
      </div>     
     </div></div>"; 
     }          
     }  
     ?>   
   </div>  
   </div> <!--id="neirong"--><br>
  <form role="form">
   <div class="form-group">
   <textarea class="form-control" rows="3" id="words"></textarea> //输入发送内容
   </div>
  </form>
  <div id="fs" style="height: 50px; width: 600px;text-align: right; padding-right: 50px;">
  <button type="button" class="btn btn-success fasong">发送</button>  //点击按钮发送
  </div>
  </div>   
  </div> <!--id=zhongjian-->

实现效果:

PHP+Mysql+Ajax实现淘宝客服或阿里旺旺聊天功能(前台页面)

2、点击发送时的ajax代码:

<script>
 $(".tc").click(function(){
  $("#kuangjia").show();  
 })
  $(".fasong").click(function(){
  var nr=$("#words").val();
  $.ajax({
   url:"qt-speak-cl.php",
   data:{words:nr},
   type:"POST",
   dataType:"TEXT",
   success: function(data){
    if(data==1)
    {
    window.location.href="qt-dh.php" rel="external nofollow" rel="external nofollow" ; 
    }
    else{
     alert("发送内容不能为空!");
    }
    }
  })
 }) 
  $("#dh").click(function(){
  $.ajax({
   url:"qt-yidu-cl.php",
   dataType:"TEXT",
   success: function(data){
//    alert(data);     
    window.location.href="qt-dh.php" rel="external nofollow" rel="external nofollow" ;    
   }   
  })
 })
</script>

 3、qt-speak-cl.php页面:

<?php
session_start();
require "DBDA.class.php";
$db = new DBDA(); 
$uid = $_SESSION["uid"];
$words =$_POST["words"];
$chtime=date("Y-m-d H:i:s",time());
$jieshou = "zhangsan";
if(!empty($words))
{
$sql="insert into duihua values ('','{$jieshou}','{$uid}','','{$words}',0,'{$chtime}')";
echo $db->query($sql,0);
<em id="__mceDel">}
else
{ 
 echo "发送内容不能为空!";
}
?>
</em>

 如果发送内容为空,则会提示“发送内容不能为空!”

PHP+Mysql+Ajax实现淘宝客服或阿里旺旺聊天功能(前台页面)

前台页面会随不同用户登录显示不同的信息;让王五登录看看:

PHP+Mysql+Ajax实现淘宝客服或阿里旺旺聊天功能(前台页面)

以上所述是小编给大家介绍的PHP+Mysql+Ajax实现淘宝客服或阿里旺旺聊天功能(前台页面),希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

PHP 相关文章推荐
使用数据库保存session的方法
Oct 09 PHP
PHP array_multisort()函数的使用札记
Jul 03 PHP
有关phpmailer的详细介绍及使用方法
Jan 28 PHP
深入理解curl类,可用于模拟get,post和curl下载
Jun 08 PHP
php实现的返回数据格式化类实例
Sep 22 PHP
3款值得推荐的微信开发开源框架
Oct 28 PHP
PHP随机生成唯一HASH值自定义函数
Apr 20 PHP
PHP的swoole扩展安装方法详细教程
May 18 PHP
PHP使用两个栈实现队列功能的方法
Jan 15 PHP
php处理抢购类功能的高并发请求
Feb 08 PHP
CentOS7.0下安装PHP5.6.30服务的教程详解
Sep 29 PHP
Laravel 解决composer相关操作提示php相关异常的问题
Oct 23 PHP
php使用str_replace替换多维数组的实现方法分析
Jun 15 #PHP
php读取出一个文件夹及其子文件夹下所有文件的方法示例
Jun 15 #PHP
php7基于递归实现删除空文件夹的方法示例
Jun 15 #PHP
php实现的二叉树遍历算法示例
Jun 15 #PHP
深入浅析PHP的session反序列化漏洞问题
Jun 15 #PHP
PHP中phar包的使用教程
Jun 14 #PHP
iis 7下安装laravel 5.4环境的方法教程
Jun 14 #PHP
You might like
php+jquery编码方面的一些心得(utf-8 gb2312)
2010/10/12 PHP
PHP引用符&amp;的用法详细解析
2013/08/22 PHP
详解PHP中mb_strpos的使用
2018/02/04 PHP
jquery checkbox全选、取消全选实现代码
2010/03/05 Javascript
JQuery live函数
2010/12/24 Javascript
JQuery的Ajax请求实现局部刷新的简单实例
2014/02/11 Javascript
scrollWidth,clientWidth,offsetWidth的区别
2015/01/13 Javascript
jquery制作LED 时钟特效
2015/02/01 Javascript
javascript中caller和callee详解
2015/08/10 Javascript
基于jQuery仿淘宝产品图片放大镜特效
2020/10/19 Javascript
javascript与jquery动态创建html元素示例
2016/07/25 Javascript
AngularJS中过滤器的使用与自定义实例代码
2016/09/17 Javascript
Vue 过渡实现轮播图效果
2017/03/27 Javascript
小程序云开发实现数据库异步操作同步化
2019/05/18 Javascript
js实现选项卡效果
2020/03/07 Javascript
一些常用的Python爬虫技巧汇总
2016/09/28 Python
PyQt5每天必学之弹出消息框
2018/04/19 Python
Python基于xlrd模块操作Excel的方法示例
2018/06/21 Python
基于Python的图像数据增强Data Augmentation解析
2019/08/13 Python
python遍历文件目录、批量处理同类文件
2019/08/31 Python
windows下Python安装、使用教程和Notepad++的使用教程
2019/10/06 Python
Python OpenCV图像指定区域裁剪的实现
2019/10/30 Python
python默认参数调用方法解析
2020/02/09 Python
Python实现从N个数中找到最大的K个数
2020/04/02 Python
Python word文本自动化操作实现方法解析
2020/11/05 Python
编写一个类体现构造,公有,私有方法,静态,私有变量
2013/08/10 面试题
优秀员工自荐书范文
2013/12/08 职场文书
大学生优秀团员事迹材料
2014/01/30 职场文书
初三学生评语大全
2014/04/24 职场文书
金融事务专业求职信
2014/04/25 职场文书
大学计划书范文800字
2014/08/14 职场文书
大学生实习推荐信
2015/03/27 职场文书
2015年安全保卫工作总结
2015/05/14 职场文书
毕业实习感受与体会
2015/05/26 职场文书
工人先锋号事迹材料(2016精选版)
2016/03/01 职场文书
JavaScript如何利用Promise控制并发请求个数
2021/05/14 Javascript