thinkphp5生成随机验证码,自定义法方法
taotaoit ThinkPHP5.1 2023-04-26 939 0
关于本站

“最难不过坚持”

本人承接扒站仿站,php网站维护,病毒查杀,网站编辑,网站改版,html制作

有需要网站维护,改版,病毒查杀,网站编辑,网站备案,html制作等相关的工作可以联系我。
本人有多年相关工作经验,也可提供免费咨询,交个朋友。
有需要探讨问题的朋友,也可以加我微信,共同探讨!
微信:15011482830 QQ:408917339

7441053 2655 39
最新评论
https://jueru.net/
评 留言
:weixiao:
评 留言
:shuijiao: :weiqu: :zhenbang: :leng:
评 留言
:yiwen: :yiwen: :yiwen: :yiwen:
评 EasySass: could not generate CSS file. See Output panel for details.
这个业务逻辑多少都有点奇怪了,阅读浏览次数增值在新闻详情页的控制器方法里setInc,这怎么还写进模型事件里了。如果非要用onAfterRead也可以,把新闻文章的内容单独分出来一个news_content表,然后把它和news做关联,然后给news_content表的onAfterRead事件做增值处理,这样点进新闻页内查询到文章内容时才会触发它。
评 TP6模型事件-查询后onAfterRead不好用
文章标签更多
ThinkPHP (254)
Mysql (58)
DedeCms (33)
jQuery (67)
证件照 (1)
setInc (4)
setDec (4)
onclick (5)
打开边栏(ESC) 关闭边栏(ESC)

代码

<?php
namespace app\api\controller;

use think\Controller;
/**
 * 微信小程序接口
 */
class Base extends Controller
{
    public $seKey = '.com'; // 验证码加密密钥
    // public $codeSet = '2345678abcdefhijkmnpqrstuvwxyzABCDEFGHJKLMNPQRTUVWXY';// 验证码字符集合
    public $codeSet = '1234567890';// 验证码字符集合
    public $expire = 300; // 验证码过期时间(s)
    public $length = 4;
    public $reset = true;           // 验证成功后是否重置
    
    /**
     * 生成验证码
     * 输出验证码并把验证码的值保存的session中
     * 验证码保存到session的格式为: array('verify_code' => '验证码值', 'verify_time' => '验证码创建时间');
     * @param string $id 要生成验证码的标识   
     */
    protected function ZHTVerify($id = ''){
        
        $code = array(); // 验证码
        for ($i = 0; $i<$this->length; $i++) {
            $code[$i] = $this->codeSet[mt_rand(0, strlen($this->codeSet)-1)];
        }
        $code = implode('', $code);
        // 保存验证码
        $key        =   $this->authcode($this->seKey);
        $code_session       =   $this->authcode(strtoupper($code));
        $secode     =   array();
        $secode['verify_code'] = $code_session; // 把校验码保存到session
        $secode['verify_time'] = time();  // 验证码创建时间
        session($key.$id, $secode);
        return $code;
    }
    /**
     * 验证验证码是否正确
     * @access public
     * @param string $code 用户验证码
     * @param string $id 验证码标识     
     * @return bool 用户验证码是否正确
     */
    protected function ZHTVerifyCheck($code, $id = ''){
        $key = $this->authcode($this->seKey).$id;
        // 验证码不能为空
        $secode = session($key);
        // echo '呵呵';
        // dump($secode);
        // die;
        if(empty($code) || empty($secode)) {
            return false;
        }
        
        // session 过期
        if(time() - $secode['verify_time'] > $this->expire) {
            session($key, null);
            return false;
        }
        if($this->authcode(strtoupper($code)) == $secode['verify_code']) {
            $this->reset && session($key, null);
            return true;
        }

        return false;
    }
    /* 加密验证码 */
    private function authcode($str){
        $key = substr(md5($this->seKey), 5, 8);
        $str = substr(md5($str), 8, 10);
        return md5($key . $str);
    }
}

使用:

生成验证码:

$phone = '15011482831';
// 生成验证码,$phone不写也可以,一个页面多个验证码,可以写个参数,区别
$captcha_code = $this->ZHTVerify($phone);
验证验证码是否正确:

$phone = '15011482831';
    $code = '7302';
    if(!$this->ZHTVerifyCheck($code,$phone)){
			$this->code(403, 'verifyCodeFailed');
		}


版权声明:本站原创文章,允许自由转载。

相关推荐
Non-static method think\Config::get() should not be called statically
ThinkPHP5.1 | 2018-12-29 10949
原来是这样use think\Config; 改成这样use think\facade\Config; 下面是官方手册的解释 配置获取 要使用Config类,首先需要在你的类文件中引入 use think\facade\Config; 或者(因为系统做了类库别名,其实就是调用think\facade\Config) u...
ThinkPHP5 order多条件排序
ThinkPHP5.1 | 2017-10-24 10809
总结如下: //单一条件排序 $user = $this->where(['parentId'=>0)->field('userId,userName,userSort,isShow')->order('userSort', 'asc')->select(); //多个条件排序,可以多加一个order...
评论:0条
评论加载中...
发表评论