正在公司做一个商城项目,由于只有一个后台,所以注册用短信注册也就轮到我来做的。刚刚开始,我内心还是有点虚的,还好有 Laravel-china 社区的 summer 大神,写的书。在里面参考了它的写法和思路,并且用了 easy-sms 包,这才用了半个下午的时间,顺利的做出来了,晚上赶紧和大家分享一波了。
1、确定短信运营商
我看到大佬都是用的云片,我也就毫不犹豫的大力推荐公司用这个短信平台了,不过其他的也可以咯。
首先自己注册一个帐号,然后找到这个 
 
 
点击开始接入,完成新手引导过程。 
 
 
第二部的签名和模板必须填写,类似我下面填写的这样 
 
 

值得注意的是这个模板必须和你到时候用 easy-sms 包的时候,设定的短信内容必须和这个一模一样,不然会报错的。
还有就是记得一定得拿到APIKEY。到时候,在env里进行配置。
# 云片YUNPIAN_API_KEY=9c60bdd**********
2、安装 easy-sms 包
利用这个包,可以快速的实现短信发送功能。
composer require "overtrue/easy-sms"
由于该组件还没有 Laravel 的 ServiceProvider ,为了方便使用,我们可以自己封装一下。
首先在 config 目录中增加 easysms.php 文件
在 config/easysms.php 填写如下内容。
<?phpreturn [ // HTTP 请求的超时时间(秒) 'timeout' => 5.0, // 默认发送配置 'default' => [  // 网关调用策略,默认:顺序调用  'strategy' => /Overtrue/EasySms/Strategies/OrderStrategy::class,  // 默认可用的发送网关  'gateways' => [   'yunpian',  ], ], // 可用的网关配置 'gateways' => [  'errorlog' => [   'file' => '/tmp/easy-sms.log',  ],  'yunpian' => [   'api_key' => env('YUNPIAN_API_KEY'),  ], ],];然后创建一个 ServiceProvider
php artisan make:provider EasySmsServiceProvider
修改文件 app/providers/EasySmsServiceProvider.php
<?phpnamespace App/Providers;use Overtrue/EasySms/EasySms;use Illuminate/Support/ServiceProvider;class EasySmsServiceProvider extends ServiceProvider{ /**  * Bootstrap the application services.  *  * @return void  */ public function boot() {  // } /**  * Register the application services.  *  * @return void  */ public function register() {  $this->app->singleton(EasySms::class, function ($app) {   return new EasySms(config('easysms'));  });  $this->app->alias(EasySms::class, 'easysms'); }}            
新闻热点
疑难解答