生成验证码图片

<?php
/**
 * 生成验证码图片
 *
 * @param String $word 验证码在session中的变量名称
 */
function valiCode($word='randcode'){
	Header("Content-type: image/gif");
	$border = 0; //是否要边框 1要:0不要
	$how = 4; //验证码位数
	$w = $how*15; //图片宽度
	$h = 18; //图片高度
	$fontsize = 10; //字体大小
	$alpha = "abcdefghijkmnpqrstuvwxyz"; //验证码内容1:字母
	$number = "23456789"; //验证码内容2:数字
	$randcode = ""; //验证码字符串初始化
	srand((double)microtime()*1000000); //初始化随机数种子
	$im = ImageCreate($w, $h); //创建验证图片
	/*
	* 绘制基本框架
	*/
	$bgcolor = ImageColorAllocate($im, 255, 255, 255); //设置背景颜色
	ImageFill($im, 0, 0, $bgcolor); //填充背景色
	if($border)
	{
		$black = ImageColorAllocate($im, 0, 0, 0); //设置边框颜色
		ImageRectangle($im, 0, 0, $w-1, $h-1, $black);//绘制边框
	}
 
	/*
	* 逐位产生随机字符
	*/
	for($i=0; $i<$how; $i++)
	{
		$alpha_or_number = mt_rand(0, 1); //字母还是数字
		$str = $alpha_or_number ? $alpha : $number;
		$which = mt_rand(0, strlen($str)-1); //取哪个字符
		$code = substr($str, $which, 1); //取字符
		$j = !$i ? 4 : $j+15; //绘字符位置
		$color3 = ImageColorAllocate($im, mt_rand(0,100), mt_rand(0,100), mt_rand(0,100)); //字符随即颜色
		ImageChar($im, $fontsize, $j, 3, $code, $color3); //绘字符
		$randcode .= $code; //逐位加入验证码字符串
	}
 
	/*
	* 如果需要添加干扰就将注释去掉
	*
	* 以下for()循环为绘背景干扰线代码
	*/
	/* + -------------------------------绘背景干扰线 开始-------------------------------------------- + */
	for($i=0; $i<5; $i++)//绘背景干扰线
	{
		$color1 = ImageColorAllocate($im, mt_rand(0,255), mt_rand(0,255), mt_rand(0,255)); //干扰线颜色
		ImageArc($im, mt_rand(-5,$w), mt_rand(-5,$h), mt_rand(20,300), mt_rand(20,200), 55, 44, $color1); //干扰线
	}
	/* + -------------------------------绘背景干扰线 结束-------------------------------------- + */
 
	/*
	* 如果需要添加干扰就将注释去掉
	*
	* 以下for()循环为绘背景干扰点代码
	*/
	/* + --------------------------------绘背景干扰点 开始------------------------------------------ + */
 
	for($i=0; $i<$how*40; $i++)//绘背景干扰点
	{
		$color2 = ImageColorAllocate($im, mt_rand(0,255), mt_rand(0,255), mt_rand(0,255)); //干扰点颜色
		ImageSetPixel($im, mt_rand(0,$w), mt_rand(0,$h), $color2); //干扰点
	}
 
	/* + --------------------------------绘背景干扰点 结束------------------------------------------ + */
 
	//把验证码字符串写入session  方便提交登录信息时检验验证码是否正确  例如:$_POST['randcode'] = $_SESSION['randcode']
	$_SESSION[$word] = $randcode;
	/*绘图结束*/
	Imagegif($im);
	ImageDestroy($im);
	/*绘图结束*/
}
?>




                
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

chaojie2009

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值