You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

239 lines
7.0 KiB

1 year ago
### 范例
详情请查看test目录的PHP源码
#### 配置说明
```php
return [
'font_file' => '', //自定义字体包路径, 不填使用默认值
//文字验证码
'click_world' => [
'backgrounds' => []
],
//滑动验证码
'block_puzzle' => [
'backgrounds' => [], //背景图片路径, 不填使用默认值
'templates' => [], //模板图
'offset' => 10, //容错偏移量
'is_cache_pixel' => true, //是否开启缓存图片像素值,开启后能提升服务端响应性能(但要注意更换图片时,需要清除缓存)
],
//水印
'watermark' => [
'fontsize' => 12,
'color' => '#ffffff',
'text' => '我的水印'
],
'cache' => [
'constructor' => \Fastknife\Utils\CacheUtils::class,//若您使用了框架,并且想使用类似于redis这样的缓存驱动,则应换成框架的中的缓存驱动
'method' => [
// 遵守PSR-16规范不需要设置此项(tp6, laravel,hyperf)。如tp5就不支持(tp5缓存方法是rm,所以要配置为"delete" => "rm"),
'get' => 'get', //获取
'set' => 'set', //设置
'delete' => 'delete',//删除
'has' => 'has' //key是否存在
],
'options' => [
//如果您依然使用\Fastknife\Utils\CacheUtils做为您的缓存驱动,那么您可以自定义缓存配置。
'expire' => 300,//缓存有效期 (默认为0 表示永久缓存)
'prefix' => '', //缓存前缀
'path' => '', //缓存目录
'serialize' => [], //缓存序列化和反序列化方法
]
]
];
```
##### 缓存配置
> config.cache.constructor类型为string|array|function 使用以访问回调的方式获得缓存实例;
+ laravel 配置:
```
'constructor' => [Illuminate\Support\Facades\Cache::class, 'store']
```
+ tp6(tp5.1) 配置
```php
'constructor' => [think\Facade\Cache::class, 'instance']
```
> 无论配置写成`[think\Facade\Cache::class, 'instance']` 还是写成 `[think\Facade\Cache::class, 'store']` 目的都是为了获取缓存实例,具体情况视框架而定
+ 灵活自定义:
1. 如果您的需要使用类似以下命令打包配置文件(ThinkPHP,Laravel 命令)
- php think optimize:config
- php artisan optimize
则需要写成下面这样:
```php
$instance = \think\facade\Cache::store();//获取缓存想实例
//省略分部代码
'constructor' => serialize($instance);
```
因为在执行optimize打包命令时,会尝试将对象进行序列化。
2. 如果您不需要使用打包压缩命令,或者使用了像hyperf这样的框架,除了上述的写法,还可以写成这样:
```php
'constructor' => function () {
$container = \Hyperf\Utils\ApplicationContext::getContainer();
//在构造函数中传入自已的配置
return $container->get(\Psr\SimpleCache\CacheInterface::class);
},
```
除此之处,您传入的缓存实例应遵守psr-16规范
##### 背景图与滑动图
> 配置中的backgrounds与templates项均支持,Array, String两种格式
+ 使用Array(索引数组)格式时,表明它每一项都是一张图片。可以是本地图片路径,也可以是网络图片路径。
示例:
```php
'backgrounds' => [
'/public/images/xxx.jpg',
'http://www.image.xx.jpg'
]
```
+ 使用String格式时,表明它是一个图片所在位置的目录
示例:
```php
'backgrounds' => ROOT_PATH . '/resources/defaultImages/jigsaw/original/'
```
当配置中的backgrounds与templates项为空时,会将`/resources/defaultImages/`目录内所有图片做为默认图片。
下面是社区人员一起维护的图片库,这些图片可以与本程序无缝衔接。
https://gitee.com/anji-plus/AJ-Captcha-Images
##### 字体配置
字体配置在水印与文字点击验证功能中使用,其配置格式化String, 指向字体库。为空时会以`/resources/fonts`下的字体文件为默认值。
示例:
```php
'font_file' => ROOT_PATH . '/resources/fonts/WenQuanZhengHei.ttf'
```
#### 获取滑动验证码
```php
public function get(){
$config = require '../src/config.php';
$service = new BlockPuzzleCaptchaService($config);
$data = $service->get();
echo json_encode([
'error' => false,
'repCode' => '0000',
'repData' => $data,
'repMsg' => null,
'success' => true,
]);
}
```
#### 滑动验证
```php
public function check()
{
$config = require '../src/config.php';
$service = new BlockPuzzleCaptchaService($config);
$data = $_REQUEST;
$msg = null;
$error = false;
$repCode = '0000';
try {
$service->check($data['token'], $data['pointJson']);
} catch (\Exception $e) {
$msg = $e->getMessage();
$error = true;
$repCode = '6111';
}
echo json_encode([
'error' => $error,
'repCode' => $repCode,
'repData' => null,
'repMsg' => $msg,
'success' => ! $error,
]);
}
```
#### 获取文字验证码
```php
public function get()
{
$config = require '../src/config.php';
$service = new ClickWordCaptchaService($config);
$data = $service->get();
echo json_encode([
'error' => false,
'repCode' => '0000',
'repData' => $data,
'repMsg' => null,
'success' => true,
]);
}
```
#### 文字验证
```php
public function check()
{
$config = require '../src/config.php';
$service = new ClickWordCaptchaService($config);
$data = $_REQUEST;
$msg = null;
$error = false;
$repCode = '0000';
try {
$service->check($data['token'], $data['pointJson']);
} catch (\Exception $e) {
$msg = $e->getMessage();
$error = true;
$repCode = '6111';
}
echo json_encode([
'error' => $error,
'repCode' => $repCode,
'repData' => null,
'repMsg' => $msg,
'success' => ! $error,
]);
}
```
#### 前端请求头修改示例
```javascript
import axios from 'axios';
import qs from 'qs';
axios.defaults.baseURL = 'https://captcha.anji-plus.com/captcha-api';
const service = axios.create({
timeout: 40000,
headers: {
'Content-Type': 'application/x-www-form-urlencoded; charset=UTF-8'
},
})
service.interceptors.request.use(
config => {
if (config.hasOwnProperty('data')) {
config.data = qs.stringify(config.data)
}
return config
},
error => {
Promise.reject(error)
}
)
```
本包后续更新 ThinkPHP、Hyperf 等框架的demo,请持续关注
https://gitee.com/fastknife/aj-captcha