php_mvc实现步骤九(登录验证码,退出-登录标记)
shop34-17-登录验证码
验证码的分析
登录:防止暴力破解
论坛:防止灌水水
展示类:被抓取。

需要技术:
图片处理技术。
会话session技术。
PHP图片处理技术 – GD
具体操作步骤
开启GD扩展

Apache restart
场景:
制作500×300的绿色图片
创建画布
画布,一种资源型数据。可以操作的图像资源。
创建新画布(新建)
ImageCreate(宽,高),创建基于调色板的画布。
imageCreateTrueColor(宽,高);创建真彩色的画布。
基于图片创建画布(打开)
imageCreateFromJPEG(图片地址);
imageCreateFromPNG(图片地址);
imageCreateFromGIF(图片地址);

操作画布
分配颜色:如果需要在画布上使用某个颜色,应该先将颜色分配到画布上。
使用函数:
颜色标识 = imageColorAllocate(画布,R,G,B);
颜色的表示方式:
RGB

填充画布:将填充点,连续并且颜色相同的点进行填充(替换)
使用函数:
imageFill(画布, 填充位置x, 填充位置Y,颜色标识)完成
位置采用坐标进行管理:
原点:0,0,画布的左上角。
向右,x轴增加,向下Y轴增加。
右下角坐标:width-1,height-1

输出画布
将画布中处理好的图样信息,输出出来。
典型的:
1输出到图片文件。
2直接输出。
使用函数:
imagePNG(画布[, 文件地址]):
imageJPEG();
imageGIF();
如果没有第二个参数,表示直接输出。


如果直接输出到浏览器,需要告知浏览器,响应数据的类型应该是PNG格式的图片:
使用指令Content-type
tip:一个画布可以输出多次,输出为各种格式!
销毁画布资源
imageDestroy();

项目中实现验证码
验证码工具类
Framework/tool/Captcha.class.php

自动加载:

生成验证码图片:

Session开启重复避免:

背景图位置:


登录表单时展示
在登录表单页面,通过IMG标签,请求生成图片的URL地址,展示图片。
<img src=”URL” />

增加一个动作,用于完成生成后台登录界面的验证码图片:
Back/AdminController->captchaAction();

页面的img标签的src属性,请求该动作:

Tip:如果图片显示失败,如何调试?
应该直接请求生成图片的地址,而不是在img标签中查看。
我的程序,应该将captchaAction()也列为登入认证例外:
后台的平台控制器:

结果:

点击更换:
通过点击事件,对生产验证码图片的地址重新请求,形成新的验证码,进行展示!
如果img标签的src属性被更改,则浏览器会对新的url进行请求,展示在img图片区域内。

验证管理员信息前验证
在验证管理员信息的合法性前,对验证码作出验证:
Back/AdminController->checkAction();
增加验证码工具类Captcha的方法
checkCaptcha()

Back/AdminController->checkAction();
利用上面的方法完成验证:

tip:图片程序错误解析
step1: 请求生成图片的URL
语法错误:

逻辑错误:

此时,如果出现语法错误,页面会有相应的提示。
但是没有语法错误,就如上面的结果,提示图片内部错误无法显示:
Step2:将header(‘Content-Type:image/jpeg’)注释


解决即可!
图片不能展示的原因:额外输出

BOM:utf-8编码文件的签名,三个字节的隐藏字符。也是输出的!
shop34-18-退出-登录标志
退出
销毁登录标志,
Session中存储的is_login
控制器-动作

修改top模板,请求到退出动作:

登录标志
通常还具有存储当前登录用户(管理员)信息的功能!
在 存储登录标志时,获取当前管理员信息,存储到session中:
Back/AdminController->checkAction();

需要back/AdminModel->check()方法,返回的为管理员信息(合法情况下):

在back/PlatformController->_checkLogin()中验证管理员是否登录时,使用admin下标:

退出时,销毁的也是该标志:
Back/AdminController->logoutAction();

页面上可以获取管理员信息:
Back/top.html中,显示:你好 管理员!

