php - 有新帖子时,如何让我的聊天脚本播放声音?

标签 php javascript audio chat

聊天页面JavaScript:
有新帖子时,如何让我的聊天脚本播放声音?

这是我正在使用的3个脚本:

<script type="text/javascript"><!--
function showmessages(){
   if(window.XMLHttpRequest){
      xmlhttp = new XMLHttpRequest();
      xmlhttp.open("GET","show-messages.php?" + Math.random(),false);
      xmlhttp.send(null);
   }
   else{
      xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
      xmlhttp.open("GET","showmessages.php?" + Math.random(),false);
      xmlhttp.send();
   }
   document.getElementById('messages').innerHTML = xmlhttp.responseText;
   setTimeout('showmessages()',5000);
}

showmessages();
function send(){
   var sendto = 'send.php?message=' + document.getElementById('message').value + '&name=' + document.getElementById('name').value;
   if(window.XMLHttpRequest){
      xmlhttp = new XMLHttpRequest();
      xmlhttp.open("GET",sendto,false);
      xmlhttp.send(null);
   }
   else{
      xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
      xmlhttp.open("GET",sendto,false);
      xmlhttp.send();
   }
   var error = '';
   switch(parseInt(xmlhttp.responseText)){
   case 1:
      error = '<span class="pink">The database is down!</span>';
      break;
   case 2:
      error = '<span class="pink">The database is down!</span>';
      break;
   case 3:
      error = '<span class="pink">Don`t forget the message!</span>';
      break;
   case 4:
      error = '<span class="pink">The message is too long!</span>';
      break;
   case 5:
      error = '<span class="pink">Don`t forget the name!</span>';
      break;
   case 6:
      error = '<span class="pink">The name is too long!</span>';
      break;
   case 7:
      error = '<span class="pink">This name is already used by somebody else!</span>';
      break;
   case 8:
      error = '<span class="pink">The database is down!</span>';
   }
   if(error == ''){
      document.getElementById('error').innerHTML = '';
      showmessages();
   }
   else{
      document.getElementById('error').innerHTML = error;
   }
}
// --></script>



Your Name: <input type="text" id="name" value="" /><br />
Enter Your Message:<br /><textarea id="message" cols="20" rows="2"></textarea><br /> 
<input type="button" value="Send" onClick="send();document.getElementById('message').value = '';"/>

<div id="messages"></div>
<div id="error"></div>

show-messages.php
<?php
mysql_connect('*******','*******','*******1');
mysql_select_db('chat') or die(2);
$random = microtime(true);

echo '<p><a href="?'.$random.'">Refresh Chat</a></p>
';
$result = mysql_query("select * from chat order by time desc limit 0,10");
$messages = array();
$i = 0;
while($row = mysql_fetch_array($result)){
$messages[$i] = '<p class="purple"><span class="pink"><strong>'. $row[name] . '</strong></span> said:<br /><span class="purple">' . $row[message] . '</span><br /> <span class="pink">';

$timeago = time() - $row['time'];
if($timeago > 86400){
$messages[$i] .= date('g:i A M, d Y',$row[time]);
}
else{
$hours = floor($timeago / 3600); 
$minutes = floor(($timeago - ($hours * 3600)) / 60);
$seconds = floor($timeago - ($hours * 3600) - ($minutes * 60));
if($hours > 0){
if($minutes > 9){
if($seconds > 9){
$messages[$i] .= $hours . ' h, ' . $minutes . ' min, ' . $seconds . ' sec';
}
else{
$messages[$i] .= $hours . ' h, ' . $minutes . ' min, 0' . $seconds . ' sec';
}
}
else{
if($seconds > 9){
$messages[$i] .= $hours . ' h, 0' . $minutes . ' min, ' . $seconds . ' sec';
}
else{
$messages[$i] .= $hours . ' h, 0' . $minutes . ' min, 0' . $seconds . ' sec';
}
}
}
else if($minutes > 0){
if($seconds > 9){
$messages[$i] .= $minutes . ' min, ' . $seconds . ' sec';
}
else{
$messages[$i] .= $minutes . ' min, 0' . $seconds . ' sec';
}
}
else{
$messages[$i] .= $seconds . ' sec';
}
$messages[$i] .= ' ago';
}
$messages[$i] .= "</span></p><p class='purple'>----------------------------</p>";
$old = $row[time];
$i++;
}
for($i=0;$i<=9;$i++){
echo $messages[$i];
}
mysql_query("delete from chat where time < " . $old);
$random = microtime(true);
echo '<p><a href="?'.$random.'">Refresh Chat</a></p>';
?>

