Pengesahan log masuk PHP adalah pautan yang sangat penting dalam pembangunan laman web Ia menentukan sama ada pengguna mempunyai hak untuk mengakses laman web dengan menyemak sama ada nombor akaun dan kata laluan yang dimasukkan oleh pengguna sepadan dengan maklumat yang disimpan dalam pangkalan data. Walau bagaimanapun, kadangkala pengaturcara membuat beberapa kesilapan biasa semasa menulis fungsi pengesahan log masuk, yang membawa kepada lubang keselamatan dalam tapak web. Artikel ini akan mendedahkan kelemahan pengesahan log masuk PHP biasa, iaitu, kata laluan yang salah sebenarnya boleh log masuk ke akaun, dan memberikan contoh kod khusus untuk analisis dan pembaikan.
Dalam beberapa logik pengesahan log masuk yang mudah, pengaturcara hanya boleh menyemak sama ada kata laluan yang dimasukkan oleh pengguna adalah konsisten dengan kata laluan yang disimpan dalam pangkalan data, tanpa mengambil kira situasi di mana kata laluan dimasukkan dengan salah. Ini membawa kepada kerentanan yang serius, di mana pengguna boleh memasukkan kata laluan yang salah dan masih berjaya log masuk ke akaun mereka.
Seterusnya, kami akan menggunakan contoh kod PHP mudah untuk menunjukkan bagaimana kerentanan ini berlaku:
<?php // 模拟数据库中的用户信息 $users = [ 'admin' => 'password123' ]; // 用户提交的表单数据 $username = $_POST['username']; $password = $_POST['password']; // 验证用户身份 if (isset($users[$username]) && $password === $users[$username]) { echo '登录成功!'; } else { echo '用户名或密码错误!'; } ?>
Dalam kod di atas, apabila pengguna memasukkan kata laluan yang salah, program tidak melakukan sebarang pemprosesan kata laluan Had bilangan ralat atau gesaan ralat membolehkan pengguna akhirnya berjaya log masuk ke akaun mereka dengan mencuba kata laluan yang berbeza.
Untuk membetulkan kerentanan ini, kami perlu melakukan pemprosesan yang sesuai apabila mengesahkan kata laluan pengguna tidak sepadan, seperti mengehadkan bilangan ralat kata laluan atau menambah fungsi kod pengesahan. Berikut ialah contoh kod yang dibaiki:
<?php // 模拟数据库中的用户信息 $users = [ 'admin' => 'password123' ]; // 用户提交的表单数据 $username = $_POST['username']; $password = $_POST['password']; // 设定密码错误次数限制 $loginAttempts = 3; // 验证用户身份 if (isset($users[$username])) { if ($password === $users[$username]) { echo '登录成功!'; } else { if ($_SESSION['login_attempts'] >= $loginAttempts) { echo '密码错误次数过多,请稍后再试!'; } else { $_SESSION['login_attempts']++; echo '用户名或密码错误!'; } } } else { echo '用户名或密码错误!'; } ?>
Dalam kod yang dibaiki, kami telah meningkatkan had bilangan kata laluan yang salah dan melarang sementara pengguna daripada log masuk selepas bilangan kata laluan yang salah mencapai nombor tertentu untuk meningkatkan keselamatan daripada laman web tersebut.
Melalui analisis artikel ini, kami mendedahkan kelemahan pengesahan log masuk PHP biasa dan memberikan contoh kod khusus untuk demonstrasi dan pembaikan. Dalam pembangunan sebenar, pengaturcara harus berhati-hati terhadap kelemahan yang mudah tetapi berbahaya itu dan mengukuhkan pengesahan dan pemprosesan data input pengguna untuk memastikan keselamatan tapak web.
Atas ialah kandungan terperinci Kerentanan pengesahan log masuk PHP didedahkan: Bolehkah anda log masuk ke akaun anda dengan kata laluan yang salah?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!