下面是一个使用PHP生成简单验证码的示例代码:
(图片来源网络,侵删)
<?php session_start(); // 创建一个随机字符串作为验证码 function generateRandomString($length = 6) { $characters = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ'; $charactersLength = strlen($characters); $randomString = ''; for ($i = 0; $i < $length; $i++) { $randomString .= $characters[rand(0, $charactersLength 1)]; } return $randomString; } // 将生成的验证码存储到会话中 $_SESSION['captcha'] = generateRandomString(); // 创建图像资源 $image = imagecreatetruecolor(100, 30); // 设置背景颜色 $bgColor = imagecolorallocate($image, 255, 255, 255); imagefill($image, 0, 0, $bgColor); // 设置字体颜色 $fontColor = imagecolorallocate($image, 0, 0, 0); // 绘制验证码文本 imagestring($image, 5, 10, 8, $_SESSION['captcha'], $fontColor); // 输出图像 header('Content-Type: image/png'); imagepng($image); // 销毁图像资源,释放内存 imagedestroy($image); ?>
这段代码首先定义了一个generateRandomString
函数,用于生成指定长度的随机字符串,它创建一个新的图像资源,并设置背景颜色和字体颜色,它在图像上绘制验证码文本,并将图像输出为PNG格式,它销毁图像资源以释放内存。
要使用此代码生成验证码,只需将其保存为一个PHP文件(例如captcha.php
),然后在需要显示验证码的地方引用该文件即可,在HTML表单中,可以这样使用:
<form action="submit.php" method="post"> <!-其他表单字段 --> <img src="captcha.php" alt="验证码" /> <input type="text" name="captcha" placeholder="请输入验证码" /> <input type="submit" value="提交" /> </form>
当用户提交表单时,可以在后端验证用户输入的验证码是否与会话中存储的验证码相匹配。
(图片来源网络,侵删)
本文来源于互联网,如若侵权,请联系管理员删除,本文链接:https://www.9969.net/42471.html