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

 2023-09-25 阅读 24 评论 0

摘要:本文记录从php 下载配置GD图片生成库 到使用该库生成验证码图片,网页上实现验证码。使用技术:php使用GD库绘图 【php版本7.3】生成验证码,php session 缓存实现最终效果:一. 配置GD库1、将php下载包解压后的主目录下的php.ini-development 文件重命名为

本文记录从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);

php生成二维码,}

**/

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

$captch_code='';

js生成随机验证码。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请求了,比较方便

}

版权声明:本站所有资料均为网友推荐收集整理而来,仅供学习和研究交流使用。

原文链接:https://hbdhgg.com/3/95337.html

发表评论:

本站为非赢利网站,部分文章来源或改编自互联网及其他公众平台,主要目的在于分享信息,版权归原作者所有,内容仅供读者参考,如有侵权请联系我们删除!

Copyright © 2022 匯編語言學習筆記 Inc. 保留所有权利。

底部版权信息