php实现数字验证码

用php实现验证码,验证码是为了区别机器与人的操作,提高安全性。需要安装服务器软件,我使用的是wamp,之后编写php验证码页面。

分为以下几个步骤来实现:

一、实现验证码底图
目标:通过php代码,生成一张100*30px大小的图片
方法:resource imagecreatetruecolor(int $width,int $height)
注意事项:
(a)依赖GD扩展
(b)输出图片前,必须提前输出图片header信息
(c)该方法默认输出为黑色背景
//
二、实现数字验证码
方法:int imagecolorallocate(resource $image,int $red,int $green,int $blue);
    bool imagestring(resource $image,int $font,int $x,int $y,string $s,int $col);
注意事项:/控制好字体大小与分布,避免字体重叠或显示不全
//
三、增加干扰元素
目标:为验证码增加干扰元素,干扰的点或线
方法:bool imagesetpixel(resource $image,int $x,int $y,int $color);
            bool imageline(resource $image,int $x1,int $y1,int $x2,int $y2,int $color)
注意事项:干扰信息一定控制好颜色,避免“喧宾夺主”;

四、通过SESSION存储验证信息
目标:在服务器端记录验证码信息,便于用户输入后做校验
方法:bool session_start(void)
注意事项:(a)session_start()必须处于脚本最顶部
(b)多服务器情况,需要考虑集中管理session信息

五、验证码通过表单提交、校验
目标:将已生成的验证码提供给用户,并校验用户验证码的正确性
方法:html<form>表单基础
validate.php

<?php
	session_start();

	$image=imagecreatetruecolor(100,30);
	$bgcolor=imagecolorallocate($image,255,255,255); //#fff
	imagefill($image, 0, 0, $bgcolor);

	$captch_code='';
	//画出4个随机的数字或者字母
	for($i=0;$i<4;$i++){
		$fontsize=6;
		//为了让数字的颜色不同,使用随机颜色rand(0,120),120之前是深色
		$fontcolor=imagecolorallocate($image,rand(0,120),rand(0,120),rand(0,120));
		
		$data='abcdefghijklmnopqrstuvwxyz123456789';//由于o和0对于一些人不太好区别,所以把0去掉了
		$fontcontent=substr($data,rand(0,strlen($data)),1);	
		$captch_code.=$fontcontent;		
		$x=($i*100/4)+rand(5,10);
		$y=rand(5,10);
		//水平画一条字符串
		imagestring($image,$fontsize,$x,$y,$fontcontent,$fontcolor);
	}
	$_SESSION['authcode']=$captch_code;
	//增加点干扰元素
	for($i=0;$i<200;$i++){
		$pointcolor=imagecolorallocate($image,rand(50,200),rand(50,200),rand(50,200));
		//画一个单一像素
		imagesetpixel($image,rand(1,99),rand(1,99),$pointcolor);
	}
	//增加线干扰元素
	for($i=0;$i<3;$i++){
		$linecolor=imagecolorallocate($image,rand(80,220),rand(80,220),rand(80,220));
		imageline($image,rand(1,99),rand(1,29),rand(1,99),rand(1,29),$linecolor);
	}
	header('content-type:image/png');
	imagepng($image);

	imagedestroy($image);

form.php


<?php


if(isset($_REQUEST['authcode'])){
	session_start();
	if(strtolower($_REQUEST['authcode'])==$_SESSION['authcode']){
		echo '<font color="#0000cc">输入正确</font>';
	}else{
		echo '<font color="#cc0000><b>输入错误</b></font>';
	}
	exit();
}
?>


<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title>确认验证码</title>
</head>
<body>
    <form method="post" action='./form.php'>
        <p>验证码图片:
        	<img id="code_img" border="1" src="./validate.php?r=<?php echo rand();?>" width="100" alt="">
        	<a href="javascript:void(0)" οnclick="document.getElementById('code_img').src='./validate.php?r='+Math.random()">换一个?</a>
        </p>
        <p>请输入图片中的内容:<input type="text" name="authcode" value=""></p>
        <p><input type="submit" value="提交" style="padding:6px 20px;"></p>
    </form>
</body>
</html>


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值