# 验证码
首先使用`Composer`安装`think-captcha`扩展包:
```
composer require topthink/think-captcha
```
## 验证码的简单用法
扩展包内定义了一些常见用法方便使用,可以满足大部分常用场景,以下示例说明。
在模版内添加验证码的显示代码
```
<div>{:captcha_img()}</div>
```
或者
```
<div><img src="{:captcha_src()}" alt="captcha" /></div>
```
> 上面两种的最终效果是一样的,根据需要调用即可。
然后使用框架的内置验证功能(具体可以参考验证章节),添加`captcha`验证规则即可
```
$this->validate($data,[
'captcha|验证码'=>'require|captcha'
]);
```
如果没有使用内置验证功能,则可以调研内置的函数手动验证
```
if(!captcha_check($captcha)){
// 验证失败
};
```
## 验证码的自定义用法
如果需要自己独立生成验证码,可以调用`Captcha`类(`think\captcha\Captcha`)操作。
在控制器中使用下面的代码进行验证码生成:
```
<?php
namespace app\index\controller;
use think\captcha\Captcha;
class Index
{
public function verify()
{
$captcha = new Captcha();
return $captcha->entry();
}
}
```
然后访问下面的地址就可以显示验证码:
```
http://serverName/index/index/verify
```
输出效果如图
![](https://box.kancloud.cn/dcbf30b119dc2bb7ec6f41d943b5646c_250x62.png)
通常可以给验证码地址注册路由
```
Route::get('verify','index/verify');
```
在模板中就可以使用下面的代码显示验证码图片
```
<div><img src="{:url('index/verify')}" alt="captcha" /></div>
```
如果你需要在一个页面中生成多个验证码的话,`entry`方法需要传入可标识的信息(数字或者字符串),例如:
```
$captcha = new Captcha();
return $captcha->entry(1);
```
可以用`Captcha`类的`check`方法检测验证码的输入是否正确,
```
// 检测输入的验证码是否正确,$value为用户输入的验证码字符串
$captcha = new Captcha();
if( !$captcha->check($value))
{
// 验证失败
}
```
或者直接调用封装的一个验证码检测的函数`captcha_check`
```
// 检测输入的验证码是否正确,$value为用户输入的验证码字符串
if( !captcha_check($value ))
{
// 验证失败
}
```
如果你在页面上同时生成了多个验证码,则可以使用
```
// 检测输入的验证码是否正确,$value为用户输入的验证码字符串,$id为验证码标识
if( !captcha_check($value, $id ))
{
// 验证失败
}
```
## 验证码的配置参数
`Captcha`类带有默认的配置参数,支持自定义配置。这些参数包括:
参数描述默认codeSet验证码字符集合略expire验证码过期时间(s)1800useZh使用中文验证码falsezhSet中文验证码字符串略useImgBg使用背景图片falsefontSize验证码字体大小(px)25useCurve是否画混淆曲线trueuseNoise是否添加杂点trueimageH验证码图片高度,设置为0为自动计算0imageW验证码图片宽度,设置为0为自动计算0length验证码位数5fontttf验证码字体,不设置是随机获取空bg背景颜色\[243, 251, 254\]reset验证成功后是否重置true> 如果使用扩展内置的方法进行验证码显示,直接在应用的`config`目录下面的`captcha.php`文件(没有则首先创建)中进行设置即可,以下设置方式仅限于独立调用Captcha类的时候使用。
实例化传入参数:
```
$config = [
// 验证码字体大小
'fontSize' => 30,
// 验证码位数
'length' => 3,
// 关闭验证码杂点
'useNoise' => false,
];
$captcha = new Captcha($config);
return $captcha->entry();
```
或者采用动态设置的方式,如:
```
$captcha = new Captcha();
$captcha->fontSize = 30;
$captcha->length = 3;
$captcha->useNoise = false;
return $captcha->entry();
```
### 验证码字体
默认情况下,验证码的字体是随机使用扩展包内 `think-captcha/assets/ttfs`目录下面的字体文件,我们可以指定验证码的字体,例如:
```
$captcha = new Captcha();
$captcha->fontttf = '5.ttf';
return $captcha->entry();
```
### 背景图片
支持验证码背景图片功能,可以如下设置:
```
$captcha = new Captcha();
// 开启验证码背景图片功能 随机使用扩展包内`think-captcha/assets/bgs`目录下面的图片
$captcha->useImgBg = true;
return $captcha->entry();
```
### 中文验证码
如果要使用中文验证码,可以设置:
```
$captcha = new Captcha();
// 使用中文验证码(字体使用扩展包内`think-captcha/assets/zhttfs`字体文件)
$captcha->useZh = true;
return $captcha->entry();
```
### 指定验证码字符
指定验证码的字符,可以设置:
```
$captcha = new Captcha();
// 设置验证码字符为纯数字
$captcha->codeSet = '0123456789';
return $captcha->entry();
```
如果是中文验证码,可以使用`zhSet`参数设置,例如:
```
$captcha = new Captcha();
$captcha->useZh = true;
// 设置验证码字符
$captcha->zhSet = '们以我到他会作时要动国产的一是工就年阶义发成部民可出能方进在了不和有大这';
return $captcha->entry();
```
> 默认的验证码字符已经剔除了易混淆的`1l0o`等字符
- 序言
- 基础
- 安装
- 开发规范
- 目录结构
- 配置
- 架构
- 架构总览
- 入口文件
- URL访问
- 模块设计
- 命名空间
- 容器和依赖注入
- Facade
- 钩子和行为
- 中间件
- 路由
- 路由定义
- 变量规则
- 路由地址
- 闭包支持
- 路由参数
- 路由缓存
- 跨域请求
- 注解路由
- 路由分组
- MISS路由
- 资源路由
- 快捷路由
- 路由别名
- 路由绑定
- 域名路由
- URL生成
- 控制器
- 控制器定义
- 前置操作
- 跳转和重定向
- 空操作和空控制器
- 分层控制器
- 资源控制器
- 请求
- 请求对象
- 请求信息
- 输入变量
- 请求类型
- HTTP头信息
- 伪静态
- 参数绑定
- 请求缓存
- 响应
- 响应输出
- 响应参数
- 重定向
- 数据库
- 连接数据库
- 查询构造器
- 查询数据
- 添加数据
- 更新数据
- 删除数据
- 查询表达式
- 链式操作
- 聚合查询
- 时间查询
- 高级查询
- 视图查询
- JSON字段
- 子查询
- 原生查询
- 查询事件
- 事务操作
- 监听SQL
- 存储过程
- 数据集
- 分布式数据库
- 模型
- 定义
- 新增
- 更新
- 删除
- 查询
- JSON字段
- 获取器
- 修改器
- 自动时间戳
- 只读字段
- 软删除
- 类型转换
- 数据完成
- 查询范围
- 模型输出
- 模型事件
- 模型关联
- 一对一关联
- 一对多关联
- 远程一对多
- 多对多关联
- 多态关联
- 关联预载入
- 关联统计
- 关联输出
- 视图
- 视图渲染
- 视图赋值
- 视图过滤
- 模板引擎
- 模板
- 变量输出
- 使用函数
- 运算符
- 原样输出
- 模板注释
- 模板布局
- 模板继承
- 包含文件
- 输出替换
- 标签库
- 内置标签
- 循环标签
- 比较标签
- 条件判断
- 资源文件加载
- 标签嵌套
- 原生PHP
- 定义标签
- 标签扩展
- 错误和日志
- 异常处理
- 日志处理
- 调试
- 调试模式
- Trace调试
- 性能调试
- SQL调试
- 变量调试
- 远程调试
- 验证
- 验证器
- 验证规则
- 错误信息
- 验证场景
- 路由验证
- 内置规则
- 独立验证
- 静态调用
- 表单令牌
- 杂项
- 缓存
- Session
- Cookie
- 多语言
- 分页
- 上传
- 命令行
- 启动内置服务器
- 自动生成目录结构
- 创建类库文件
- 生成类库映射文件
- 清除缓存文件
- 生成配置缓存文件
- 生成数据表字段缓存
- 生成路由映射缓存
- 自定义指令
- 扩展库
- 验证码
- 图像处理
- Time
- 数据库迁移工具
- Workerman
- MongoDb
- 单元测试
- 安全和性能
- 安全建议
- 优化建议
- 附录
- 助手函数
- 升级指导
- 更新日志