Rumah pembangunan bahagian belakang tutorial php **Mengapa skrip log masuk MySQL saya tidak berfungsi?**

**Mengapa skrip log masuk MySQL saya tidak berfungsi?**

Oct 26, 2024 am 07:15 AM

**Why is my MySQL login script not working?**

Apakah masalah dengan sambungan MySQL saya dalam skrip log masuk saya?

Dalam serpihan kod yang disediakan, nampaknya terdapat beberapa kawasan yang boleh menyebabkan masalah dengan borang log masuk. Mari kita baca satu persatu:

1. Sambungan Pangkalan Data:

Dalam log masuk fail PHP.php, anda cuba mewujudkan sambungan ke pangkalan data menggunakan kod berikut:

<code class="php">// Pretend the following is locked in a vault and loaded but hard coded here
$hostname = "localhost";
$database = "boost";
$username = "root";
$password = "";
$localhost = mysqli_connect($hostname, $username, $password, $database);

if (mysqli_connect_errno()) {
    die("Connection Failed" . mysqli_error());
}</code>
Salin selepas log masuk

Walau bagaimanapun, anda mempunyai kod keras kelayakan pangkalan data. Bukan amalan yang baik untuk mengekodkan butiran ini dalam kod, kerana ia mungkin berubah pada masa hadapan. Sebaliknya, adalah disyorkan untuk mengasingkan bukti kelayakan pangkalan data dalam fail konfigurasi dan membacanya dari sana untuk memastikan keselamatan dan fleksibiliti yang lebih baik.

2. Penyata Disediakan:

Dalam kedua-dua register.php dan login.php, anda menyediakan pernyataan SQL menggunakan fungsi mysqli_prepare. Walau bagaimanapun, anda tidak melaksanakannya selepas itu menggunakan mysqli_stmt_execute. Ini akan menghalang pertanyaan daripada dilaksanakan dan mengakibatkan log masuk atau pendaftaran gagal.

3. Parameter Pengikat:

Apabila menggunakan fungsi mysqli_stmt_bind_param, anda harus menyediakan jenis parameter terikat. Dalam kedua-dua register.php dan login.php, anda mengikat parameter menggunakan jenis "s", iaitu untuk rentetan. Walau bagaimanapun, jika anda mengikat nilai integer, anda harus menggunakan penentu jenis yang sesuai, seperti "i" untuk integer.

4. Pengesahan Pengguna:

Dalam login.php, apabila mengesahkan kata laluan pengguna, anda membandingkan kata laluan cleartext ($ctPassword) terus dengan kata laluan cincang yang disimpan dalam pangkalan data ($dbHashedPassword). Ini adalah risiko keselamatan, kerana ia membolehkan penyerang mendapat akses kepada kata laluan pengguna jika mereka boleh memintas permintaan. Sebaliknya, anda harus menggunakan fungsi password_verify untuk membandingkan kata laluan yang dicincang dengan selamat.

5. Pengendalian Sesi:

Anda menggunakan superglobal $_SESSION untuk menyimpan ID pengguna apabila berjaya log masuk. Walau bagaimanapun, anda tidak memulakan sesi menggunakan session_start() dalam login.php. Ini akan menghalang sesi daripada dimulakan dengan betul dan data sesi tidak akan tersedia.

6. SQL Injection:

Anda tidak menggunakan pernyataan yang disediakan semasa melaksanakan pertanyaan SQL anda, yang menjadikan kod anda terdedah kepada serangan suntikan SQL. Anda hendaklah sentiasa menggunakan pernyataan yang disediakan untuk menghalang jenis serangan ini.

Berikut ialah beberapa serpihan kod yang dikemas kini yang menangani isu ini:

register.php:

<code class="php">session_start();

if (isset($_POST['register'])) {
    $email = $_POST['email'];
    $ctPassword = $_POST['password'];   // Cleartext password from user

    // Pretend the following is locked in a vault and loaded but hard coded here
    $host = "yourhostname";
    $dbname = "dbname";
    $user = "dbuser";
    $pwd = "password";
    $port = 3306; // Comes along for the ride so I don't need to look up param order below

    try {
        $mysqli = new mysqli($host, $user, $pwd, $dbname, $port);

        if ($mysqli->connect_error) {
            die('Connect Error (' . $mysqli->connect_errno . ') ' . $mysqli->connect_error);
        }

        $query = "INSERT INTO user_accounts2(email, password) VALUES (?, ?)";
        $stmt = $mysqli->prepare($query);

        $hp = password_hash($ctPassword, PASSWORD_DEFAULT); // Hashed password using cleartext one

        $stmt->bind_param("ss", $email, $hp);
        $stmt->execute();

        $iLastInsertId = $mysqli->insert_id;
        $stmt->close();
        $mysqli->close();
    } catch (mysqli_sql_exception $e) {
        throw $e;
    }
}</code>
Salin selepas log masuk

