PHP生产一个验证码图片,PHP使用GD库生成验证码图片,实现图片验证

本文记录从php 下载配置GD图片生成库 到使用该库生成验证码图片,网页上实现验证码。

使用技术:

php使用GD库绘图 【php版本7.3】

php session 缓存

实现最终效果:

3f8256ff86fd?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

一. 配置GD库

1、将php下载包解压后的主目录下的php.ini-development 文件重命名为php.ini。

2、将“;extension_dir = "ext" ”这一选项修改为“extension_dir = "你的php下载包解压后的主目录/ext“”。注意,这个修改的路径是你自己的ext文件夹的完整绝对路径,另外还要把最前面的逗号删除。PS:可以利用很多文本编辑器的搜索功能查找。

3、打开apache压缩包主目录下conf文件夹里的httpd.conf文件,然后搜索 PHPIniDir 这个选项,然后修改它的值为自己下载的php压缩包解压后的主目录的完整绝对路径。

4、自己写一个php文件测试,内容主要是phpinfo(); 其实就是调用这个函数,在浏览器中访问这个文件,去查看它的loadfile选项里是否是正确的自己php压缩包解压后的位置。

5、剩下的开启GD库支持也很简单了。直接搜索 ; extension=php_gd2.dl 然后删除最前面的分号就可以了。

二、 写php代码提供完成验证码

本次使用两个php文件:分别是图片生成php文件(getAuthentication.php)和前台页面(auth.php)// 访问auth.php文件效果图:

3f8256ff86fd?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

getAuthentication.php文件代码:

session_start(); //启动session // 使用session需要调用这个函数,它也是一个扩展

$image = imagecreatetruecolor(100,30);//创建一个宽100,高度30的图片

$bgcolor=imagecolorallocate($image,255,255,255);//图片背景是白色

imagefill($image,0,0,$bgcolor);//图片填充白色

//随机数,下面的例子是只是数字的验证码

/**

for($i=0;$i<4;$i++){

$fontsize=6;

$fontcolor=imagecolorallocate($image,rand(0,120),rand(0,120),rand(0,120));

$fontcontent=rand(0,9);

$x=($i*100/4)+ rand(5,10);

$y=rand(5,10);

imagestring($image,$fontsize,$x,$y,$fontcontent,$fontcolor);

}

**/

//随机数据,下面的例子是随机数据,包括字母和数字

$captch_code='';

for($i=0;$i<4;$i++){

$fontsize=6;

$fontcolor=imagecolorallocate($image,rand(0,120),rand(0,120),rand(0,120));

$data='asdfdfglfg74erf21854hgfhgfhkg4ljkghjtrtywiqpoqpwepdfgvnjytyut12313345645667686797800';

$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['authenticate']=$captch_code;// 设置session

//随机点,生成干扰点

for($i=0;$i<200;$i++){

$pointcolor=imagecolorallocate($image,rand(50,120),rand(50,120),rand(50,120));

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); //返回图片

imagedestory($image);

?>

auth.php 的代码:

//验证表单:

if ($_SERVER['REQUEST_METHOD']=='POST') {

session_start(); //session也是一个扩展,使用这个扩展必须先调用这个函数。

echo $_SESSION['authenticate'];

if(!empty($_POST['authenticate'])&&!empty($_SESSION['authenticate'])) {

if($_POST['authenticate']==$_SESSION['authenticate']) {

$_GLOBALS['message'] = '正确';

}

else {

$_GLOBALS['message'] = '错误';

}

}

else {

$_GLOBALS['message'] = '没有输入验证码';

}

}

?>

<?php echo $_GLOBALS['message'] ; ?>

验证

getAuthentication.php

提交

// 点击验证码图片,进行更换验证码

document.getElementById("img").onclick = function() {

this.src='getAuthentication.php?r='+Math.random(); ///这样就不需要AJAX请求了,比较方便

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值