Menyahsulit Cincang Kata Laluan dalam PHP Menggunakan Password_Hash
Soalan:
Bagaimana hendak menyahsulit cincang kata laluan yang dihasilkan menggunakan fungsi PHP password_hash? Kata laluan disimpan dalam pangkalan data dan perlu dibandingkan dengan input pengguna yang dimasukkan.
Jawapan:
Tidak seperti penyulitan, pencincangan ialah proses sehala. Setelah kata laluan dicincang menggunakan password_hash, ia tidak boleh dinyahsulit kembali kepada nilai asalnya. Oleh itu, adalah penting untuk menggunakan pengesahan kata laluan dan bukannya penyahsulitan.
Pengesahan Kata Laluan menggunakan password_verify:
<code class="php">$hash = password_hash('examplepassword', PASSWORD_DEFAULT); if (password_verify('examplepassword', $hash)) { echo 'Password is valid!'; } else { echo 'Invalid password.'; }</code>
Dalam senario log masuk anda, laksanakan pertanyaan SQL menggunakan hanya nama pengguna:
<code class="php">$sql_script = 'SELECT * FROM USERS WHERE username=?';</code>
Kemudian, bandingkan kata laluan yang dimasukkan dengan cincang yang disimpan dalam PHP:
<code class="php">if (password_verify($inputpassword, $fetchedPasswordHashFromDB)) { // Password matches }</code>
Nota Penting:
Pastikan anda membersihkan input pengguna untuk mengelakkan serangan suntikan SQL. Parameterkan pertanyaan anda menggunakan pernyataan yang disediakan atau lapisan abstraksi pangkalan data.
Atas ialah kandungan terperinci Bolehkah saya Menyahsulit Cincang Kata Laluan yang Dijana oleh Fungsi `password_hash` PHP?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!