使用PHP怎样做有干扰素的验证码功能?
导读:验证码相信大家都不陌生,比较常见的有一般数字字母验证码、有干扰素的数字字母验证码、图片验证码等等,这篇我们我们来了解如何用PHP和GD哭实现有干扰素的验证码功能,文中示例代码介绍的非常详细,感兴趣的朋友接下来一起跟随小编看看吧。 生成字母数...
验证码相信大家都不陌生,比较常见的有一般数字字母验证码、有干扰素的数字字母验证码、图片验证码等等,这篇我们我们来了解如何用PHP和GD哭实现有干扰素的验证码功能,文中示例代码介绍的非常详细,感兴趣的朋友接下来一起跟随小编看看吧。
生成字母数字的图片验证码
首先需要看php.ini配置文件中有没有GD库,如果没有开启,请自行开启下,我用的小皮面板,基本现在都给你带上了。
需要生成4位(位数自定)验证码
//首先生成4位验证码
//开启session
session_start();
//数组集合
$arr = array_merge(range(0,9),range('a','z'),range('A','Z'));
//打乱数组
shuffle($arr);
//截取4位验证码
$code = array_slice($arr,0,4);
//全部转为小写
$code = strtolower(join('',$code));
var_dump($code);
//将code存入session
$_SESSION['code'] = $code;
3. 开启GD库画图
注意一下这个imagecolorallocate函数
//创建画布
$img = imagecreate(120,30);
//画布颜色
$white = imagecolorallocate($img,255,255,255);
//自定义集中颜色
$c1 = imagecolorallocate($img,14,38,54);
$c2 = imagecolorallocate($img,63,5,16);
$c3 = imagecolorallocate($img,248,248,42);
$c4 = imagecolorallocate($img,0,0,0);
//点干扰素
for ($i = 0;
$i 300;
$i++){
imagesetpixel($img,rand(0,120),rand(0,30),$c1);
}
//虚线干扰素
for($j = 0;
$j 200;
$j++){
imagedashedline($img,rand(0,120),rand(0,30),rand(0,120),rand(0,30),$c2);
}
//线干扰素
for ($j = 0;
$j 10;
$j++){
imageline($img,rand(0,120),rand(0,30),rand(0,120),rand(0,30),$c2);
}
//字体,这个你路径对了就OK
$font = "simhei.ttf";
//向图像写入文本
imagettftext($img,18,2,40,20,$c4,$font,$code);
//以jpg格式输出,还有以png啥的,imagepng这个自己看
imagejpeg($img);
//结束之后销毁,不销毁也行,php自带垃圾回收
imagedestroy($img);
前台的展示
?php
session_start();
print_r($_POST);
print_r($_SESSION['code']);
//如果提交的验证码跟session里面存的一样及认证成功
if($_POST['n3'] == $_SESSION['code']){
echo '注册成功';
}
else{
echo '注册失败';
}
?>
!doctype html>
html lang="en">
head>
meta charset="UTF-8">
meta name="viewport"
content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
meta http-equiv="X-UA-Compatible" content="ie=edge">
title>
Document/title>
/head>
body>
form action="" method="post">
input type="text" name="n1" placeholder="cc">
input type="text" name="n2" placeholder="s">
input type="text" name="n3">
!--这里点击刷新验证码 -->
img src="xxx.php" onclick="this.src='index.php?'+Math.random()" alt="">
input type="submit" value="submit">
/form>
/body>
/html>
以上就是用PHP和GD库实现有干扰素的验证码的代码,本文只是提供了一种实现思路,代码仅供参考,需要的朋友可以了解看看,希望对大家学习PHP有帮助,想要了解更多可以继续浏览网络其他相关的文章。
文本转载自脚本之家
声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!
若转载请注明出处: 使用PHP怎样做有干扰素的验证码功能?
本文地址: https://pptw.com/jishu/653333.html
