这个类库使用 PHP实现了行为验证码。基于gd扩展生成滑动验证码和文字验证码。允许 phper定制验证码规则,并且不再使用 curl来请求第三方验证。
Java实现: https://gitee.com/anji-plus/captcha
PHP实现: https://gitee.com/fastknife/aj-captcha
anji-plus/captcha前端默认请求头是 application/json 需替换为 application/x-www-form-urlencode
滑动验证图响应时间慢?
性能慢的主要原因是受php GD库的imagecolorat函数与imagesetpixel函数性能的影响
ini_set('memory_limit', '256M')
将本包升级到1.1.x版本,开启像素缓存block_puzzle.is_cache_pixel = true
, 若还是性能还是慢,则将干扰图片关闭block_puzzle.is_interfere => false
test 目录下示例了三种使用方式,phper可以参考使用。查看demo
本软件包需要配合composer一起使用
非框架使用的场景,直接使用git下载这个软件包。然后执行composer命令composer install
安装本软件包依赖,接着手动引入对应的 service层文件即可(同test目录里的原生引用方式)。
composer require fastknife/ajcaptcha
(稳定版) 或者composer require fastknife/ajcaptcha dev-master
(最新版) ,建议使用composer阿里源(https://mirrors.aliyun.com/composer
)
本软件包基于整洁架构理念,设计了下文的目录结构。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💘支持