sql >> Databáze >  >> RDS >> Mysql

Automatické obnovení tabulky bez obnovení stránky PHP MySQL

Technika se nazývá AJAX a jednou z nejjednodušších knihoven, kterou lze do projektu přidat, by byla jQuery . Předpokládám, že váš problém není s JavaScriptem, ale s myšlenkou opětovného načtení celé stránky.

AKTUALIZACE Protože jsem takový sympaťák;) Tohle by mělo víceméně fungovat, nezkoušel jsem to, takže tam může být překlep nebo dva:

<?php

$host="****";
$user="****";
$password="****";

$cxn = mysql_pconnect ($host, $user, $password);

mysql_select_db("defaultdb", $cxn);

if (getenv(HTTP_X_FORWARDED_FOR)) {
$ipaddress = getenv(HTTP_X_FORWARDED_FOR);
} else {
$ipaddress = getenv(REMOTE_ADDR);
}

$message = nl2br(strip_tags(nl2br($_POST["message"])));
if (isset($_POST['submitButton'])) { 
if ($message != "") {
mysql_query("INSERT INTO ChatTest (ID, TimeStamp, Message) VALUES ('$ipaddress', NOW(), '$message')");
}
header('Location: chat.php');
}

$message = "";

$data = mysql_query("SELECT * FROM ChatTest ORDER BY TimeStamp DESC") or die(mysql_error()); 

$tbl = '';
$tbl .= "<table border cellpadding=3 width='100%' style='table-layout:fixed'>
"; 
$tbl .= "<tr>"; 
$tbl .= "<th style='width:10%;'>ID:</th><th style='width:10%;'>TimeStamp:</th><th style='width:70%;'>Message:</th>";
while($info = mysql_fetch_array( $data )) { 
$tbl .= "
<tr>"; 
$tbl .= " <td>".$info['ID'] . "</td> "; 
$tbl .= " <td>".$info['TimeStamp'] . " </td>";
$tbl .= " <td style='white-space:pre-wrap;white-space:-moz-pre-wrap;white-space:-pre-wrap;white-space:-o-pre-wrap;word-wrap:break-word'>".$info['Message'] . "</td></tr>
"; 
} 
$tbl .= "</table>"; 

mysql_close($cxn);

if (isset ($_GET['update']))
{
    echo $tbl;
    die ();
}

?>
<html><head>
  <script src="https://ajax.googleapis.com/ajax/libs/jquery/1.7.0/jquery.min.js" type="text/javascript"></script>
</head><body><center>
<form action="chat.php" method="post">
Message: <br><textarea type="text" name="message" style="width:80%; height:300px;"></textarea><br>
<input type="submit" name="submitButton"/> <a href="https://www.****.com/chat.php"><button name="Refresh Chat">Refresh Chat</button></a>
</form>
<div id="messages" style="width:100%;">
  <?php echo $tbl; ?>
</div></center>
<script type="text/javascript">
$(document).ready (function () {
    var updater = setTimeout (function () {
        $('div#messages').load ('chat.php', 'update=true');
    }, 1000);
});
</script>
</body></html>

Co se týče technik kódování, možná se budete chtít podívat do SQL-injekcí a možná napsat čistší HTML, ale jsem si jistý, že se tam dostanete :)



  1. Pomocí OBJECTPROPERTY() zjistěte, zda tabulka má výchozí omezení na serveru SQL Server

  2. Došlo k chybě JNI, zkontrolujte prosím svou instalaci a zkuste to znovu v Eclipse x86 Windows 8.1

  3. Jak se dotazovat sql s aktivním záznamem na data mezi určenými časy

  4. CHYBA 1452 (23000):Nelze přidat nebo aktualizovat podřízený řádek:omezení cizího klíče se nezdaří