Cara membuat kod pengesahan imej dinamik menggunakan pustaka PHP dan GD
Dalam aplikasi web, untuk mengelakkan bot dan penyerang berniat jahat daripada mengautomasikan operasi, kod pengesahan sering digunakan, yang memerlukan pengguna memasukkan kod pengesahan untuk mengesahkan identiti mereka. Dengan menggunakan perpustakaan PHP dan GD, kami boleh membuat kod pengesahan imej dinamik dengan mudah.
Pustaka GD ialah perpustakaan sambungan untuk PHP yang menyediakan beberapa fungsi untuk memproses imej. Dalam artikel ini, kami akan menggunakan fungsi pustaka GD untuk menjana imej yang mengandungi aksara rawak dan membentangkannya kepada pengguna sebagai kod pengesahan.
Langkah 1: Buat halaman web PHP yang ringkas
Mula-mula, kami perlu mencipta halaman web PHP yang ringkas untuk membentangkan kod pengesahan imej dinamik kami. Cipta fail bernama index.php dan salin kod berikut ke dalam fail:
<!DOCTYPE html> <html> <head> <title>动态图片验证码</title> </head> <body> <h1>动态图片验证码</h1> <img src="captcha.php" alt="验证码"> <br> <a href="">换一个验证码</a> </body> </html>
Dalam halaman HTML mudah ini, kami telah mencipta tajuk dan elemen imej yang memaparkan kod pengesahan. Kami menetapkan captcha.php untuk atribut src imej, kemudian kami akan menjana dan memberikan imej dalam fail ini.
Langkah 2: Buat fail captcha.php
Sekarang, kita perlu mencipta fail bernama captcha.php dan salin kod berikut ke dalam fail:
<?php // 启动会话 session_start(); // 创建图像宽度和高度 $width = 200; $height = 50; // 创建一个空的图像 $image = imagecreatetruecolor($width, $height); // 设置背景颜色 $bg_color = imagecolorallocate($image, 255, 255, 255); imagefill($image, 0, 0, $bg_color); // 生成随机的验证码 $characters = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ'; $length = mt_rand(4, 6); $code = ''; for ($i = 0; $i < $length; $i++) { $code .= $characters[mt_rand(0, strlen($characters) - 1)]; } // 将验证码存储在会话中 $_SESSION['captcha_code'] = $code; // 设置文本颜色 $text_color = imagecolorallocate($image, 0, 0, 0); // 在图像中绘制验证码 $font = __DIR__ . '/arial.ttf'; imagettftext($image, 30, 0, 10, 40, $text_color, $font, $code); // 发送图像头信息 header('Content-Type: image/png'); // 将图像呈现给用户 imagepng($image); imagedestroy($image); ?>
Dalam fail PHP ini, kita mulakan sesi supaya kod pengesahan boleh disimpan dan diakses. Kami kemudian mencipta imej kosong dengan lebar dan ketinggian yang ditentukan, dan menetapkan warna latar belakang kepada putih. Seterusnya, kami menjana kod pengesahan yang mengandungi aksara rawak dan menyimpannya dalam sesi.
Kemudian kami menetapkan warna teks kepada hitam dan melukis teks captcha pada imej menggunakan fon yang dipilih. Akhir sekali, kami menghantar maklumat pengepala imej dan membentangkan imej kepada pengguna.
Langkah 3: Uji dan gunakan kod pengesahan
Kini, kita boleh membuka fail index.php dalam pelayar dan melihat kod pengesahan yang dijana. Setiap kali halaman dimuat semula, kod pengesahan yang berbeza dijana.
Dalam borang, kami boleh mengesahkan identiti pengguna dengan menyemak sama ada kod pengesahan yang dimasukkan oleh pengguna sepadan dengan kod pengesahan yang disimpan dalam sesi.
Kami boleh menggunakan kod berikut untuk menyemak ketepatan kod pengesahan:
session_start(); if (isset($_POST['submit'])) { if ($_POST['captcha'] == $_SESSION['captcha_code']) { // 验证码正确,执行所需操作 } else { echo '验证码错误!'; } }
Di sini kami menganggap bahawa kandungan artikel ini tidak termasuk bahagian borang dan hanya menunjukkan cara untuk mengesahkan ketepatan kod pengesahan.
Dengan menggunakan perpustakaan PHP dan GD, kami boleh mencipta captcha imej dinamik dengan mudah untuk melindungi aplikasi web kami. Kod pengesahan ini memainkan peranan penting dalam mengenal pasti pengguna sebenar dan mencegah serangan automatik.
Atas ialah kandungan terperinci Cara membuat kod pengesahan imej dinamik menggunakan perpustakaan PHP dan GD. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!