今天看啥  ›  专栏  ›  码农UP2U

TP5 使用验证码功能

码农UP2U  · 简书  ·  · 2019-10-26 21:20

工作中后台开发使用的是 TP5,但是对语法不是很熟悉,总是看着手册写代码。当时做 Java 的时候也是这样,很多语法需要靠百度。不是不能写代码,但是这样的效率感觉不高,没有行云流水的感觉,要是能有聊天时打字的感觉就好多了。不熟悉就得多学习,但是学完经常就忘记了,所以博客就当是记录了。

TP5的验证码在 /vendor/topthink/think-captcha 目录下,文件分别是 Captcha.php 、CaptchaController.php 和 helper.php 三个文件。可以直接通过 http://localhost/ 项目名称/public/index.php/captcha 来进行访问。

1、在页面上显示验证码

插入一个 img 的 html 标签:

<img src="/public/index.php/captcha" alt="点击更新验证码" onclick="reloadcode(this);"/>

2、点击验证码图片时更新验证码

插入一段 js 代码:

// 刷新验证码
function reloadcode(obj) {
    obj.src = '/public/index.php/captcha?id=' + Math.random();
}

3、验证码显示大小的设置

在 /application/config.php 文件的末尾增加配置如下:

'captcha'   => [
    'imageH'    => 50,
    'imageW'    => 200,
],

4、判断验证码

登录时将数据提交的地址,代码如下:

<form class="form form-horizontal" action="{:url('login/check')}" method="post">

5、判断验证码

判断验证码是否正确,在提交的 Controller 中增加对应的判断代码:

public function check()
{
    $data = input('post.');
    if (!captcha_check($data['code'])) {
        $this->error('验证码不正确');
    } else {
        $this->success('OK');
    }
}

TP5 验证码的详细说明地址: https://www.kancloud.cn/manual/thinkphp5/154295



我的微信公众号:“码农UP2U”
我的公众号




原文地址:访问原文地址
快照地址: 访问文章快照