现在验证码在表单中的应用越来越多了,但是如果用js来实现总觉得不太方便,因此使用php来实现下,在此记录下。
当然,我们也可以封装成一个函数,以后使用的时候也是很方便的,这里并未封装,感兴趣的小伙伴可以自己封装下。
具体实现代码:
新建一个cap_sz.php文件:
<?phpsession_start(); //设置session,一定要在顶部$width = 150; //设置图片宽为300像素$height = 40; //设置图片高为40像素$image = imagecreatetruecolor($width, $height); //设置验证码大小的函数$bgcolor = imagecolorallocate($image, 255, 255, 255); //验证码颜色RGB为(255,255,255)#ffffffimagefill($image, 0, 0, $bgcolor); //区域填充$cap_code = "";for($i=0;$i<4;$i++){ $fontsize = 7; //设置字体大小 $fontcolor = imagecolorallocate($image, rand(0,120), rand(0,120), rand(0,120)); //数字越大,颜色越浅,这里是深颜色0-120 $fontcontent = rand(0,9); $cap_code.=$fontcontent; //.=连续定义变量 $x = ($i*150/4)+rand(5,10); $y = rand(5,10); //设置坐标 imagestring($image, $fontsize, $x, $y, $fontcontent, $fontcolor);}$_SESSION['code'] = $cap_code; //存到session//设置干扰元素,设置雪花点for($i=0;$i<300;$i++){ $inputcolor = imagecolorallocate($image, rand(50,200), rand(20,200), rand(50,200)); //设置颜色,20-200颜色比数字浅,不干扰阅读 i->keys[$i]['filename'],$this->keys[$i]['char']); } //绘制干扰线 //根据字体酌情增加干扰线 imageline($bg,0,15,40,10,$blue); //图像输出头文件 header('Content-type:image/png'); //输出png图像 imagepng($bg); //清除缓存资源 imagedestroy($bg); } public function checkKeys($input){ if(count($input)!=$this->count){ return 'ERROR:长度不正确.'; }else{ for($i=0;$i < $this->count;$i++){ //0 o O I l 1 校准,根据所选择的字体确定是否需要手动校准 if($input[$i] != $this->keys[$i]['char']){ return 'SUCCESS.'; }else{ return 'ERROR:请输入正确验证码.'; } } } }}?>







