


Bagaimana untuk melaksanakan pendaftaran log masuk dengan kod pengesahan dalam PHP
PHP ialah bahasa pengaturcaraan yang digunakan secara meluas dalam pembangunan laman web Ia sangat mudah, cekap dan fleksibel. Dalam pembangunan PHP, fungsi log masuk dan pendaftaran pengguna sering terlibat, dan untuk mencapai keselamatan, mekanisme pengesahan kod pengesahan perlu ditambah. Artikel ini akan memperkenalkan cara menggunakan PHP untuk melaksanakan fungsi pendaftaran log masuk dengan kod pengesahan.
1. Pelaksanaan fungsi log masuk
1.1 Buat halaman log masuk
Kita perlu membuat halaman log masuk untuk pengguna, menyediakan mereka dengan rangka kerja untuk memasuki akaun mereka nombor dan kata laluan, serta kotak input kod pengesahan. Anda boleh menambah kod berikut pada kod:
<html> <head> <title>登陆页面</title> <meta charset="utf-8"> </head> <body> <form action="login.php" method="POST"> <label>账号: <input type="text" name="username"></label><br> <label>密码: <input type="password" name="password"></label><br> <label>验证码: <input type="text" name="captcha"></label> <img src="captcha.php" alt="验证码"><br> <input type="submit" name="submit" value="登陆"> </form> </body> </html>
1.2 Cipta kod pengesahan
Untuk meningkatkan keselamatan log masuk, kami perlu menggunakan kod pengesahan untuk mengesahkan identiti pengguna, jadi kita perlu mencipta imej kod Pengesahan. Anda boleh menambah kod berikut pada kod:
<?php session_start(); header("Content-type: image/PNG"); //定义画布的宽和高 $width = 60; $height = 25; //生成验证码并保存到Session $captcha_num = ''; for ($i = 0; $i < 4; ++$i) { $captcha_num .= rand(0, 9); } $_SESSION['captcha'] = $captcha_num; //创建画布 $img = imagecreate($width, $height); //设置画布颜色 $bg_color = imagecolorallocate($img, 255, 255, 255); //生成干扰线 for ($i = 0; $i < 5; ++$i) { $line_color = imagecolorallocate($img, rand(0, 255), rand(0, 255), rand(0, 255)); imageline($img, rand(0, $width), rand(0, $height), rand(0, $width), rand(0, $height), $line_color); } //生成干扰点 for ($i = 0; $i < 100; ++$i) { $pixel_color = imagecolorallocate($img, rand(0, 255), rand(0, 255), rand(0, 255)); imagesetpixel($img, rand(0, $width), rand(0, $height), $pixel_color); } //设置验证码颜色和大小 $captcha_color = imagecolorallocate($img, 0, 0, 0); $captcha_size = 20; //将验证码画到画布上 imagestring($img, $captcha_size, 10, 5, $captcha_num, $captcha_color); //输出画布 imagepng($img); //释放资源 imagedestroy($img); ?>
Fail captcha.php dalam kod ini adalah fail berasingan Ia akan menjana imej kod pengesahan rawak dan menyimpan kod pengesahan ke tengah Sesi .
1.3 Lakukan pengesahan log masuk
Selepas pengguna memasukkan maklumat pengguna dan kod pengesahan, kami perlu mengesahkan kandungan input. Anda boleh menambah kod berikut pada kod:
<?php session_start(); if (isset($_POST['submit'])) { //判断是否提交表单 if ($_POST['captcha'] == $_SESSION['captcha']) { //判断验证码是否正确 $username = $_POST['username']; $password = $_POST['password']; //查询数据库验证账号密码是否正确 $mysql = new mysqli('localhost', 'root', 'password', 'database'); //替换成自己的用户名、密码、数据库 $result = $mysql->query("SELECT * FROM users WHERE username='$username' AND password='$password'"); if ($result->num_rows == 1) { //账号密码验证成功 echo "登录成功!"; } else { //账号或密码错误 echo "账号或密码错误!"; } $mysql->close(); } else { //验证码错误 echo "验证码错误!"; } } ?>
Fail login.php dalam kod ini ialah fail berasingan yang digunakan untuk memproses data borang yang diserahkan oleh pengguna, dan kemudian melakukan operasi yang sepadan selepas lulus pengesahan itu.
2. Pelaksanaan fungsi pendaftaran
2.1 Buat halaman pendaftaran
Kami perlu membuat halaman pendaftaran untuk pengguna, memberikan mereka rangka kerja untuk memasukkan nombor akaun mereka dan kata laluan, serta kotak input kod pengesahan. Anda boleh menambah kod berikut pada kod:
<html> <head> <title>注册页面</title> <meta charset="utf-8"> </head> <body> <form action="register.php" method="POST"> <label>账号: <input type="text" name="username"></label><br> <label>密码: <input type="password" name="password"></label><br> <label>验证码: <input type="text" name="captcha"></label> <img src="captcha.php" alt="验证码"><br> <input type="submit" name="submit" value="注册"> </form> </body> </html>
2.2 Pengesahan pendaftaran
Selepas pengguna memasukkan maklumat pengguna dan kod pengesahan, kami perlu mengesahkan kandungan input. Anda boleh menambah kod berikut pada kod:
<?php session_start(); if (isset($_POST['submit'])) { //判断是否提交表单 if ($_POST['captcha'] == $_SESSION['captcha']) { //判断验证码是否正确 $username = $_POST['username']; $password = $_POST['password']; //插入数据到数据库中 $mysql = new mysqli('localhost', 'root', 'password', 'database'); //替换成自己的用户名、密码、数据库 $result = $mysql->query("INSERT INTO users(username, password) VALUES ('$username', '$password')"); if ($result) { //插入数据成功 echo "注册成功!"; } else { //插入数据失败 echo "注册失败!"; } $mysql->close(); } else { //验证码错误 echo "验证码错误!"; } } ?>
Fail register.php dalam kod ini ialah fail berasingan yang digunakan untuk memproses data borang yang dihantar oleh pengguna Selepas lulus pengesahan, data tersebut dimasukkan ke dalam pangkalan data.
3. Ringkasan
Di atas adalah semua kod untuk menggunakan PHP untuk melaksanakan fungsi log masuk dan pendaftaran dengan kod pengesahan. Melalui artikel ini, kita boleh belajar cara membuat kod pengesahan dan mengesahkan maklumat log masuk dan pendaftaran pengguna dalam PHP. Fungsi log masuk dan pendaftaran dengan kod pengesahan boleh meningkatkan keselamatan tapak web dengan berkesan, mencegah serangan berniat jahat oleh robot dan melindungi maklumat peribadi pengguna.
Atas ialah kandungan terperinci Bagaimana untuk melaksanakan pendaftaran log masuk dengan kod pengesahan dalam PHP. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas



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.

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.

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.

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.

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.

Artikel ini membincangkan strategi untuk mencegah serangan CSRF di PHP, termasuk menggunakan token CSRF, kuki tapak yang sama, dan pengurusan sesi yang betul.

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

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