第一种是session 验证方式
<?php
session_start();
//开启session记录验证码数据
vCode(4, 15);//设置验证码的字符个数和图片基础宽度
//vCode 字符数目,字体大小,图片宽度、高度
function vCode($num = 4, $size = 20, $width = 0, $height = 0) {
!$width && $width = $num * $size * 4 / 5 + 15;
!$height && $height = $size + 10;
//设置验证码字符集合
$str = "23456789abcdefghijkmnpqrstuvwxyzABCDEFGHIJKLMNPQRSTUVW";
//保存获取的验证码
$code = '';
//随机选取字符
for ($i = 0; $i < $num; $i++) {
$code .= $str[mt_rand(0, strlen($str)-1)];
}
//创建验证码画布
$im = imagecreatetruecolor($width, $height);
//背景色
$back_color = imagecolorallocate($im, mt_rand(0,100),mt_rand(0,100), mt_rand(0,100));
//文本色
$text_color = imagecolorallocate($im, mt_rand(100, 255), mt_rand(100, 255), mt_rand(100, 255));
imagefilledrectangle($im, 0, 0, $width, $height, $back_color);
// 画干扰线
for($i = 0;$i < 5;$i++) {
$font_color = imagecolorallocate($im, mt_rand(0, 255), mt_rand(0, 255), mt_rand(0, 255));
imagearc($im, mt_rand(- $width, $width), mt_rand(- $height, $height), mt_rand(30, $width * 2), mt_rand(20, $height * 2), mt_rand(0, 360), mt_rand(0, 360), $font_color);
}
// 画干扰点
for($i = 0;$i < 50;$i++) {
$font_color = imagecolorallocate($im, mt_rand(0, 255), mt_rand(0, 255), mt_rand(0, 255));
imagesetpixel($im, mt_rand(0, $width), mt_rand(0, $height), $font_color);
}
//随机旋转角度数组
$array=array(5,4,3,2,1,0,-1,-2,-3,-4,-5);
// 输出验证码
// imagefttext(image, size, angle, x, y, color, fontfile, text)
@imagefttext($im, $size , array_rand($array), 12, $size + 6, $text_color, 'c:\WINDOWS\Fonts\simsun.ttc', $code);
$_SESSION["VerifyCode"]=$code;
//no-cache在每次请求时都会访问服务器
//max-age在请求1s后再次请求会再次访问服务器,must-revalidate则第一发送请求会访问服务器,之后不会再访问服务器
// header("Cache-Control: max-age=1, s-maxage=1, no-cache, must-revalidate");
header("Cache-Control: no-cache");
header("Content-type: image/png;charset=gb2312");
//将图片转化为png格式
imagepng($im);
imagedestroy($im);
}
?>
第二种是cookie验证
<?php
//session_start();
header("Content-type: image/png");//生成验证码图片
// 全数字
$str = "2,3,4,5,6,7,8,a,b,c,d,e,f,h,i,j,k,m,n,p,q,r,s,t,u,v,w,x,y,z,A,B,C,D,E,F,G,H,J,K,L,M,N,P,Q,R,T,U,V,W,X,Y"; //要显示的字符,可自己进行增删
$list = explode(",", $str);
$cmax = count($list) - 1;
$verifyCode = '';
for ( $i=0; $i < 4; $i++ ){
$randnum = mt_rand(0, $cmax);
$verifyCode .= $list[$randnum]; //取出字符,组合成为我们要的验证码字符
}
$im = imagecreate(58,28); //生成图片
$black = imagecolorallocate($im, 0,0,0); //此条及以下三条为设置的颜色
$white = imagecolorallocate($im, 255,255,255);
$gray = imagecolorallocate($im, 200,200,200);
$red = imagecolorallocate($im, 255, 0, 0);
imagefill($im,0,0,$white); //给图片填充颜色
//将验证码绘入图片
imagestring($im, 5, 10 , 8, $verifyCode, $black); //将验证码写入到图片中
setCookie("code", $verifyCode, time() + 3600, "/");
//$_SESSION['code']=$verifyCode;
//$_SESSION['code'] = $verifyCode; //将字符放入SESSION中
for($i=0;$i<50;$i++) //加入干扰象素
{
imagesetpixel($im, rand(0,100) , rand(0,100) , $black); //加入点状干扰素
imagesetpixel($im, rand(0,100) , rand(0,100) , $red);
imagesetpixel($im, rand(0,100) , rand(0,100) , $gray);
imagearc($im, rand(0,200), rand(0,200), '5', '10', '75', '170', rand(0,300)); //加入弧线状干扰素
//imageline($im, rand(0,200), rand(0,200), rand(0,200), rand(0,200), $red); //加入线条状干扰素
}
imagepng($im);
imagedestroy($im);
分别验证
session验证方式 在验证前端页面php 在生成图片验证码端
//页面提交数据 $varye 开启session_start();
session_start();
$_SESSION["VerifyCode"]=$code;
strtolower($code)==strtolower($varye);
cookie 验证方式 注意时间限制
//设置cookie值
setCookie("code", $verifyCode, time() + 3600, "/");
//接收到生成的验证码 和页面提交的验证码作对比
//$params['code']页面提交数据
$user_code=$params['code'];
//$_COOKIE["code"]取出cookie中验证码 统一字符大小格式
if(strtolower($user_code)==strtolower($_COOKIE["code"])){
echo "验证成功!";
}
strtolower 返回转换为小写的字符串。