Rumah  >  Artikel  >  pembangunan bahagian belakang  >  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?

PHPz
PHPzasal
2023-03-29 11:33:52757semak imbas

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);
}

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);

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");
}

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:
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