GD库在php 中的另一个重要的应用,是使用GD库生成验证码。
使用GD库生成验证码 的工作原理是:在生成图像时将验证的文字保存在session中然后在接受用户表单时将用户的提交内容与session中的值进行比较。
表单代码如下:
<html>
<head>
<title>GD库生成验证码html页面</title>
</head>
<h1 align="center">WELCOME TO WWW.PHPDO.NET<BR></h1>
<h2>请输入验证码:</h2>
<form action="GD_yanzheng.php" method="post">
<input name="auth" type="text" size="4" maxlength="4" />
<img src="auth.php" border="0"/>
<input type="submit" value="Submit" />
</form>
<body>
</body>
</html>
php 生成验证图像的代码如下:
<?php
session_start();
header("Content-type:image/png"); //声明图片格式是png
$img_width = 100;
$img_height = 20;
srand(microtime() * 100000);
for($i=0;$i<4;$i++)
{
$new_number.=dechex(rand(0,15));
}
//将验证码输入session
$_SESSION[check_auth]=$new_number;
$number_img = imageCreate($img_width,$img_height);
imageColorallocate($number_img, 255, 255, 255);
for ($i=0;$i<strlen($_SESSION[check_auth]);$i++)
{
$font = mt_rand(3,5);
$x = mt_rand(1,8)+$img_width*$i/4;
$y = mt_rand(1,$img_height/4);
//字符颜色
$color = imageColorAllocate($number_img,mt_rand(0,100),mt_rand(0,150),mt_rand(0,200));
imageString($number_img,$font,$x,$y,$_SESSION[check_auth][$i],$color);
}
//以png格式输出
imagepng($number_img);
imagedestroy($number_img);
?>
验证成功与否的php页面如下:
<?php
session_start();
//获取输入的验证码
$auth = $_POST['auth'];
if ($auth = "")
{
echo "错误:验证码为空";
}
if ($auth == $_SESSION[check_auth])
{
echo "正确:验证码输入正确";
}
else
{
echo "错误:验证码输入不正确";
}
?>
srand函数:播下随机数发生器种子,具体用法在PHP常用函数(2) 。
microtime 函数:返回当前 Unix 时间戳和微秒数,具体用法在PHP常用函数(2) 。
dechex函数:十进制转换为十六进制
rand函数:产生一个随机整数
imagecreate函数:新建一个基于调色板的图像
imagecolorallocate 函数:为一幅图像分配颜色
strlen函数:返回字符串长度
mt_rand 函数:生成更好的随机数
imagestring 函数:水平地画一行字符串
imagepng 函数:以 PNG 格式将图像输出到浏览器或文件
imagedestroy函数:销毁一图像
5289

被折叠的 条评论
为什么被折叠?



