当前位置: 首页 > news >正文

做移动网站快速排名/淄博seo培训

做移动网站快速排名,淄博seo培训,网站动画效果怎么做,ai可以用来做网站吗项目简介:本课程通过使用 PHP 及 Web 前端技术实现一个网站注册登录入口页面,学习并实践 PHP 编程,GD库,MySQL 扩展,Bootstrap 响应式布局,Cookie/Session 及 Ajax 等知识点。本项目发布在实验楼&#xff0…

项目简介:本课程通过使用 PHP 及 Web 前端技术实现一个网站注册登录入口页面,学习并实践 PHP 编程,GD库,MySQL 扩展,Bootstrap 响应式布局,Cookie/Session 及 Ajax 等知识点。
本项目发布在实验楼,分为四部分内容:1前端页面制作,2验证码制作,3实现注册登陆,4功能完善。本节实验内容为第二部分验证码制作部分。

全部章节及代码详解可以在实验楼中在线完成:PHP 实现用户注册登录功能

验证码制作

一、实验简介

本次实验将会带领大家使用面向对象的思想封装一个验证码类。并在注册和登陆界面展示使用。通过本次实验的学习,你将会领悟到 PHP 的 OOP 思想,以及 GD 库的使用,验证码生成。

1.1 涉及到的知识点

  • PHP

  • GD库

  • OOP编程

1.2 开发工具

  • sublime,一个方便快速的文本编辑器。点击桌面左下角: 应用程序菜单/开发/sublime

1.3 效果图

验证码1

验证码

二、封装验证码类

2.1 建立目录以及准备字体

在 web 目录下建立一个 admin 目录作为我们的后台目录,存放后台代码文件。在 admin 下建立一个 fonts 目录,用于存放制作验证码所需字体。

在 admin 下新建一个 Captcha.php 文件,这就是我们需要编辑的验证码类文件。

当前目录层次结构:

此处输入图片的描述

编辑 Captcha.php 文件:

<?php 
/**
* Captcha class
*/
class Captcha
{function __construct(){# code...}
}

添加该类的私有属性和构造方法:

<?php 
/**
* Captcha class
*/
class Captcha
{private $codeNum;    //验证码位数private $width;    //验证码图片宽度private $height;    //验证码图片高度private $img;    //图像资源句柄private $lineFlag;    //是否生成干扰线条private $piexFlag;    //是否生成干扰点private $fontSize;    //字体大小private $code;    //验证码字符private $string;    //生成验证码的字符集private $font;    //字体function __construct($codeNum = 4,$height = 50,$width = 150,$fontSize = 20,$lineFlag = true,$piexFlag = true){$this->string = 'qwertyupmkjnhbgvfcdsxa123456789';    //去除一些相近的字符$this->codeNum = $codeNum;$this->height = $height;$this->width = $width;$this->lineFlag = $lineFlag;$this->piexFlag = $piexFlag;$this->font = dirname(__FILE__).'/fonts/consola.ttf';$this->fontSize = $fontSize;}
}

字体文件可通过以下命令下载到 fonts 目录:

$ wget http://labfile.oss.aliyuncs.com/courses/587/consola.ttf

接下来开始编写具体的方法:

  • 创建图像资源句柄

