Laravel学习-短信验证码

1.安装拓展包    overtrue/easy-sms

地址:   overtrue/easy-sms - Packagist

安装:  

composer require overtrue/easy-sms

创建控制器

php artisan make:controller Api/BindController

BindController.php

<?php

namespace App\Http\Controllers\Admin;

use App\Events\SendSms;
use App\Http\Controllers\Controller;
use Doctrine\Common\Cache\Cache;
use Illuminate\Http\Request;
use Overtrue\EasySms\EasySms;

class BindController extends Controller
{
    public function send(Request $request)
    {
        // 使用事件派发 发送验证码 Providers\EventServiceProvider\$listen下
        SendSms::dispatch($request->input('phone'), '绑定手机');
    }

    public function updatePhone(Request $request)
    {
        $request->validate([
            'phone' => 'required',
            'code'  => 'required'
        ]);

        // 验证code是否正确
         if (\cache('phone_code_'.$request->input('phone')) !=  $request->input('code')) {
             return response()->json(['code' => 500]);
         }

    }
}

在阿里云里添加用户还要添加权限, 只有分配了权限, 才能使用这里的数据

Laravel短信验证码

Laravel短信验证码


优化: 把短信的config需要抽离出来

在config下新建 sms.php

<?php
return [
    // HTTP 请求的超时时间(秒)
    'timeout' => 5.0,

    // 默认发送配置
    'default' => [
        // 网关调用策略,默认:顺序调用
        'strategy' => \Overtrue\EasySms\Strategies\OrderStrategy::class,

        // 默认可用的发送网关
        'gateways' => [
            'aliyun',
        ],
    ],
    // 可用的网关配置
    'gateways' => [
        'errorlog' => [
            'file' => '/tmp/easy-sms.log',
        ],
        'aliyun' => [
            'access_key_id' => env('SMS_AK'),
            'access_key_secret' => env('SMS_SK'),
            'sign_name' => '',
        ]
    ],
];

在.env中添加

SMS_AK=
SMS_SK=

使用事件派发 发送验证码 Providers\EventServiceProvider\$listen里面
protected $listen = [
	Registered::class => [
		SendEmailVerificationNotification::class,
	],
	'App\Events\OrderShoped' => [
		'App\Listeners\SendShopToUser',
	],
	'App\Events\SendSms' => [
		'App\Listeners\SendSmsListener',
	],
];

然后执行  php artisan event:generate 可以生成监听文件

SendSms.php

<?php

namespace App\Events;

use Illuminate\Broadcasting\Channel;
use Illuminate\Broadcasting\InteractsWithSockets;
use Illuminate\Broadcasting\PresenceChannel;
use Illuminate\Broadcasting\PrivateChannel;
use Illuminate\Contracts\Broadcasting\ShouldBroadcast;
use Illuminate\Foundation\Events\Dispatchable;
use Illuminate\Queue\SerializesModels;

class SendSms
{
    use Dispatchable, InteractsWithSockets, SerializesModels;
    public $phone;
    public $product;

    /**
     * Create a new event instance.
     *
     * @return void
     */
    public function __construct($phone, $product)
    {
        $this->phone = $phone;
        $this->product = $product;
    }

    /**
     * Get the channels the event should broadcast on.
     *
     * @return \Illuminate\Broadcasting\Channel|array
     */
    public function broadcastOn()
    {
        return new PrivateChannel('channel-name');
    }
}

SendSmsListener.php

<?php

namespace App\Listeners;

use App\Events\SendSms;
use Doctrine\Common\Cache\Cache;
use Illuminate\Contracts\Queue\ShouldQueue;
use Illuminate\Queue\InteractsWithQueue;
use Overtrue\EasySms\EasySms;

class SendSmsListener
{
    /**
     * Create the event listener.
     *
     * @return void
     */
    public function __construct()
    {
        //
    }

    /**
     * Handle the event.
     *
     * @param  SendSms  $event
     * @return void
     */
    public function handle(SendSms $event)
    {
        $config = config('sms');
        $easySms = new EasySms($config);
        $code = rand(1000, 9999);
        // 缓存验证码
        Cache::put('phone_code_'.$event->phone, $code, now()->addMinutes(15));
        try {
            $easySms->send(13188888888, [
                'content'  => '您的验证码为: ',
                'template' => $config['template'],
                'data' => [
                    'code' => $code
                ]
            ]);
        } catch (\Exception $e) {
            return $e->getExceptions();
        }
    }
}

TODO:

使用队列

检查env中 QUEUE_CONNECTION=database


                
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
好的,关于 Laravel 的 app->make(),它是用来解决依赖注入的问题的,也就是通过容器来自动实例化对象并注入到需要的类中的。具体使用的场景如下: 1. 容器的构建和使用:Laravel 中的容器是通过 Illuminate\Container\Container 类实现的。我们可以通过 app()->make() 方法来获取一个容器实例,也可以通过 app() 方法来获取已经绑定的服务实例。 2. 类的自动解析:当一个类需要使用到其它类的实例时,可以通过在类的构造方法中声明需要的依赖来实现自动解析。当调用 app()->make() 方法时,容器会自动解析所需要的类,并且将实例注入到类中。 3. 实现服务提供者:在 Laravel 中,服务提供者是一个用来绑定服务到容器的类。如果将服务提供者注册到应用程序中,就可以将服务绑定到容器中,然后可以使用 app()->make() 方法来获取服务实例了。 下面是一些示例代码,用来说明 app->make() 的用途: ```php // 注册服务提供者 app()->register(MyServiceProvider::class); // 获取容器实例 $container = app(); // 获取服务实例 $myService = $container->make('my-service'); // 自动解析依赖 class UserController { protected $userService; public function __construct(UserService $userService) { $this->userService = $userService; } } // 手动绑定依赖 $container->bind('userService', function($container) { return new UserService($container->make('userRepository')); }); ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

TO_WebNow

你的鼓励将是我创作的最大动力

¥2 ¥4 ¥6 ¥10 ¥20
输入1-500的整数
余额支付 (余额:-- )
扫码支付
扫码支付:¥2
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、C币套餐、付费专栏及课程。

余额充值