php_mvc实现步骤九(登录验证码,退出-登录标记)的更多相关文章
- PHP 用户登录与退出
PHP 用户登录与退出 登录页面 login.html 负责收集用户填写的登录信息. <fieldset> <legend>用户登录</legend> <fo ...
- 【招聘App】—— React/Nodejs/MongoDB全栈项目:个人中心&退出登录
前言:最近在学习Redux+react+Router+Nodejs全栈开发高级课程,这里对实践过程作个记录,方便自己和大家翻阅.最终成果github地址:https://github.com/66We ...
- 清除@SessionAttributes 网站实现退出登录
在网站实现登录时,我认识了@SessionAttributes,对我来说是真的好用,@SessionAttributes注解可以使得模型中的数据存储一份到session域中. 这样在页面跳转时可以直接 ...
- Python+fiddler(基于Cookie绕过验证码自动登录)
案例:使用Cookie绕过百度验证码自动登录账户 步骤: 1.浏览器进入百度首页,点击登录按钮,输入相关信息(注意:暂时不要点击登录按钮) 2.进入fiddler,首先获取证书,Tools--> ...
- 织梦DedeCMS会员登录或退出后如何直接跳转到首页
织梦dedecms默认情况下的会员登录后会直接跳转到会员中心,退出也是一样,但是如果我们想让会员登录后直接跳转到首页,那该如何实现呢? 经过我们的研究,已经找到解决办法,下面是详细的修改步骤: 首先在 ...
- Java中SSM+Shiro系统登录验证码的实现方法
1.验证码生成类: import java.util.Random; import java.awt.image.BufferedImage; import java.awt.Graphics; im ...
- spring boot:spring security给用户登录增加自动登录及图形验证码功能(spring boot 2.3.1)
一,图形验证码的用途? 1,什么是图形验证码? 验证码(CAPTCHA)是"Completely Automated Public Turing test to tell Computers ...
- Vue Springboot (包括后端解决跨域)实现登录验证码功能详细完整版
利用Hutool 基于Vue.ElementUI.Springboot (跨域)实现登录验证码功能 前言 一.Hutool是什么? 二.下面开始步入正题:使用步骤 1.先引入Hutool依赖 2.控制 ...
- SpringBoot开发十-开发登录,退出功能
需求介绍-开发登录,退出功能 访问登录页面:点击头部区域的链接打开登录页面 登录: 验证账号,密码,验证码 成功时生成登录凭证发放给客户端,失败时跳转回登录页面 退出: 将登录状态修改为失效的状态 跳 ...
随机推荐
- Java——CaptchaUtil生成二维码乱码
前言 这个问题就是因为Linux上没有字体,你可以有两种方法,一个在生成的时候设置字体,一个就是安装字体. 默认的字体为Courier 乱码情况 步骤 安装字体工具 yum install -y fo ...
- C++中的类所占内存空间总结(转)
类所占内存的大小是由成员变量(静态变量除外)决定的,成员函数(这是笼统的说,后面会细说)是不计算在内的. 摘抄部分: 成员函数还是以一般的函数一样的存在.a.fun()是通过fun(a.this)来调 ...
- Wideband Direction of Arrival Estimation Based on Multiple Virtual Extension Arrays
基于多重虚拟扩展阵列的宽带信号DOA估计[1]. 宽带DOA估计是阵列信号处理领域的一个重要研究方向.在DOAs估计的实际应用中,信号总是会被噪声破坏,在某些情况下,源信号的数量大于传感器的数量,因此 ...
- LeetCode 845. Longest Mountain in Array
原题链接在这里:https://leetcode.com/problems/longest-mountain-in-array/ 题目: Let's call any (contiguous) sub ...
- learning armbian steps(11) ----- armbian 源码分析(六)
接下来我们来分析一下uboot的编写过程: 从 lib/compilation.sh 89开始阅读: compile_uboot() { # not optimal, but extra clean ...
- 数组(定义、遍历、冒泡排序、合并和Join 方法)
一.数组的定义 1.理解:数组指一组数据,有序的数据,可以一次性存储多个数据,将多个元素(通常统一类型)按照一定的顺序排列放到一个集合里 2.通过构造函数创建数组: var 数组名=new Arrar ...
- 19-ESP8266 SDK开发基础入门篇--C# TCP客户端编写 , 连接和断开
https://www.cnblogs.com/yangfengwu/p/11130428.html 渐渐的看过去,,,好多节了... 这节做一个C# TCP客户端 新建项目啥子的就不详细截图写了,自 ...
- 洛谷 P1432 倒水问题
目录 题目 思路 \(Code\) 题目 戳 思路 \(bfs\) 第一遍提交\(50\),第二遍就\(100\)了,qwq \(Code\) #include<iostream> #in ...
- 阿里云部署自己的web服务器
阿里云部署自己的web服务器 [外链图片转存失败(img-GIKNTPPx-1564287221547)(https://upload-images.jianshu.io/upload_images/ ...
- VSCode 本地如何查看历史页面
1.首先要在VSCode的扩展中安装一个 Local history插件,蓝色框部分不用管,直接安装即可 2.安装并操作:安装后,修改 productManage/supplierList/addSu ...