zx/vendor/fastknife/ajcaptcha
gboy ed1278a5e3 first 2024-07-02 15:32:59 +08:00
..
resources first 2024-07-02 15:32:59 +08:00
src first 2024-07-02 15:32:59 +08:00
test first 2024-07-02 15:32:59 +08:00
.gitignore first 2024-07-02 15:32:59 +08:00
LICENSE first 2024-07-02 15:32:59 +08:00
changelog.md first 2024-07-02 15:32:59 +08:00
composer.json first 2024-07-02 15:32:59 +08:00
demo.md first 2024-07-02 15:32:59 +08:00
readme.md first 2024-07-02 15:32:59 +08:00

readme.md

AJ-Captcha · php

介绍

这个类库使用 PHP实现了行为验证码。基于gd扩展生成滑动验证码和文字验证码。允许 phper定制验证码规则并且不再使用 curl来请求第三方验证。

Java实现 https://gitee.com/anji-plus/captcha

PHP实现 https://gitee.com/fastknife/aj-captcha

官方预览效果

block click

注意事项

  • 你需要打开 gd、 openssl扩展

  • PHP版本至少需要7.1

  • 此软件包自带缓存,如有需要请自行更换

  • anji-plus/captcha前端默认请求头是 application/json 需替换为 application/x-www-form-urlencode

  • 滑动验证图响应时间慢?

    性能慢的主要原因是受php GD库的imagecolorat函数与imagesetpixel函数性能的影响

    1. 您可以尝试将修改内存ini_set('memory_limit', '256M')
    2. 将本包升级到1.1.0以上的版本,开启像素缓存block_puzzle.is_cache_pixel = true, 若还是性能还是慢,则将干扰图片关闭block_puzzle.is_interfere => false

如何使用

test 目录下示例了三种使用方式phper可以参考使用。查看demo

本软件包需要配合composer一起使用

  1. 非框架使用的场景直接使用git下载这个软件包。然后执行composer命令composer install安装本软件包依赖,接着手动引入对应的 service层文件即可同test目录里的原生引用方式

  2. 基于框架使用的场景,输入安装命令composer require fastknife/ajcaptcha(稳定版) 或者composer require fastknife/ajcaptcha dev-master(最新版) 建议使用composer阿里源https://mirrors.aliyun.com/composer

    • 支持各种前沿框架ThinkPHP, YII, Laravel, HyperfIMI,Swoft,EasySwoole
    • 本软件包内未使用单例、注册树容器模式不含任何全局变量基于swoole开发的同学不用担心内存泄露。

项目结构

本软件包基于整洁架构理念设计了下文的目录结构。Domain(领域层)作为内层同心圆承担所有业务逻辑功能Service服务层并向最外层Controller需自行实现提供粗颗粒度服务。
区别于DDD(领域驱动设计),本软件包的领域层不含Entity(实体)以Logic逻辑层实现单元逻辑为了方便管理作者将逻辑层的数据处理与图形处理分隔以达到整洁效果。

AJ-Captcha for php
│
├─resources 资源
│	│
│	├─defaultImages 图片资源
│	│
│	└─fonts 字体
│
├─src 源码
│	│
│	├─Domian 领域层
│	│
│	├─Exception 异常
│	│
│	├─Service 服务层
│	│
│	├─ Utils工具类
│	│
│	└─ config.php 配置参考
└─test 测试实例
	│
	├─thinkphp thinkphp框架测试示例
	│
	├─laravel laravel框架测试示例
	│
	└─*.php 原生测试文件 配置文件

更新日志

若此软件对您有所帮助,您可以点右上角 💘Star💘支持