Rumah >pembangunan bahagian belakang >tutorial php >Gunakan PHP untuk melaksanakan fungsi bilik sembang

Gunakan PHP untuk melaksanakan fungsi bilik sembang

WBOY
WBOYasal
2023-06-22 22:58:452329semak imbas

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.

  1. Tentukan keperluan

Sebelum kita mula menulis program, kita perlu menjelaskan keperluan kita terlebih dahulu. Bilik sembang yang ringkas perlu mempunyai fungsi asas berikut:

  • Pengguna boleh mendaftar, log masuk dan log keluar
  • Pengguna boleh melihat rekod sembang bersejarah
  • Pengguna boleh Menghantar mesej dan memaparkannya serta-merta pada halaman kepada pengguna dalam talian yang lain.
  1. Reka bentuk pangkalan data

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:

  • Jadual pengguna: merekodkan nama pengguna, kata laluan, masa pendaftaran dan maklumat lain
  • Jadual rekod sembang: Rakam semua rekod sembang dalam bilik sembang;
  • Jadual pengguna dalam talian: rekod semua maklumat pengguna dalam talian.
  1. Menulis kod PHP

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.

  1. Ringkasan

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!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn