php验证码安装代码_php实现的验证码小程序代码分享

基于php实现的验证码小程序

验证码功能(个人理解):

减轻服务器的压力(如12306的验证码功能);

防止暴力注册

个人思路:在a-z,A-Z,1-9生成n位随机的数来构成新的验证码。

关于生成验证码的几个小函数

range() //指定范围输出一个数组

a)       如: range(1,9)

array_merge()//合并数组

a)       array_merge(数组1,数组2….)

array_rand(数组,数量)

a)       随机从数组中取出几个下标返回一个数组

shuffle(数组)//将再一次打乱数组中元素

mt_rand(指定一个范围) //生成一个更好的随机数

如: mt_rand(1,5) //生成一个在1-5之间的任意数

生成验证码代码

$arr1=range('a', 'z');//指定范围输出一个数组

$arr2=range('A', 'Z');

$arr3=range(1,9);

$arr=array_merge($arr1,$arr2,$arr3); //合并数组

$index = array_rand($arr,5); //在$arr中随机取5个数,返回值是$arr的下标

Shuffle($index);

$code = '';//定义一个空的字符串来存储生成的验证码用'点'来进行拼接

foreach ($index as $key => $value) {//遍历数组

$code.= $arr[$value];//根据下标取数组中的值

}

var_dump($code);

?>

运行结果截图

13322e88b6dda04db6fc5721bf3157d7.png

完善:要把验证码添加到图像中这样的验证码才逼真

在完善之前先介绍有关图像创建的大致步骤

创建图像

方法一: 创建一个真彩色图像 (空画布)

imagecreatetruecolor(width, height) //创建一个真彩色图像

说明:

width : 画布的宽度(像素)

height: 画布的高度(像素)

返回值为图像资源

01d28bd6511e1ea7c09487b79eb17eff.png

注意:

496136f6f5dea8e5d2b72c43061d6cf3.png

为真彩色图像: 填充颜色

imagefill(image, x, y, color) //为图像资源填充颜色

说明:

image //图像资源

x,y,填充的坐标点(注意:填充的与此点最接近的颜色)

color; //用什么颜色来填充

为真彩色图像: 分配颜色

imagecolorallocate(image, red, green, blue)

说明:

image //图像资源

red: //红颜色(0-255) 或 0x(00-ff) //即十六进制来表示 (0xff就是255)

green//绿颜色(0-255)

blue //蓝颜色(0-255)

imagefill和imagecolorallocate的代码演示

在没有给画布填充颜色时的效果

e6752db32c447b545d4ce3df150ca78d.png

给画布填充颜色时的效果和代码

//创建图像资源(空白画布)默认显示为黑色

$image = imagecreatetruecolor(300, 400);

//1.image //图像资源

//2.red: //红颜色(0-255) 或 0x(00-ff) //即十六进制来表示 (0xff就是255)

//3.green//绿颜色(0-255)

//4.blue //蓝颜色(0-255)

$color = imagecolorallocate($image, 255, 0, 0);

//1.image //图像资源

//2.x,y,填充的坐标点(注意:填充的与此点最接近的颜色)

//3.color; //用什么颜色来填充

imagefill($image, 0, 0, $color);

//输出图像

header('content-type:image/jpeg');

imagejpeg($image);

//销毁图像资源

imagedestroy($image);

?>

结果截图;

c183610493a19b69233edf375b5e4bd1.png

输出图像(以jpeg为例)

输出图像到浏览器

a)  header('content-type:image/jpeg'); //设置将图像通过浏览来查看

b)  imagejpeg(图像资源)

按文件进行输出图像

a)  imagejpeg(图像资源,'图像路径',图像的质量)    //质量取值0-100

b)  注意:

cd94e0ba87f7301653d7138281ff399e.png

注意:只能jpeg格式才有质量这个参数.

销毁图像

imagedestroy($image); //销毁图像,释放内存资源.

注意: 当前生成几个图像资源,就销毁几个.

验证码的整个代码:

//实例:让文本居于图像的正中

//创建图像资源(空白的画布)

$image = imagecreatetruecolor(100, 50);

$color = imagecolorallocate($image, mt_rand(20,200), mt_rand(20,200), mt_rand(20,200));

//为图像资源填充颜色

imagefill($image, 0, 0, $color);

//绘制图像

$font = 5;

//验证码的开始

$arr1 = range('a','z');

$arr3 = range('A','Z');

$arr2 = range(1,9);

//array_merge — 合并一个或多个数组

$arr = array_merge($arr1,$arr2,$arr3);

$index = array_rand($arr,5); //随机从原数组中找出5个下标

$string = '';

foreach ($index as $value) { //$value 两个功能,即是$index中的值,又是$arr中的下标

$string .= $arr[$value]; //将得到字符进行连接

}

//验证码的结束

//mt_rand — 生成更好的随机数

//echo mt_rand(1,5);die;

//加入点干扰

$pointcolor = imagecolorallocate($image, mt_rand(20,200), mt_rand(20,200), mt_rand(20,200));

//循环创建1000个干扰点

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

imagesetpixel($image, mt_rand(0,imagesx($image)), mt_rand(0,imagesy($image)), $pointcolor);

}

//加入线的干扰

$lintecolor = imagecolorallocate($image, mt_rand(20,200), mt_rand(20,200), mt_rand(20,200));

// 循环创建50个线干扰

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

imageline($image, mt_rand(0,imagesx($image)), mt_rand(0,imagesy($image)), mt_rand(0,imagesx($image)), mt_rand(0,imagesy($image)) ,$lintecolor);

}

//一个字符的宽度 imagefontwidth($font)

//字符串的个数: strlen(字符串)

//一个字符的宽度*字符串的个数

//所有字符串宽度和= 一个字符的宽度*字符串的个数

//$x = (画布的宽度-所有字符串宽度和)/2

$x = (imagesx($image)-imagefontwidth($font)*strlen($string))/2;

//$y = (画布的高度-字符的高度)/2;

//字符的高度: imagefontheight($font)

$y = (imagesy($image)-imagefontheight($font))/2;

$stringcolor = imagecolorallocate($image, mt_rand(20,200), mt_rand(20,200), mt_rand(20,200));

imagestring($image, $font, $x, $y, $string, $stringcolor);

//输出图像

header('content-type:image/jpeg'); //设置将图像通过浏览来查看

imagejpeg($image,'',100); //将图像资源输出

//销毁图像资源

imagedestroy($image); //销毁图像

理解代码中的一些函数

加入干扰的点

imagesetpixel(image, x, y, color)

说明:x,y 一个点的坐标

67d4ad7d4367cbe249d66b4a166ec87a.png

加入干扰的线

imageline(image, x1, y1, x2, y2, color)

说明: x1,y1是线的一个端点坐标; x2,y2是线的另一个端口的坐标; 由两点画一条线

92037e8944650e2e46c2621e6cb6a3c5.png

让验证码居于图像的正中

imagefontheight(font)获取字体的高度:

imagefontwidth(font)获取字体的宽度:

strlen(字符串)//获取字符串的长度

imagesx(image) //获取画布的宽度

imagesy(image) //获取画布的高度

9a9f789995031b115e5cf522778fe100.png

最后运行结果

5babc9c1975c668f4bff6a087645b231.png

再次完善(和html代码结合起来)

Html代码

52597e07cef5bffccae517fc2487d537.png

Document
请输入信息
姓名:
密码:
验证码21.php

理解;

79a1cef7e0f71c68613c5e1f331018ea.png

最后结果截图

f99dbdba3b0f32110c7f58aa31ba1b17.png

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持码农之家!

以上就是本次给大家分享的关于java的全部知识点内容总结,大家还可以在下方相关文章里找到相关文章进一步学习,感谢大家的阅读和支持。

您可能感兴趣的文章:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1.安装 上传源码到网站目录,设置网站目录为源码二级目录public,很多虚拟主机不支持此设置 伪静态,源码默认包含了apache的伪静态规则,但很多情况下还需要自己设置,请百度对应对应的设置方法,例如Nginx thinkphp5伪静态设置,如果您使用的宝塔,那么在网站伪静态里面设置一下即可。如果伪静态没有设置好,会出现资源文件找不到,图片脚本等都404等情况。 2.配置 由于前期准备写给自己用的,偷懒了很多情况,一些配置直接写在\application\config.php中,所有请打开文件修改配置 3.邮箱服务器配置,注册,找回密码,购卡等操作需要用到邮箱发信 请在配置文件中找到mail节点设置smtp服务器账号和密码 如 'mail' => [ 'server'=>'smtp.qq.com', 'acount' => '[email protected]', 'password' => '' 密码不是qq密码 ] 4.此版本更新安全,有用到openssl的rsa加密。需要配置openssl.cnf的路径,请在配置文件中修改 如:'opensslConf'=> 'D:\BtSoft\WebSoft\apache\conf\openssl.cnf' 此文件一般在你的apache配置文件夹中 5.支付,如果您想使用验证的自动发卡功能,官方默认支持两种对接方式 1.微信原生支付,需要签约商户,微信支付配置文件vendor/wxpay/WxPay.Config.php 绑定支付的APPIDGet AppId() 商户号 GetMerchantId()商户支付密钥 GetKey() 2.码支付,默认qq和支付宝使用码支付对接,需要挂监听软件,码支付官网https://codepay.fateqq.com/ 6.开启Workerman,这是一个socket库,这次的版本添加了websocket心跳方式,开启的好处是即时心跳,比如秒t下线,即时消息,群发消息,另外带个定时器,每个6分钟自动执行一次清理异常掉线未发退出登录通知服务器的用户,如果不开启,会出现很多麻烦,使用方法,双击打开源码目录下的start_for_win.bat,并保持cmd窗口打开,此功能仅在windows下测试过,linux大同小异主要执行php start_register.php start_gateway.php start_businessworker.php 如果正常运行您可以看到3个工作ok yzGateway Register yzBusinessWorker,可能出现的问题,找不到php命令,把php.exe加入到环境变量即可,如果使用websocket心跳的话,单机最大可能只有1000左右连接 7.必须开启openssl扩展 安装可能出现的问题 1.数据库连接不上,如果您确认数据库账号密码是正确的却连接不上,可以手动导入sql文件,文件路径/public/install/test.sql,导入成功后需要在application/database.php中配置您的库信息 2.安装时候环境监测有可能有点问题,不想整了,自己确定就行 遇到其它问题加群 365011408 提问即可 遇到返回数据未解密,用模块源码取调试 调用例子群文件获取,官网对接看这里 必须要开启Workerman 心跳处理,2种心跳方式,一种web定时心跳,一种socket主动发送

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值