Rumah pembangunan bahagian belakang masalah PHP Apakah yang perlu saya lakukan jika pelayar PHP kekal dalam antara muka log masuk sebelum ditutup?

Apakah yang perlu saya lakukan jika pelayar PHP kekal dalam antara muka log masuk sebelum ditutup?

Mar 29, 2023 am 11:33 AM

Dengan perkembangan pesat dan pempopularan Internet, semakin banyak tapak web dan aplikasi telah mula menyediakan pengguna dengan fungsi dan perkhidmatan yang lebih mudah, cekap dan kaya. Dalam aplikasi Internet ini, fungsi log masuk pengguna telah menjadi salah satu ciri standard. Menggunakan fungsi log masuk, pengguna boleh mengakses maklumat peribadi mereka dengan mudah, menyesuaikan profil mereka sendiri, menikmati perkhidmatan pengesyoran yang diperibadikan, dsb. Walau bagaimanapun, dalam penggunaan sebenar, sebaik sahaja pengguna menutup penyemak imbas, dia masih perlu log masuk semula pada kali berikutnya dia melawat, yang sudah pasti akan meningkatkan kesulitan dan kegusaran pengguna. Untuk tujuan ini, PHP menyediakan penyelesaian yang membolehkan pengguna kekal log masuk sebelum menutup penyemak imbas Mari perkenalkan di bawah.

Dalam sistem log masuk umum, selepas pengguna log masuk, maklumat log masuk pengguna (seperti nama pengguna, kata laluan, masa log masuk, dll.) biasanya disimpan dalam SESSION atau COOKIE pada pelayan. Apabila pengguna meneruskan menyemak imbas atau keluar, identiti pengguna disahkan dan diproses berdasarkan nilai SESSION atau COOKIE. Walau bagaimanapun, apabila pengguna menutup pelayar, SESSION atau COOKIE juga akan menjadi tidak sah. Ini menyebabkan pengguna log masuk semula pada kali berikutnya mereka melawat, yang sangat menyusahkan.

Untuk ini, kita boleh menggunakan penyelesaian yang disediakan oleh PHP, iaitu menyimpan maklumat log masuk pengguna dalam pangkalan data. Apabila pengguna log masuk, maklumat log masuk pengguna dimasukkan ke dalam jadual dalam pangkalan data apabila pengguna log keluar, rekod dipadamkan daripada jadual. Dengan cara ini, selepas pengguna menutup pelayar, maklumat log masuk tidak akan dipadamkan Pada lawatan seterusnya, kami boleh mendapatkan semula maklumat daripada pangkalan data dan kemudian melakukan pengesahan dan pemprosesan pengguna mengikut situasi.

Dalam pelaksanaan khusus, kita perlu mencipta jadual pangkalan data terlebih dahulu untuk menyimpan maklumat log masuk pengguna. Jadual boleh termasuk medan berikut:

  • id: kunci utama kenaikan automatik
  • nama pengguna: nama pengguna
  • kata laluan: kata laluan
  • masa_log masuk: masa log masuk
  • logout_time: masa log keluar atau masa akses terakhir

Apabila pengguna log masuk, kami memasukkan maklumat log masuk pengguna ke dalam jadual:

//连接数据库
$conn = mysqli_connect("localhost", "user", "password", "demo");

//获取用户输入的用户名和密码
$username = $_POST["username"];
$password = $_POST["password"];

//查询该用户是否已经登录过
$sql = "SELECT id FROM login_info WHERE username='$username'";
$result = mysqli_query($conn, $sql);

if (mysqli_num_rows($result) > 0) {
    //该用户已经登录过了,更新登录时间即可
    $login_time = time();
    $sql = "UPDATE login_info SET login_time='$login_time' WHERE username='$username'";
    mysqli_query($conn, $sql);
} else {
    //该用户是首次登录,将登录信息插入到数据库中
    $login_time = time();
    $sql = "INSERT INTO login_info (username,password,login_time) VALUES ('$username','$password','$login_time')";
    mysqli_query($conn, $sql);
}
Salin selepas log masuk

Apabila pengguna log keluar, kami memadam maklumat log masuk pengguna daripada pangkalan data:

//获取用户的用户名
$username = $_SESSION["username"];

//将该用户的登录信息从数据库中删除
$sql = "DELETE FROM login_info WHERE username='$username'";
mysqli_query($conn, $sql);
Salin selepas log masuk

Apabila pengguna melawat tapak web sekali lagi, kami boleh mengeluarkan maklumat log masuk pengguna daripada pangkalan data untuk pengesahan identiti :

//连接数据库
$conn = mysqli_connect("localhost", "user", "password", "demo");

//从数据库中取出用户的登录信息
$username = $_SESSION["username"];
$sql = "SELECT * FROM login_info WHERE username='$username'";
$result = mysqli_query($conn, $sql);

