ThinkPHP 验证码简单实现

ThinkPHP版本6.1,验证码功能是外置的,安装后通过简单的配置后即可使用,十分方便。

目录

1. 使用composer 安装 

2.开启session

3.验证码显示

4. 表单设置

5. 使用验证器检测

6. 使用助手函数验证

7.验证码配置文件修改

8.自定义验证器

总结


1. 使用composer 安装 

composer require topthink/think-captcha

 

2.开启session

全局中间件App/middleware.php

开启session

// 全局中间件定义文件
return [
    // 全局请求缓存
    // \think\middleware\CheckRequestCache::class,
    // 多语言加载
    // \think\middleware\LoadLangPack::class,
    // Session初始化
    \think\middleware\SessionInit::class
];

3.验证码显示

<div>{:captcha_img()}</div>

或者

<div>
<img src="{:captcha_src()}" alt="captcha"
 onclick='this.src="/captcha.html?"+Math.random();' />
</div>

4. 表单设置

创建一个模版页面,设置一个验证码和文本框提交比对;

<form action="{:url('admin/check')}" method="post">
    <div>{:captcha_img()}<input type="text" name="captcha"></div>
    <input type="hidden" name="__token__" value="{:token()}">
    <input type="submit" value="确定">
</form>

5. 使用验证器检测

// 验证码验证规则
$validate = Validate::rule([
    'captcha' => 'require|captcha'
]);
// 验证码和表单对比
$result = $validate->check([
    'captcha' => input('post.captcha')
]);
if (!$result) {
    dump($validate->getError());die;
}
dump('验证通过');die;

6. 使用助手函数验证

if(!captcha_check(input('post.captcha'))){
    dump('验证失败');die;
}
dump('验证通过');die;

7.验证码配置文件修改

验证码的配置文件位于config/captcha.php中,可按需修改。

修改字符为4个

/验证码位数
'length'   => 4,

 

改为中文验证码

// 是否使用中文验证码
'useZh'    => true,

 

8.自定义验证器

创建一个 verify 方法

namespace app\admin\controller;


use think\captcha\facade\Captcha;

class AdminCaptcha
{
    public function verify()
    {
        return Captcha::create();
    }
}

添加路由验证

Route::get('captcha', 'AdminCaptcha/verify)->name('captcha');

访问路由

效果

添加额外的验证码设置

Config/captcha.php中间添加

// 添加额外的验证码设置
 'verify' => [
     'length'   =>  4,
     'math'     => true,
],

方法添加配置

public function verify()
{
    return Captcha::create('verify');
}

 效果

总结

主要通过composer安装think-captcha三方封装的验证码来实现。

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
可以通过使用第三方短信平台的 API 来发送短信验证码。以下是一个使用阿里云短信服务的示例代码: ```php // 引入阿里云 SDK require_once __DIR__ . '/aliyun-php-sdk-core/Config.php'; use Aliyun\Core\Config; use Aliyun\Core\DefaultAcsClient; use Aliyun\Core\Profile\DefaultProfile; use Aliyun\Api\Sms\Request\V20170525\SendSmsRequest; // 配置信息 Config::load(); $accessKeyId = 'your_access_key_id'; $accessKeySecret = 'your_access_key_secret'; $signName = 'your_sign_name'; // 签名名称 $templateCode = 'your_template_code'; // 模板CODE // 发送短信验证码 $mobile = 'your_mobile_number'; $code = rand(100000, 999999); // 生成随机验证码 $paramString = '{"code":"' . $code . '"}'; // 短信模板参数 $profile = DefaultProfile::getProfile('cn-hangzhou', $accessKeyId, $accessKeySecret); $acsClient = new DefaultAcsClient($profile); $request = new SendSmsRequest(); $request->setPhoneNumbers($mobile); $request->setSignName($signName); $request->setTemplateCode($templateCode); $request->setTemplateParam($paramString); $response = $acsClient->getAcsResponse($request); // 处理响应结果 if ($response->Code == 'OK') { // 发送成功,将验证码存储到 session 或缓存中 session('sms_code', $code); echo '验证码已发送,请注意查收'; } else { echo '发送失败:' . $response->Message; } ``` 需要注意的是,上述代码中的 `your_access_key_id`、`your_access_key_secret`、`your_sign_name`、`your_template_code` 和 `your_mobile_number` 都需要根据实际情况进行替换。同时,由于阿里云 SDK 并不包含在 ThinkPHP 中,需要手动下载并添加到项目中。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

JSON_L

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值