log masuk.php:

<code class="php">session_start();

if (isset($_POST['login'])) {
    $email = $_POST['email'];
    $ctPassword = $_POST['password'];   // Cleartext password from user

    // Pretend the following is locked in a vault and loaded but hard coded here
    $host = "yourhostname";
    $dbname = "dbname";
    $user = "dbuser";
    $pwd = "password";
    $port = 3306;

    try {
        $mysqli = new mysqli($host, $user, $pwd, $dbname, $port);

        if ($mysqli->connect_error) {
            die('Connect Error (' . $mysqli->connect_errno . ') ' . $mysqli->connect_error);
        }

        $query = "SELECT id, email, password FROM user_accounts2 WHERE email = ?";
        $stmt = $mysqli->prepare($query);

        $stmt->bind_param("s", $email);
        $stmt->execute();

        $result = $stmt->get_result();

        if ($row = $result->fetch_array(MYSQLI_ASSOC)) {
            $dbHashedPassword = $row['password'];
            if (password_verify($ctPassword, $dbHashedPassword)) {
                echo "Right, userId=";
                $_SESSION['userid'] = $row['id'];
                echo $_SESSION['userid'];
            } else {
                echo "Wrong";
            }
        } else {
            echo 'No such record';
        }

        $stmt->close();
        $mysqli->close();
    } catch (mysqli_sql_exception $e) {
        throw $e;
    }
}</code>
Salin selepas log masuk

Nota Tambahan:

  • Adalah sangat disyorkan untuk menggunakan lapisan abstraksi pangkalan data (DAL) seperti PDO atau Doktrin untuk memudahkan interaksi pangkalan data anda.
  • Jangan sekali-kali menyimpan kata laluan dalam teks biasa dalam pangkalan data anda. Sentiasa cincangnya dengan selamat menggunakan algoritma pencincangan yang kuat seperti bcrypt atau Argon2.
  • Gunakan pernyataan yang disediakan untuk mengelakkan serangan suntikan SQL.
  • Sahkan input pengguna sebelum menyerahkannya ke pangkalan data untuk mengelakkan serangan berniat jahat.
  • Pertimbangkan untuk menggunakan rangka kerja keselamatan yang lebih teguh untuk melindungi aplikasi anda daripada pelbagai jenis serangan.

Atas ialah kandungan terperinci **Mengapa skrip log masuk MySQL saya tidak berfungsi?**. 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)
2 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Repo: Cara menghidupkan semula rakan sepasukan
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Cara mendapatkan biji gergasi
3 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)

11 skrip pemendek URL terbaik PHP (percuma dan premium) 11 skrip pemendek URL terbaik PHP (percuma dan premium) Mar 03, 2025 am 10:49 AM

11 skrip pemendek URL terbaik PHP (percuma dan premium)

Pengenalan kepada API Instagram Pengenalan kepada API Instagram Mar 02, 2025 am 09:32 AM

Pengenalan kepada API Instagram

Bekerja dengan Data Sesi Flash di Laravel Bekerja dengan Data Sesi Flash di Laravel Mar 12, 2025 pm 05:08 PM

Bekerja dengan Data Sesi Flash di Laravel

Bina aplikasi React dengan hujung belakang Laravel: Bahagian 2, React Bina aplikasi React dengan hujung belakang Laravel: Bahagian 2, React Mar 04, 2025 am 09:33 AM

Bina aplikasi React dengan hujung belakang Laravel: Bahagian 2, React

Respons HTTP yang dipermudahkan dalam ujian Laravel Respons HTTP yang dipermudahkan dalam ujian Laravel Mar 12, 2025 pm 05:09 PM

Respons HTTP yang dipermudahkan dalam ujian Laravel

Curl dalam PHP: Cara Menggunakan Pelanjutan PHP Curl dalam API REST Curl dalam PHP: Cara Menggunakan Pelanjutan PHP Curl dalam API REST Mar 14, 2025 am 11:42 AM

Curl dalam PHP: Cara Menggunakan Pelanjutan PHP Curl dalam API REST

12 skrip sembang php terbaik di codecanyon 12 skrip sembang php terbaik di codecanyon Mar 13, 2025 pm 12:08 PM

12 skrip sembang php terbaik di codecanyon

Pengumuman Penyiasatan Situasi PHP 2025 Pengumuman Penyiasatan Situasi PHP 2025 Mar 03, 2025 pm 04:20 PM

Pengumuman Penyiasatan Situasi PHP 2025

See all articles