if (mysqli_num_rows($result) > 0) {
    //该用户已经登录过,验证用户身份
    $row = mysqli_fetch_assoc($result);
    if ($_SESSION["password"] == $row["password"]) {
        //用户身份验证通过,更新上次访问时间即可
        $logout_time = time();
        $sql = "UPDATE login_info SET logout_time='$logout_time' WHERE username='$username'";
        mysqli_query($conn, $sql);
    } else {
        //用户身份验证失败,跳转到登录页面
        header("Location:login.php");
    }
} else {
    //该用户未登录过,跳转到登录页面
    header("Location:login.php");
}
Salin selepas log masuk

Dengan cara ini, walaupun pengguna menutup tetingkap penyemak imbas, maklumat log masuk masih boleh disimpan dalam pangkalan data dan pengguna boleh mengekalkan status log masuk tanpa log masuk semula pada kali berikutnya mereka melawat. Sudah tentu, kita perlu membuat beberapa pengoptimuman untuk penyelesaian ini, seperti menetapkan masa log keluar automatik, mencegah suntikan SQL, dsb., untuk melaksanakan fungsi ini dengan lebih selamat dan boleh dipercayai.

Ringkasnya, dengan menyimpan maklumat log masuk pengguna dalam pangkalan data, pengguna boleh kekal log masuk sebelum menutup penyemak imbas, yang meningkatkan pengalaman dan kecekapan pengguna dengan sangat baik.

Atas ialah kandungan terperinci Apakah yang perlu saya lakukan jika pelayar PHP kekal dalam antara muka log masuk sebelum ditutup?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
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

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Arahan sembang dan cara menggunakannya
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

PHP 8 JIT (Just-in-Time) Penyusunan: Bagaimana ia meningkatkan prestasi. PHP 8 JIT (Just-in-Time) Penyusunan: Bagaimana ia meningkatkan prestasi. Mar 25, 2025 am 10:37 AM

Kompilasi JIT Php 8 meningkatkan prestasi dengan menyusun kod yang sering dilaksanakan ke dalam kod mesin, memberi manfaat kepada aplikasi dengan pengiraan berat dan mengurangkan masa pelaksanaan.

PHP Secure File Muat naik: Mencegah kelemahan berkaitan fail. PHP Secure File Muat naik: Mencegah kelemahan berkaitan fail. Mar 26, 2025 pm 04:18 PM

Artikel ini membincangkan mendapatkan muat naik fail PHP untuk mengelakkan kelemahan seperti suntikan kod. Ia memberi tumpuan kepada pengesahan jenis fail, penyimpanan selamat, dan pengendalian ralat untuk meningkatkan keselamatan aplikasi.

OWASP Top 10 PHP: Huraikan dan mengurangkan kelemahan umum. OWASP Top 10 PHP: Huraikan dan mengurangkan kelemahan umum. Mar 26, 2025 pm 04:13 PM

Artikel ini membincangkan kelemahan OWASP 10 dalam strategi PHP dan mitigasi. Isu -isu utama termasuk suntikan, pengesahan yang rosak, dan XSS, dengan alat yang disyorkan untuk memantau dan mendapatkan aplikasi PHP.

Penyulitan PHP: Penyulitan simetri vs asimetrik. Penyulitan PHP: Penyulitan simetri vs asimetrik. Mar 25, 2025 pm 03:12 PM

Artikel ini membincangkan penyulitan simetri dan asimetrik dalam PHP, membandingkan kesesuaian, prestasi, dan perbezaan keselamatan mereka. Penyulitan simetri lebih cepat dan sesuai untuk data pukal, manakala asimetrik digunakan untuk pertukaran utama yang selamat.

Pengesahan PHP & amp; Kebenaran: Pelaksanaan selamat. Pengesahan PHP & amp; Kebenaran: Pelaksanaan selamat. Mar 25, 2025 pm 03:06 PM

Artikel ini membincangkan pelaksanaan pengesahan dan kebenaran yang mantap dalam PHP untuk mencegah akses yang tidak dibenarkan, memperincikan amalan terbaik dan mengesyorkan alat peningkatan keselamatan.

PHP API Kadar Mengehadkan: Strategi Pelaksanaan. PHP API Kadar Mengehadkan: Strategi Pelaksanaan. Mar 26, 2025 pm 04:16 PM

Artikel ini membincangkan strategi untuk melaksanakan kadar API yang mengehadkan PHP, termasuk algoritma seperti baldi token dan baldi bocor, dan menggunakan perpustakaan seperti simfoni/kadar-limiter. Ia juga meliputi pemantauan, had kadar penyesuaian secara dinamik, dan tangan

Apakah tujuan penyataan yang disediakan dalam PHP? Apakah tujuan penyataan yang disediakan dalam PHP? Mar 20, 2025 pm 04:47 PM

Kenyataan yang disediakan dalam PHP meningkatkan keselamatan pangkalan data dan kecekapan dengan mencegah suntikan SQL dan meningkatkan prestasi pertanyaan melalui kompilasi dan penggunaan semula.

Bagaimana anda mengambil data dari pangkalan data menggunakan PHP? Bagaimana anda mengambil data dari pangkalan data menggunakan PHP? Mar 20, 2025 pm 04:57 PM

Artikel membincangkan mendapatkan data dari pangkalan data menggunakan PHP, meliputi langkah, langkah keselamatan, teknik pengoptimuman, dan kesilapan umum dengan penyelesaian.

See all articles