图片验证码生成以及前端验证

第一种是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 返回转换为小写的字符串。

你可能感兴趣的:(PHP)