    //创建图像资源    
    public function createImage(){$this->img = imagecreate($this->width, $this->height);    //创建图像资源imagecolorallocate($this->img,mt_rand(0,100),mt_rand(0,100),mt_rand(0,100));    //填充图像背景(使用浅色)}

用到的相关函数

  • imagecreate:新建一个基于调色板的图像

  • imagecolorallocate:为一幅图像分配颜色

  • mt_rand:生成更好的随机数

  • 创建验证码字符串并输出到图像

    //创建验证码    
    public function createCode(){$strlen = strlen($this->string)-1;for ($i=0; $i < $this->codeNum; $i++) { $this->code .= $this->string[mt_rand(0,$strlen)];    //从字符集中随机取出四个字符拼接}$_SESSION['code'] = $this->code;    //加入 session 中//计算每个字符间距$diff = $this->width/$this->codeNum;for ($i=0; $i < $this->codeNum; $i++) { //为每个字符生成颜色(使用深色)$txtColor = imagecolorallocate($this->img,mt_rand(100,255),mt_rand(100,255),mt_rand(100,255));//写入图像imagettftext($this->img, $this->fontSize, mt_rand(-30,30), $diff*$i+mt_rand(3,8), mt_rand(20,$this->height-10), $txtColor, $this->font, $this->code[$i]);}}

用到的相关函数:

  • imagettftext:用 TrueType 字体向图像写入文本

  • 创建干扰线条

    //创建干扰线条(默认四条)
    public function createLines(){for ($i=0; $i < 4; $i++) { $color = imagecolorallocate($this->img,mt_rand(0,155),mt_rand(0,155),mt_rand(0,155));    //使用浅色imageline($this->img,mt_rand(0,$this->width),mt_rand(0,$this->height),mt_rand(0,$this->width),mt_rand(0,$this->height),$color); }}

用到的相关函数:

  • imageline:画一条线段

  • 创建干扰点

    //创建干扰点    (默认一百个点)
    public function createPiex(){for ($i=0; $i < 100; $i++) { $color = imagecolorallocate($this->img,mt_rand(0,255),mt_rand(0,255),mt_rand(0,255));imagesetpixel($this->img,mt_rand(0,$this->width),mt_rand(0,$this->height),$color);}}

使用的相关函数:

  • imagesetpixel:画一个单一像素

  • 对外输出图像:

        public function show(){$this->createImage();$this->createCode();if ($this->lineFlag) {    //是否创建干扰线条$this->createLines();}if ($this->piexFlag) {    //是否创建干扰点$this->createPiex();}header('Content-type:image/png');    //请求页面的内容是png格式的图像imagepng($this->img);    //以png格式输出图像imagedestroy($this->img);    //清除图像资源,释放内存}

用到的相关函数:

  • imagepng:以 PNG 格式将图像输出到浏览器或文件

  • imagedestroy:销毁一图像

  • 对外提供验证码:

    public function getCode(){return $this->code;}

完整代码如下:

<?php 
/**
* Captcha class
*/
class Captcha
{private $codeNum;private $width;private $height;private $img;private $lineFlag;private $piexFlag;private $fontSize;private $code;private $string;private $font;function __construct($codeNum = 4,$height = 50,$width = 150,$fontSize = 20,$lineFlag = true,$piexFlag = true){$this->string = 'qwertyupmkjnhbgvfcdsxa123456789';$this->codeNum = $codeNum;$this->height = $height;$this->width = $width;$this->lineFlag = $lineFlag;$this->piexFlag = $piexFlag;$this->font = dirname(__FILE__).'/fonts/consola.ttf';$this->fontSize = $fontSize;}public function createImage(){$this->img = imagecreate($this->width, $this->height);imagecolorallocate($this->img,mt_rand(0,100),mt_rand(0,100),mt_rand(0,100));}public function createCode(){$strlen = strlen($this->string)-1;for ($i=0; $i < $this->codeNum; $i++) { $this->code .= $this->string[mt_rand(0,$strlen)];}$_SESSION['code'] = $this->code;$diff = $this->width/$this->codeNum;for ($i=0; $i < $this->codeNum; $i++) { $txtColor = imagecolorallocate($this->img,mt_rand(100,255),mt_rand(100,255),mt_rand(100,255));imagettftext($this->img, $this->fontSize, mt_rand(-30,30), $diff*$i+mt_rand(3,8), mt_rand(20,$this->height-10), $txtColor, $this->font, $this->code[$i]);}}public function createLines(){for ($i=0; $i < 4; $i++) { $color = imagecolorallocate($this->img,mt_rand(0,155),mt_rand(0,155),mt_rand(0,155));imageline($this->img,mt_rand(0,$this->width),mt_rand(0,$this->height),mt_rand(0,$this->width),mt_rand(0,$this->height),$color); }}public function createPiexs(){for ($i=0; $i < 100; $i++) { $color = imagecolorallocate($this->img,mt_rand(0,255),mt_rand(0,255),mt_rand(0,255));imagesetpixel($this->img,mt_rand(0,$this->width),mt_rand(0,$this->height),$color);}}public function show(){$this->createImage();$this->createCode();if ($this->lineFlag) {$this->createLines();}if ($this->piexFlag) {$this->createPiexs();}header('Content-type:image/png');imagepng($this->img);imagedestroy($this->img);}public function getCode(){return $this->code;}
}

以上就是验证码类的全部代码。看起来确实挺简单的,不过用的图像处理函数比较多,上面相关的函数我也做了必要的链接和用途说明。这些函数也不用死记硬背,遇到不清楚的,随时查阅 PHP 官方文档,最重要的是还有中文文档。

2.2 使用验证码

既然已经封装完毕,那就可以开始使用了。这里为了方便,直接在 Captcha 类的下方调用该类:

session_start(); //开启session
$captcha = new Captcha();    //实例化验证码类(可自定义参数)
$captcha->show();    //调用输出

三、前端展示

后端已经准备好了验证码,前端界面就可以展示了,修改 index.php 中的注册与登陆表单的验证码部分:

<div class="form-group"><div class="col-sm-12"><img src="admin/Captcha.php" alt="" id="codeimg" onclick="javascript:this.src = 'admin/Captcha.php?'+Math.random();"><span>Click to Switch</span></div>
</div>

img 标签添加了点击事件的 js 代码,这样就可以实现点击更换验证码的功能!

效果图:

效果图

四、完善

到目前为止,我们的验证码模块基本就完成了。学习到这里,大家应该对面向对象编程有了进一步的理解。也领悟到了一丝 OOP 思想。OOP 的三大特征:封装,继承,多态。我们这里只用到了一点封装的思想。大家可以继续完善和改进这个验证码类,设计出更加完美的类。这个实验也告诉我们,PHP 的函数很多,不要死记硬背,多看官方文档。

本项目完整教程和代码详解可以在实验楼查看。
更多PHP经典项目:PHP全部-课程

图片描述

http://www.lbrq.cn/news/1106299.html

相关文章:

  • 平台开发者/北京seo平台
  • 网站的反链怎么做/雅虎日本新闻
  • asp动态网站开发/营销课程培训
  • 做除尘环保的如何推广自己的网站/游戏广告投放平台
  • 到国外网站上做兼职翻译/手机优化大师
  • 长沙优化网站/优化关键词排名优化公司
  • 网站主页 优帮云/经典软文范例大全
  • 网站建站价格/站长工具精品
  • 上海建设工程质监站网站/网上营销推广
  • 网站站内内链建设/网络营销方案策划书
  • 建筑网cbi/优就业seo怎么样
  • 个人建站除了wordpress/商旅平台app下载
  • 腾讯云服务器centos做静态网站/国内搜索引擎排名2022
  • 常用网络营销方法举例/大连百度关键词优化
  • 大连在哪个网站做网上核名/关键词
  • 百度站长平台工具/做网络优化哪家公司比较好
  • 如何在网站上做qq群链接/网络营销好不好
  • 免费网页制作网站/优化服务平台
  • mangeto和wordpress/seo公司优化方案
  • 无锡做网站、/谷歌官网
  • 企业网站建设方案详细方案/线上教育培训机构十大排名
  • 美澳居的网站谁做的/湖北网站seo设计
  • 牡丹江信息网手机版招聘/百度seo关键词排名查询
  • 校园加盟网站建设/青岛百度网站排名
  • 购物网站开发总结报告/单页网站
  • wordpress爱视频/襄阳seo优化排名
  • 网站标题怎么做/全网营销型网站
  • 我想做个网站怎么弄/市场调研数据网站
  • 网上哪个网站教做西点/银川seo优化
  • 深圳哪几个区最繁华/上海搜索引擎优化1
  • 让Logo/文字“自己画自己”!✨
  • Python高级数据类型:字典(Dictionary)
  • 数字化转型:概念性名词浅谈(第三十一讲)
  • 20250718-5-Kubernetes 调度-Pod对象:重启策略+健康检查_笔记
  • MC0457符咒封印
  • 游戏盾能否保护业务免受DDoS攻击吗?