Kini, dengan pempopularan Internet, komunikasi masa nyata telah menjadi bahagian yang sangat diperlukan dalam kehidupan seharian orang ramai, dan bilik sembang, sebagai kaedah komunikasi kolektif, semakin diterima dan digunakan oleh semua orang. Artikel ini akan memperkenalkan cara menggunakan PHP untuk melaksanakan fungsi bilik sembang yang mudah.
Sebelum kita mula menulis program, kita perlu menjelaskan keperluan kita terlebih dahulu. Bilik sembang yang ringkas perlu mempunyai fungsi asas berikut:
Sebelum melaksanakan fungsi bilik sembang, kita perlu mereka bentuk struktur jadual pangkalan data yang berkaitan. Jadual pangkalan data yang diperlukan untuk ruang sembang ringkas mungkin termasuk yang berikut:
Sekarang anda boleh mula menulis kod PHP Kita boleh melakukannya dalam langkah berikut:
3.1 Sambung ke pangkalan data
Pertama, anda perlu menyambung ke pangkalan data yang direka bentuk sebelum ini dalam kod PHP. Hanya gunakan perpustakaan mysqli yang disediakan oleh PHP Kod sambungan adalah seperti berikut:
$mysqli = new mysqli("localhost", "root", "password", "chatroom"); if ($mysqli->connect_error) { die("连接失败: " . $mysqli->connect_error); }
Di sini "localhost" ialah alamat hos pangkalan data, "root" ialah nama pengguna pangkalan data, "kata laluan" ialah pangkalan data. kata laluan, dan "ruang sembang" ialah nama Pangkalan Data. Anda perlu mengubahnya mengikut situasi anda sendiri.
3.2 Pendaftaran pengguna, log masuk dan log keluar
Pendaftaran pengguna, log masuk dan log keluar adalah asas fungsi bilik sembang Mari perkenalkan mereka masing-masing di bawah.
3.2.1 Pendaftaran Pengguna
Pengguna perlu mengisi nama pengguna dan kata laluan mereka semasa mendaftar. Kami perlu mengenakan beberapa sekatan pada nama pengguna dan kata laluan, seperti nama pengguna tidak boleh diulang, kata laluan perlu disulitkan, dsb. Kodnya adalah seperti berikut:
// 判断用户名是否已存在 $query = "SELECT * FROM users WHERE username='$username'"; $result = $mysqli->query($query); if ($result->num_rows > 0) { echo '该用户名已被注册,请重新选择用户名!'; return; } // 使用 sha1 对密码进行加密 $password_hash = sha1($password); // 将加密后的密码和用户信息插入到用户表中 $add_time = date("Y-m-d H:i:s"); $query = "INSERT INTO users (username, password, add_time) VALUES ('$username', '$password_hash', '$add_time')"; if ($mysqli->query($query) === TRUE) { echo '注册成功!'; } else { echo '注册失败!'; }
3.2.2 Log masuk pengguna
Pengguna perlu memasukkan nama pengguna dan kata laluan yang betul semasa log masuk untuk berjaya log masuk. Selepas log masuk berjaya, maklumat pengguna perlu direkodkan dalam jadual pengguna dalam talian untuk kegunaan kemudian. Kodnya adalah seperti berikut:
$query = "SELECT * FROM users WHERE username='$username' AND password='".sha1($password)."'"; $result = $mysqli->query($query); if ($result->num_rows > 0) { $row = $result->fetch_assoc(); $user_id = $row['id']; $online_time = date("Y-m-d H:i:s"); $query = "INSERT INTO online_users (user_id, online_time) VALUES ('$user_id', '$online_time')"; if ($mysqli->query($query) === TRUE) { echo '登录成功!'; } else { echo '登录失败!'; } } else { echo '用户名或密码错误,请重新输入!'; }
3.2.3 Keluar pengguna
Apabila pengguna keluar, rekod pengguna yang sepadan dalam jadual pengguna dalam talian perlu dipadamkan. Kodnya adalah seperti berikut:
$online_time = date("Y-m-d H:i:s"); $query = "DELETE FROM online_users WHERE user_id='$user_id'"; if ($mysqli->query($query) === TRUE) { echo '退出成功!'; } else { echo '退出失败!'; }
3.3 Paparkan rekod sembang sejarah
Dalam bilik sembang, pengguna boleh melihat rekod sembang sejarah. Kita boleh membaca beberapa rekod terkini daripada jadual rekod sembang dan memaparkannya pada halaman. Kodnya adalah seperti berikut:
$query = "SELECT * FROM chat_records ORDER BY id DESC LIMIT 50"; $result = $mysqli->query($query); echo '<div class="chat-history">'; while ($row = $result->fetch_assoc()) { echo '<div class="chat-message">'; echo '<span class="message-name">'.$row['username'].'</span>'; echo '<span class="message-time">'.$row['add_time'].'</span><br>'; echo '<span class="message-text">'.$row['message'].'</span>'; echo '</div>'; } echo '</div>';
Dalam kod di atas, kami menggunakan gaya CSS untuk mencantikkan paparan rekod sembang, yang tidak akan diterangkan di sini.
3.4 Melaksanakan pemesejan segera
Melaksanakan pemesejan segera memerlukan penggunaan teknologi Ajax, yang bermaksud interaksi data dengan pelayan tanpa memuat semula halaman. Kita boleh merealisasikan fungsi pemesejan segera dengan memasukkan mesej dalam kotak input sembang dan menghantarnya ke pelayan melalui Ajax. Kodnya adalah seperti berikut:
// 客户端通过Ajax发送消息到服务器 $(".chat-input").keypress(function(event) { if (event.which == 13) { var message = $(this).val().trim(); if (message != '') { $.post("send_message.php", { message: message }, function(data, status) { if (data == 'ok') { $(".chat-input").val(''); } else { alert('消息发送失败!'); } }); } } }); // 服务器接收到消息后将消息存储到聊天记录表中 $message = $_POST['message']; $add_time = date("Y-m-d H:i:s"); $query = "INSERT INTO chat_records (username, message, add_time) VALUES ('$username', '$message', '$add_time')"; if ($mysqli->query($query) === TRUE) { echo 'ok'; } else { echo 'error'; }
Dalam kod di atas, kami menghantar mesej dalam kotak input sembang ke pelayan melalui Ajax, dan menyimpan mesej dalam jadual rekod sembang di sebelah pelayan. Dengan cara ini, pengguna dalam talian lain boleh melihat mesej yang dihantar dalam bilik sembang dengan serta-merta.
Artikel ini memperkenalkan cara menggunakan PHP untuk menulis fungsi bilik sembang ringkas, termasuk pendaftaran pengguna, log masuk dan keluar, paparan rekod sembang sejarah dan pelaksanaan pemesejan segera, dsb. Fungsi yang biasa digunakan. Sebagai kaedah komunikasi kolektif, bilik sembang membolehkan pengguna berkomunikasi dengan lebih mudah di Internet. Sudah tentu, dalam aplikasi praktikal, kita juga perlu mempertimbangkan lebih banyak faktor seperti keselamatan dan kestabilan Ini hanyalah contoh mudah.
Atas ialah kandungan terperinci Gunakan PHP untuk melaksanakan fungsi bilik sembang. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!