cann/laravel-vcode is a Laravel package for laravel sms verification.
It currently has 1 GitHub stars and 201 downloads on Packagist (latest version v2.1).
Install it with composer require cann/laravel-vcode.
Discover more Laravel packages by cann
or browse all Laravel packages to compare alternatives.
Last updated
便捷的验证码发送工具,目前支持基于[easysms]https://github.com/overtrue/easy-sms 的短信验证码
composer require cann/laravel-vcode
php artisan vendor:publish --provider="Cann\Vcode\VcodeServiceProvider"
php artisan migrate
config/easysms.php: 短信服务商配置
config/vcode.php: 验证码相关配置
修改 .env 加入相关配置(以腾讯云短信通道为例):
SMS_QCLOUD_SECRET_ID=
SMS_QCLOUD_SECRET_KEY=
SMS_QCLOUD_REGION=
SMS_QCLOUD_APP_ID=
SMS_QCLOUD_VCODE_TPL=
SMS_QCLOUD_VCODE_TPL_INTL=
SMS_SIGN_NAME=高灯科技
该工具提供了统一的接口进行验证码发送:
POST:{host}/{prefix}/vcode
| 字段 | 必填 | 类型 | 详细描述 |
| ---- | ---- | ---- | -------- |
| channel | 否 | STRING | 验证码发送渠道
sms: 短信验证码 (默认)
email: 邮箱验证码 (暂不支持) |
| scene | 是 | STRING | 发送场景
config/vcode.channels.{channel}.scenes 中定义
注:不同场景短信冷却时间不共享,验证码不通用 |
| mobile | 是 | STRING | 发送目标,字段名可在 config/vcode.channels.{channel}.field 修改 |
| captcha_key | 否 | STRING | 图形验证码 Key
注:当触发图形验证码时,该值必填 |
| captcha_code | 否 | STRING | 图形验证码
注:当触发图形验证码时,该值必填 |
| 字段 | 类型 | 详细描述 |
| ---- | -----| ------- |
| code | INT | 响应码,可在 config/vcode.responses 修改 |
| message | STRING | 响应消息,可在 config/vcode.responses 修改 |
| data | ARRAY | 响应数据 |
{
"code": 0,
"message": "发送成功",
"data": {
"seconds": 60
}
}
or
{
"code": -1,
"message": "你的动作太快了,请在 57 秒后重试",
"data": {
"seconds": 57
}
}
or
{
"code": -101,
"message": "请输入图形验证码",
"data": {
"captcha_api": "http://yocann.cn/api/captcha"
}
}
vcode 参数上加上 verify_code 验证器进行验证,verify_vcode 会自动读取请求中的 channel scene mobile vcode 参数进行校验verify_vcode(string $scene, string $mobile, string $vcode, string $channel) 方法进行校验