注:由于thinkphp5.1没有自带验证码,所以需要通过composer安装think-captcha 扩展包才能实现验证码
一、安装composer
https://www.zzvips.com/article/194579.html
二、通过composer安装think-captcha 扩展包
打开命令窗口,进入vendor/topthink输入指令即可,也可以安装shift键再右击鼠标打开命令窗口可以直接进入当前文件夹位置
1
|
composer require topthink/think-captcha |
三、在控制器里写验证码的方法,要在命名空间引入use think\captcha\Captcha;然后在网址中输入该方法的路由地址就可以出来验证码
1
2
3
4
5
6
|
//验证码 public function verify() { $captcha = new Captcha(); return $captcha ->entry(); } |
四、验证码在模板中输出
在视图中加入以下代码:
1
|
< img src = "{:url('user/verify')}" alt = "captcha" /> |
src里填写verify方法的路由地址
五、验证输入的验证码是否正确
1、可以用 Captcha 类的 check 方法检测验证码的输入是否正确
1
2
3
4
5
6
|
// 检测输入的验证码是否正确,$value为用户输入的验证码字符串 $captcha = new Captcha(); if ( ! $captcha ->check( $value )) { // 验证失败 } |
2、或者直接调用封装的一个验证码检测的函数 captcha_check
1
2
3
4
5
|
/ 检测输入的验证码是否正确, $value 为用户输入的验证码字符串 if ( !captcha_check( $value )) { // 验证失败 } |
六、自定义验证码的参数
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
//验证码 public function verify() { $config = [ // 验证码字体大小 'fontSize' => 30, // 验证码位数 'length' => 4, // 关闭验证码杂点 'useNoise' => true, // 验证码图片高度 'imageH' => 60, // 验证码图片宽度 'imageW' => 200, // 验证码过期时间(s) 'expire' => 1800, ]; $captcha = new Captcha( $config ); return $captcha ->entry(); } |
在vendor\topthink\think-captcha\src目录下的Captcha.php中也可以配置
七、以下是我测试登录的代码部分截图
控制器里的verify()方法
控制器里的验证登录的loginCheck()方法
视图层里的验证码显示
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:https://blog.csdn.net/John_rush/article/details/80169702