首页 > 作文

Laravel实现短信注册的示例代码

更新时间:2023-04-06 17:36:47 阅读: 评论:0

正在公司做一个商城项目,由于只有一个后台,所以注册用短信注册也就轮到我来做的。刚刚开始,我内心还是有点虚的,还好有 laravel-china 社区的 summer 大神,写的书。在里面参考了它的写法和思路,并且用了 easy-sms 包,这才用了半个下午的时间,顺利的做出来了,晚上赶紧和大家分享一波了。

1、确定短信运营商

我看到大佬都是用的云片,我也就毫不犹豫的大力推荐公司用这个短信平台了,不过其他的也可以咯。

首先自己注册一个帐号,然后找到这个

点击开始接入,完成新手引导过程。

第二部的签名和模板必须填写,类似我下面填写的这样

值得注意的是这个模板必须和你到时候用 easy-sms 包的时候,设定的短信内容必须和这个一模一样,不然会报错的。

还有就是记得一定得拿到apikey。到时候,在env里进行配置。

# 云片yunpian_api_key=9c60bdd**********

2、安装 easy-sms

利用这个包,可以快速的实现短信发送功能。

compor require "overtrue/easy-sms"

由于该组件还没有 laravel 的 rviceprovider ,为了方便使用,我们可以自己封装一下。

首先在 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'),  ], ],];

然后创建一个 rviceprovider

php artisan make:provider easysmsrviceprovider

修改文件 app/providers/easysmsrviceprovider.php

<?phpnamespace app\providers;u overtrue\easysms\easysms;u illuminate\support\rviceprovider;class easysmsrviceprovider extends rviceprovider{ /**  * bootstrap the application rvices.  *  * @return void  */ public function 读书破万卷下一句boot() {  // } /**  * register the application rvices.  *  * @return void  */ public function register() {  $this->app->singleton(easysms::class, function ($app) {   return new easysms(config('easysms'));  });  $this->app->alias(easysms::class, 'easysms'); }}

最后在 config/app.phpproviders 里增加刚刚创建的服务写进去,app\providers\easysmsrviceprovider::class,

app\providers\apprviceprovider::class,app\providers\authrviceprovider::class,// app\providers\broadcastrviceprovider::class,app\providers\eventrviceprovider::class,app\providers\routerviceprovider::class,app\providers\easysmsrviceprovider::class, //easy-sms

3、创建路由和对应的控制器

首先创建路由,我们需要一个ajax请求短信验证码的方法,和一个进行确认注册的逻辑方法,如下:

route::group(['prefix' => 'verificationcodes', 'as' =&g1两等于多少斤t; 'verificationcodes.'], function() {  route::post('register', 'verificationcodescontroller@register')->name('register');  route::get('ajaxregister', 'verificationcodescontroller@ajaxregister')->name('ajaxregister'); });

路由创建好了,我们用命令生成controller了

p防疫主题hp artisan make:controller home\verificationcodescontroller

再直接在里面写 registerajaxregister 方法了

代码逻辑

修改文件

app/home/verificationcodescontroller.php

<?php...u overtrue\easysms\easysms;u app\models\system\ur;class verificationcodescontroller extends controller{ // 这里验证就不写了。 public function aj个性签字axregister(verificationcoderequest $request, easysms $easysms) {  //获取前端ajax传过来的手机号  $phone = $request->phone;    // 生成4位随机数,左侧补0  $code = str_pad(random_int(1, 9999), 4, 0, str_pad_left);    try {   $result = $easysms->nd($mobile, [    'content' => "【安拾商城】您的验证码是{$code}。如非本人操作,请忽略本短信"   ]);  } catch (overtrue\easysms\exceptions\nogatewayavailableexception $exception) {   $respon = $exception->getexceptions();   return respon()->json($respon);  }    //生成一个不重复的key 用来搭配缓存cache判断是否过期  $key = 'verificationcode_' . str_random(15);  $expiredat = now()->addminutes(10);    // 缓存验证码 10 分钟过期。  \cache::put($key, ['mobile' => $mobile, 'code'=> $code], $expiredat);    return respon()->json([   'key' => $key,   'expired_at' => $expiredat->todatetimestring(),  ], 201); }

这样,用户就能收到短信,并且前端应该保存这个 key ,提交注册表单的时候传递给后台,判断是否已经过期。下面就是判断是否过期,验证码是否错误。

public function register(verificationcoderequest $request){ //获取刚刚缓存的验证码和key $verifydata = \cache::ge四次元空间t($request->verification_key);  //如果数据不存在,说明验证码已经失效。 if(!$verifydata) {  return respon()->json(['status' =>0, 'message'=> '短信验证码已失效'], 422); }  // 检验前端传过来的验证码是否和缓存中的一致 if (!hash_equals($verifydata['code'], $request->verification_code) {  return redirect()->back()->with('warning', '短信验证码错误'); }  $ur = ur::create([  'mobile' => $verifydata['mobile'],  'password' => bcrypt($request->password), ]); // 清除验证码缓存 \cache::forget($request->verification_key); return redirect()->route('login')->with('success', '注册成功!'); }

上面的 hash_equals 是可防止时序攻击的字符串比较的~

以上就是我整个的过程。

本文发布于:2023-04-06 17:36:45,感谢您对本站的认可!

本文链接:https://www.wtabcd.cn/fanwen/zuowen/97005ee3aefbcd943f8b49a682e62d79.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

本文word下载地址:Laravel实现短信注册的示例代码.doc

本文 PDF 下载地址:Laravel实现短信注册的示例代码.pdf

标签:验证码   短信   缓存   网关
相关文章
留言与评论(共有 0 条评论)
   
验证码:
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图