溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

PHP+Mysql+Ajax怎么實(shí)現(xiàn)淘寶客服或阿里旺旺聊天功能

發(fā)布時間:2021-05-18 13:42:38 來源:億速云 閱讀:163 作者:小新 欄目:開發(fā)技術(shù)

這篇文章主要介紹了PHP+Mysql+Ajax怎么實(shí)現(xiàn)淘寶客服或阿里旺旺聊天功能,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

首先來看一下我已經(jīng)實(shí)現(xiàn)的效果圖:

消費(fèi)者頁面:

(1)會顯示店主的頭像

(2)當(dāng)前用戶發(fā)送信息顯示在右側(cè),接受的信息,顯示在左側(cè)

PHP+Mysql+Ajax怎么實(shí)現(xiàn)淘寶客服或阿里旺旺聊天功能

店主或客服頁面:(下一篇隨筆)

(1)在左側(cè)有一個列表 ,會顯示所有與店主對話的顧客;該列表可以移動;有新消息時會提示;也可以清空該聊天記錄

(2)點(diǎn)擊列表里的顧客進(jìn)入右邊的對話框界面,顯示與該顧客的聊天信息

PHP+Mysql+Ajax怎么實(shí)現(xiàn)淘寶客服或阿里旺旺聊天功能

 在實(shí)現(xiàn)功能之前,來說一下我用到的兩張表:

PHP+Mysql+Ajax怎么實(shí)現(xiàn)淘寶客服或阿里旺旺聊天功能

 解釋一下:bkid在此處沒有用到;isok列是用來判斷消息是否已讀,未讀為0;

現(xiàn)在,來說一下步驟:(分前臺和后臺兩部分)

在這篇隨筆中我們首先來說一下前臺頁面是如何實(shí)現(xiàn)的:(李四登錄)

PHP+Mysql+Ajax怎么實(shí)現(xiàn)淘寶客服或阿里旺旺聊天功能

用session存取一下lisi;便于后面從user表中取數(shù)據(jù)

1、布局頁面代碼以及讀取數(shù)據(jù)代碼:

<!--中間內(nèi)容-->
 <div id="zhongjian">
  <div id="kuangjia" >
   <div id="neirong" >
    <div >
  //取店主用戶名,顯示店主的頭像和姓名<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 ><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>        //如果是店主,則信息要顯示在左側(cè)
     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>//如果是李四,則顯示在右側(cè)    
     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> //輸入發(fā)送內(nèi)容
   </div>
  </form>
  <div id="fs" >
  <button type="button" class="btn btn-success fasong">發(fā)送</button>  //點(diǎn)擊按鈕發(fā)送
  </div>
  </div>   
  </div> <!--id=zhongjian-->   

實(shí)現(xiàn)效果:

PHP+Mysql+Ajax怎么實(shí)現(xiàn)淘寶客服或阿里旺旺聊天功能

2、點(diǎn)擊發(fā)送時的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("發(fā)送內(nèi)容不能為空!");
    }
    }
  })
 }) 
  $("#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 "發(fā)送內(nèi)容不能為空!";
}
?>
</em>

 如果發(fā)送內(nèi)容為空,則會提示“發(fā)送內(nèi)容不能為空!”

PHP+Mysql+Ajax怎么實(shí)現(xiàn)淘寶客服或阿里旺旺聊天功能

前臺頁面會隨不同用戶登錄顯示不同的信息;讓王五登錄看看:

PHP+Mysql+Ajax怎么實(shí)現(xiàn)淘寶客服或阿里旺旺聊天功能

PHP開發(fā)環(huán)境搭建工具有哪些

一、phpStudy,是一個新手入門最常用的開發(fā)環(huán)境。二、WampServer,WampServer也同樣的也是和phpStudy一樣操作簡單對小白比較友好。三、XAMPP,XAMPP(Apache+MySQL+PHP+PERL)是一個功能強(qiáng)大的建站集成軟件包;四、MAMP,MAMP分為兩種MAMP和MAMP Pro for Mac。五、寶塔面板,寶塔面板是一款服務(wù)器管理軟件,支持windows和linux系統(tǒng)。六、UPUPW,UPUPW是目前Windows平臺下最具特色的Web服務(wù)器PHP套件。

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“PHP+Mysql+Ajax怎么實(shí)現(xiàn)淘寶客服或阿里旺旺聊天功能”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關(guān)注億速云行業(yè)資訊頻道,更多相關(guān)知識等著你來學(xué)習(xí)!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI