万能php验证码类,供大家参考,具体内容如下

code.php是验证码类,类的名称最好和文件名的名称一样,这样有利于我们的查看。
code.php
<?php
header('Content-type:text/html;charset=utf8');
class Code{
// 验证码个数$number
protected $number;
// 验证码类型$codeType
protected $codeType;
// 验证码图像宽度$width
protected $width;
// 验证码$height
protected $height;
// 验证码字符串$code
protected $code;
// 图像资源$image
protected $image;
public function __construct($number=4,$codeType=0,$height=50,$width=100){
//初始化自己的成员属性
$this->number=$number;
$this->codeType=$codeType;
$this->width = $width;
$this->height= $height;
//生成验证码函数
$this->code = $this ->createCode();
}
public function __get($name){
if ($name == 'code'){
return $this->code;
}
return false;
}
/*获取验证码*/
public function getCode() {
return $this->code;
}
/*图像资源销毁*/
public function __destruct(){
imagedestroy($this->image);
}
protected function createCode(){
//通过你的验证码类型生成验证码
switch ($this->codeType){
case 0: //纯数字
$code = $this->getNumberCode();
break;
case 1: //纯字母的
$code = $this->getCharCode();
break;
case 2: //数字和字母混合
$code = $this->getNumCharCode();
break;
default:
die('不支持此类验证码类型');
}
return $code;
}
protected function getNumberCode(){
$str = join('', range(0, 9));
return substr(str_shuffle($str),0, $this->number);
}
protected function getCharCode(){
$str = join('', range('a', 'z'));
$str = $str.strtoupper($str);
return substr(str_shuffle($str),0,$this->number);
}
protected function getNumCharCode(){
$numstr = join('',range(0, 9));
$str =join('', range('a', 'z'));
$str =$numstr.$str.strtoupper($str);
return substr(str_shuffle($str), 0,$this->number);
}
protected function createImage(){
$this->image = imagecreatetruecolor($this->width,
$this->height);
}
protected function fillBack(){
imagefill($this->image, 0, 0, $this->lightColor());
}
/*浅色*/
protected function lightColor(){
return imagecolorallocate($this->image, mt_rand(133,255), mt_rand(133,255), mt_rand(133,255));
}
/*深色*/
protected function darkColor(){
return imagecolorallocate($this->image, mt_rand(0,120), mt_rand(0,120), mt_rand(0,120));
}
protected function drawChar(){
$width = ceil($this->width / $this->number);
for ($i=0; $i< $this->number;$i++){
$x = mt_rand($i*$width+5, ($i+1)*$width-10);
$y = mt_rand(0, $this->height -15);
imagechar($this->image, 5, $x, $y, $this->code[$i], $this->darkColor());
}
}
protected function drawLine(){
for ($i=0;$i<5;$i++) {
imageline($this->image,mt_rand(0,$this->width),mt_rand(0,$this->height),mt_rand(0,$this->width),mt_rand(0,$this->height),$this->darkColor());
}
}
protected function drawDisturb(){
for ($i=0;$i<150;$i++){
$x=mt_rand(0, $this->width);
$y=mt_rand(0, $this->height);
imagesetpixel($this->image, $x, $y, $this->lightColor());
}
}
protected function show(){
header('Content-Type:image/png');
imagepng($this->image);
}
public function outImage(){
// 创建画布
$this->createImage();
// 填充背景色
$this->fillBack();
// 将验证码字符串花到画布上
$this->drawChar();
// 添加干扰元素
$this->drawDisturb();
// 添加线条
$this->drawLine();
// 输出并显示
$this->show();
}
}
test.php是new一个新的验证码,并把它保存到session中,为我们验证码的验证起到保存和存储的作用。
test.php
<?php //开启session session_start(); require_once 'code.php'; $code= new Code(4,1,50,100); $_SESSION['code']= $code->getCode(); $code->outImage();
login.php就是最后的验证。
login.php
<?php
//开启Session
session_start();
//判断是否提交
if(isset($_POST['dosubmit'])){
//获取session中的验证码并转为小写
$sessionCode=strtolower($_SESSION['code']);
//获取输入的验证码
$code=strtolower($_POST['code']);
//判断是否相等
if($sessionCode==$code){
echo "<script type='text/javascript'>alert('验证码正确!');</script>";
}else{
echo "<script type='text/javascript'>alert('验证码错误!');</script>";
}
}
?>
<!DOCTYPE html>
<html>
<head>
<title></title>
<meta http-equiv="Content-Type" content="text/html;charset=UTF-8"/>
<style type="text/css">
*{margin:0px;padding:0px;}
ul{
width:400px;
list-style:none;
margin:50px auto;
}
li{
padding:12px;
position:relative;
}
label{
width:80px;
display:inline-block;
float:left;
line-height:30px;
}
input[type='text'],input[type='password']{
height:30px;
}
img{
margin-left:10px;
}
input[type="submit"]{
margin-left:80px;
padding:5px 10px;
}
</style>
</head>
<body>
<form action="login.php" method="post">
<ul>
<li>
<label>用户名:</label>
<input type="text" name="username"/>
</li>
<li>
<label>密码:</label>
<input type="password" name="password"/>
</li>
<li>
<label>验证码:</label>
<input type="text" name="code" size="4" style="float:left"/>
<img src="test.php" onclick="this.src='test.php?Math.random()'"/>
</li>
<li>
<input type="submit" value="登录" name="dosubmit"/>
</li>
</ul>
</form>
</body>
</html>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# php
# 验证码类
# 个人写的PHP验证码生成类分享
# 一个漂亮的php验证码类(分享)
# PHP验证码类代码( 最新修改
# 完全定制化! )
# 一个经典的PHP验证码类分享
# 一个好用的PHP验证码类实例分享
# 一个PHP验证码类代码分享(已封装成类)
# PHP实现的封装验证码类详解
# PHP使用GIFEncoder类生成的GIF动态图片验证码
# 一个简单安全的PHP验证码类、PHP验证码
# 分享一个漂亮的php验证码类
# PHP验证码类ValidateCode解析
# PHP code 验证码生成类定义和简单使用示例
# 验证码
# 自己的
# 判断是否
# 把它
# 此类
# 不支持
# 具体内容
# 大家多多
# 背景色
# 验证码错误
# substr
# range
# join
# strtoupper
# str_shuffle
# getCharCode
# str
# break
# die
# default
相关文章:
怀化网站制作公司,怀化新生儿上户网上办理流程?
如何高效生成建站之星成品网站源码?
如何通过多用户协作模板快速搭建高效企业网站?
网站按钮制作软件,如何实现网页中按钮的自动点击?
如何选择美橙互联多站合一建站方案?
建站之星如何防范黑客攻击与数据泄露?
广州营销型建站服务商推荐:技术优势与SEO优化解析
微信小程序 input输入框控件详解及实例(多种示例)
简历在线制作网站免费,免费下载个人简历的网站是哪些?
成都品牌网站制作公司,成都营业执照年报网上怎么办理?
实例解析angularjs的filter过滤器
,南京靠谱的征婚网站?
建站主机如何选?高性价比方案全解析
如何在IIS管理器中快速创建并配置网站?
Python文件管理规范_工程实践说明【指导】
教育培训网站制作流程,请问edu教育网站的域名怎么申请?
如何制作一个表白网站视频,关于勇敢表白的小标题?
如何在Windows环境下新建FTP站点并设置权限?
完全自定义免费建站平台:主题模板在线生成一站式服务
如何零基础在云服务器搭建WordPress站点?
宝塔建站无法访问?如何排查配置与端口问题?
北京网站制作网页,网站升级改版需要多久?
如何确认建站备案号应放置的具体位置?
c# 在ASP.NET Core中管理和取消后台任务
电影网站制作价格表,那些提供免费电影的网站,他们是怎么盈利的?
建站之星如何实现网站加密操作?
建站之星如何快速解决建站难题?
如何配置WinSCP新建站点的密钥验证步骤?
如何在Golang中指定模块版本_使用go.mod控制版本号
如何使用Golang table-driven基准测试_多组数据测量函数效率
东莞专业制作网站的公司,东莞大学生网的网址是什么?
中山网站制作网页,中山新生登记系统登记流程?
盘锦网站制作公司,盘锦大洼有多少5G网站?
如何选择最佳自助建站系统?快速指南解析优劣
大连 网站制作,大连天途有线官网?
网站制作公司广州有几家,广州尚艺美发学校网站是多少?
建站主机选购指南:核心配置优化与品牌推荐方案
建站之星收费标准详解:套餐费用及年费价格表一览
网站制作模板下载什么软件,ppt模板免费下载网站?
如何选择高效可靠的多用户建站源码资源?
详解一款开源免费的.NET文档操作组件DocX(.NET组件介绍之一)
青岛网站设计制作公司,查询青岛招聘信息的网站有哪些?
如何快速生成橙子建站落地页链接?
如何零成本快速生成个人自助网站?
制作网站怎么制作,*游戏网站怎么搭建?
建站主机数据库如何配置才能提升网站性能?
如何将凡科建站内容保存为本地文件?
如何用西部建站助手快速创建专业网站?
建站之星IIS配置教程:代码生成技巧与站点搭建指南
建站之星与建站宝盒如何选择最佳方案?
*请认真填写需求信息,我们会在24小时内与您取得联系。