标签:version 用户 xxxxx hang 模板类 main app you 支持
Laravel 贴合实际需求同时满足多种通道的短信发送组件
我们基于业务需求在 overtrue/easy-sms 基础进行扩展开发,主要实现如下目标:
TODO:
composer require ibrand/laravel-sms:~1.0 -vvv
低于 Laravel5.5 版本
config/app.php
文件中 ‘providers‘ 添加
iBrand\Sms\ServiceProvder::class
config/app.php
文件中 ‘aliases‘ 添加
‘Sms‘=> iBrand\Sms\Facade::class
实现了发送短信验证码路由,支持 web 和 api ,可以自定义路由的 prefix。
‘route‘ => [
‘prefix‘ => ‘sms‘,
‘middleware‘ => [‘web‘],
],
or
‘route‘ => [
‘prefix‘ => ‘sms‘,
‘middleware‘ => [‘api‘],
],
POST请求 http://your.domain/sms/verify-code
参数:mobile
备注:为了支持开发时的调试,在发送验证码时不去验证手机号本身的有效性,请在发送验证码前自行验证。
返回参数:
{
"status": true,
"message": "短信发送成功"
}
use iBrand\Sms\Facade as Sms;
if (!Sms::checkCode(\request(‘mobile‘), \request(‘code‘))) {
//Add you code.
}
在 config/ibrand/sms.php
的 gateways
参数可以直接添加 code_template_id
来配置模板 id
// 可用的网关配置
‘gateways‘ => [
‘errorlog‘ => [
‘file‘ => ‘/tmp/easy-sms.log‘,
],
‘yunpian‘ => [
‘api_key‘ => ‘824f0ff2f71cab52936axxxxxxxxxx‘,
],
‘aliyun‘ => [
‘access_key_id‘ => ‘dalvTXXX‘,
‘access_key_secret‘ => ‘XXXX‘,
‘sign_name‘ => ‘阿里云短信测试专用‘,
‘code_template_id‘ => ‘SMS_80215252‘
],
‘alidayu‘ =>
//...
],
],
非模板类通道,可以通过 config/ibrand/sms.php 自定义短信内容
‘content‘ => ‘【your signature】亲爱的用户,您的验证码是%s。有效期为%s分钟,请尽快验证。‘
在实际开发中会存在并不用真实发出验证码的情况,因此在 debug 模式下,可以通过
http://your.domain/api/sms/info?mobile=1898888XXXX
来直接只看某个手机号当前有效验证码信息。
欢迎大家 star 和提交 issue :)
标签:version 用户 xxxxx hang 模板类 main app you 支持
原文地址:https://www.cnblogs.com/iBrand2018/p/10035820.html