send.php
<?php
//Connect to MySQL
mysql_connect('******', '******', '******') or die (1);
//Select database
mysql_select_db('chat') or die (2);
$message = $_GET['message']; 
$name = $_GET['name'];
//Check if message is empty and send the error code
if(strlen($message) < 1){
echo 3;
}
//Check if message is too long
else if(strlen($message) > 255){
   echo 4;
}
//Check if name is empty
else if(strlen($name) < 1){
   echo 5;
}
//Check if name is too long
else if(strlen($name) > 29){
   echo 6;
}
//Check if the name is used by somebody else
else if(mysql_num_rows(mysql_query("select * from chat where name = '" . $name . "' and ip != '" . $_SERVER['REMOTE_ADDR'] . "'")) != 0){
   echo 7;
}
//If everything is fine
else{
   //This array contains the characters what will be removed from the message and name, because else somebody could send redirection script or links
   $search = array("<",">","&gt;","&lt;");
   //Insert a new row in the chat table
   mysql_query("insert into chat values ('" . time() . "', '" . str_replace($search,"",$name) . "', '" . $_SERVER['REMOTE_ADDR'] . "', '" . str_replace($search,"",$message) . "')") or die(8);
}
?>

如果和发布新帖子时,我要进行什么更改才能播放.wav文件?
谢谢.....

最佳答案

由于函数showmessages()是通过AJAX调用show-messages.php的函数,因此使用回调选项会比较好。您是否考虑过使用jQuery as an AJAX framework?我用它所有的时间。它具有用于不同类型结果的令人难以置信的处理程序(我最喜欢的是JSON返回),并且在函数完成后可以运行回调函数,您可以对其进行设置。

在回调中,如果您可以触发声音播放,那就太完美了。但是,我对在网站上播放音乐不熟悉(除了将老式的.wav文件嵌入到在后台播放的HTML中的那种老派方式之外,这就是Web 1.0,而不是2.0)。

我发现这是一个plugin via jQuery,可以播放您存储在服务器上的某些噪音来执行:http://plugins.jquery.com/project/sound_plugin

我敢肯定,利用这两个,您可以立即完成此操作。

编辑:

function showmessages(){
    $.get("show-messages.php", { random: Math.random()},
   function(data){
        $('#messages').html(data); // put teh return data here
        // call back the function to play sound based on the jQuery plugin. 
   });
}

上面是您可以设置的更简单的AJAX查询,而不是当前的showmessage()函数。

此外,如果您希望使用jSON获得更复杂的结果,其中包含多个数组(除了javascript对象形式,可以将其视为PHP数组)。另请注意,PHP中的json_encode()函数可从任何PHP数组(甚至是多级,但我认为不包括PHP对象)中创建JSON对象。
function showmessages(){
    $.get("show-messages.php", { random: Math.random()},
   function(data){
       if(data.code==1) {
           // assuming 1 means successful
            $('#messages').html(data.content); // put teh return data here
        // call back the function to play sound based on the jQuery plugin.
       } else {
           // execute code that runs IF the result was no good
       }
   },'json');
}

关于php - 有新帖子时,如何让我的聊天脚本播放声音?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8129423/

相关文章:

audio - .Ogg 与 .mp3 用于移动应用程序?

php - 使用 mysql PDO 获取字符集

php - 在 while 循环中构造 json 数组

javascript - 如何从对象数组中查找名称属性

javascript - JQuery 不断改变跨度颜色

javascript - 打破 PrototypeJS .each() 循环

c# - 如何制作音频记录功能,例如知名度

audio - 是否可以在下载整个文件之前知道 MP3 的持续时间?

php - 如何使用指定参数的 Android Volley GET 方法?

php - 在 mySQL 5 TABLES 中使用 INNER JOIN 删除多个表中的多行