ThinkPHP简单的验证码实现

时间:2022-08-15 15:17:21

ThinkPHP简单的验证码实现

写一个最简单的TP验证码。

  • 写Controller

首先在Controller/IndexController.class.php(简称Index)文件中编辑:

 <?php
namespace Home\Controller;
use Think\Controller;
use Think\Verify;//这个类一定记得引用
class IndexController extends Controller {
public function index(){
$this->redirect('login');//重定向至login方法
} /*验证码*/
public function verify(){
$verify=new Verify();//新建一个验证码
$verify->entry();//输出验证码
} /*登陆*/
public function login(){
$this->display();//调用对应模板中的login.html
} /*登陆验证*/
public function login_do(){
$code=I('code');
$verify=new Verify();
if($verify->check($code)){
$this->success("验证成功");
}else{
$this->error("验证码错误");
}
}
}
  • 写html

接下来要去新建一个表单,用于显示验证码并提供一个输入框,输入验证。

如果表单先不新建,现在就去看验证码的效果也是可以的。在浏览器访问:

http://localhost:8088/TP/Home/Index/verif就可以了。

上面操作是在Controller文件夹里面的index控制器进行的。我们去同级文件夹View里面新建一个文件夹叫做index进入index新建login.html

该html文件的命名与控制器文件中的login方法一直,在方法调用

 $this->display();//调用对应模板中的login.html

  即可显示login.html

文件中添加如下表单。

  <form action="__URL__/login_do" method="post">
<input type="text" placeholder="请输入验证码" name="code" required>
<img src="{:U('verify')}" alt="" onclick="this.src='{:U('verify')}?'+Math.random()" title="看不清换一张">
<button>登陆</button>
</form>

  

  • 访问测试

访问http://localhost:8088/TP/Home/Index/login即可看到如下效果。

ThinkPHP简单的验证码实现

这个验证码是默认的,以上编写显示过程也是相对比较简单的。

  • 验证码图形自定义

我们接下来可以在此基础之上自定义一下。

修改控制器文件:

     /*验证码*/
public function verify(){
$config=array(
'expire'=> 60, //验证码的有效期(秒)
'useImgBg'=>false , //是否使用背景图片 默认为false
'fontSize'=>35 , //验证码字体大小(像素) 默认为25
'useCurve'=>true , //是否使用混淆曲线 默认为true
'useNoise'=>true , //是否添加杂点 默认为true
//'imageW'=>100 , //验证码宽度 设置为0为自动计算
//'imageH'=>30 , //验证码高度 设置为0为自动计算
'length'=>4 , //验证码位数
//'fontttf'=> , //指定验证码字体 默认为随机获取
//'useZh'=> , //是否使用中文验证码
//'bg'=> , //验证码背景颜色 rgb数组设置,例如 array(243, 251, 254)
//'seKey'=> , //验证码的加密密钥
//'codeSet'=> , //验证码字符集合 3.2.1 新增
//'zhSet'=> , //验证码字符集合(中文) 3.2.1 新增
); $verify=new Verify($config);//新建一个验证码
$verify->entry();//输出验证码
}

这样则可以自定义验证码。