第一步:首先要确定你已经把php的图片库的功能打开了

找到php.ini中;extension=php_gd2.dll
把 之前的;去掉,然后在php文件夹下ext文件夹中的php_gd2.dll拷贝到windows/system32下(这里是windows xp系统,如果是2000的话,应该是放到winnt/system32下),这样之后,你的php的图片库已经被加载了,否则你就会收到类似< br />
<b>Fatal error</b>: Call to undefined function: imagecreate() in <b>d:wwwimgtest3.php</b> on line <b>3</b><br />
的错误。
实现这一步之后,我们实际上已经解决了第一个难题,接下来就是生成随机数字了。

第二步:生成随机的数字

这 里用到了两个函数,srand & rand,另外有很多网站中的验证码不完全是数字,有些是字母和数字相混合的,有的甚至就是汉字,这个又是如何实现的呢,带着这个疑问,我baidu了一 下。所谓的数字和字母一起的验证码其实也很简单,我自己写了一段就可以实现
$ychar="0,1,2,3,4,5,6,7,8,9,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P,Q,R,S,T,U,V,W,X,Y,Z";
$list=explode(",",$ychar);
for($i=0;$i<4;$i++){
$randnum=rand(0,35);
$authnum.=$list[$randnum];
}
这里的只有数字和大写字母,因为有的人反映,小写的字母l和数字1很难区分,数字0和字母o也不好分,所以数字和大写字母组合还是比较好的。

第三步:生成图片

主要的用到了两个函数
ImagePNG($im);
ImageDestroy($im);
另外,为了防止用ocr读取验证码,可以用imagesetpixel给图片加一些杂色,这样的话就不容易识别出来了。

至此,验证码的功能基本上能够达到了。

完整的代码如下:

<?php
session_start();
?>
<?php
//生成验证码图片
Header("Content-type: image/PNG");
srand((double)microtime()*1000000);//播下一个生成随机数字的种子,以方便下面随机数生成的使用

//session_start();//将随机数存入session中
$_SESSION[‘authnum’]="";
$im = imagecreate(70,20) or die("Cant’s initialize new GD image stream!"); //制定图片背景大小
$black = ImageColorAllocate($im, 0,0,0); //设定三种颜色
$white = ImageColorAllocate($im, 255,255,255);
$gray = ImageColorAllocate($im, 200,200,200);

imagefill($im,0,0,$gray); //采用区域填充法,设定(0,0)

//生成数字和字母混合的验证码方法
$ychar="0,1,2,3,4,5,6,7,8,9,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P,Q,R,S,T,U,V,W,X,Y,Z";
$list=explode(",",$ychar);
for($i=0;$i<4;$i++){
$randnum=rand(0,35);
$authnum.=$list[$randnum];
}

//while(($authnum=rand()%100000)<10000); //生成随机的五们数
//将五位整数验证码绘入图片
$_SESSION[‘authnum’]=$authnum;

imagestring($im, 5, 10, 3, $authnum, $black);
// 用 col 颜色将字符串 s 画到 image 所代表的图像的 x,y 座标处(图像的左上角为 0, 0)。
//如果 font 是 1,2,3,4 或 5,则使用内置字体

for($i=0;$i<200;$i++) //加入干扰象素
{
$randcolor = ImageColorallocate($im,rand(0,255),rand(0,255),rand(0,255));
imagesetpixel($im, rand()%70 , rand()%30 , $randcolor);
}
ImagePNG($im);
ImageDestroy($im);

?>