首頁  >  文章  >  後端開發  >  TP6驗證碼驗證失敗的原因以及解決方法

TP6驗證碼驗證失敗的原因以及解決方法

silencement
silencement轉載
2020-01-26 22:16:165232瀏覽

TP6驗證碼驗證失敗的原因以及解決方法

首先使用Composer安裝think-captcha擴充套件:

composer require topthink/think-captcha

控制器引入

use think\captcha\facade\Captcha;
產生驗證碼
public function verify()
{
    return Captcha::create();
}

#驗證驗證碼

if( !Captcha::check($vercode)) {
    return json(['code'=>1001, 'msg'=>'验证码错误');
}

check的方法

/**
 * 验证验证码是否正确
 * @access public
 * @param string $code 用户验证码
 * @return bool 用户验证码是否正确
 */
public function check(string $code): bool
{
    if (!$this->session->has('captcha')) {
        return false;
    }
 
    $key = $this->session->get('captcha.key');
 
    $code = mb_strtolower($code, 'UTF-8');
 
    $res = password_verify($code, $key);
 
    if ($res) {
        $this->session->delete('captcha');
    }
 
    return $res;
}

從以上check方法可以看出來驗證碼驗證是需要session的,而Thinkphp6預設是不開啟的,需要依照手冊初始化一下

在應用程式app目錄下找到全域中間件middleware.php文件,把下面註解的程式碼\think\middleware\SessionInit::class開啟就行了

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

以上是TP6驗證碼驗證失敗的原因以及解決方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:www.liqingbo.cn。如有侵權,請聯絡admin@php.cn刪除