利用laravel怎么实现一个短信验证码功能

今天就跟大家聊聊有关利用laravel怎么实现一个短信验证码功能,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。

流程如下:

利用laravel怎么实现一个短信验证码功能

在阿里云上开通短信服务后需要做的:

1,申请签名  2,申请模板   3,创建Accesskey ,值得说的是,可以通过阿里云提供的子用户进行Accesskey的创建,这样可以更安全  4,充值

laravel有很多的进行短信业务的扩展包,之前我用的是阿里大于,使用如下:

1,从终端或者命令进入您的项,运行:composer require iscms/alisms-for-laravel

2,将:iscms\Alisms\AlidayuServiceProvider::class加入config\app.php的Providers下 类似:

利用laravel怎么实现一个短信验证码功能

3,运行:php artisan vendor:publish,这样会在config文件夹下新增一个alisms.php文件,内容如下:

<?php  return [   'KEY' =>env('ALISMS_KEY',null),   'SECRETKEY'=>env('ALISMS_SECRETKEY',null),  ];

4,在.env文件中写入:

ALISMS_KEY=23305789 ALISMS_SECRETKEY=**************

 注意:ALISMS_KEY和ALISMS_SECRETKEY就是阿里云生成的访问秘钥成对(AccessKeyId 与 AccessKeySecret)

开始使用:

1,在您需要调用短信服务的控制器中引入SMS:

  use iscms\Alisms\SendsmsPusher as Sms;

public function __construct(Sms $sms)  {   $this->sms=$sms;  }  public function index()  {   $result=$this->sms->send("$phone","$name","$content","$code");  }

参数说明:$phone,$name,$content,$code

$phone 指接受短信方的短信号码,

$name 指短信签名 可以在阿里大鱼短信签名 找到

$content 是指短信模板中的变量内容.举个例子

在自己的阿里大鱼模板里面有下面一个短信模板

模板名称: 身份验证验证码

模板ID: SMS_3910275

*模板内容: 验证码$[code],您正在进行${product}身份验证,打死不要告诉别人哦!

那么对应的我们的$content 就应该为

   {   code:"生成的验证码",   product:"示例项目"  }

到此就可以正常使用,但是不知道为什么,我在使用过程中,控制台返回了code=11的错误码,在淘宝上查证后是因为isv权限的问题,之后我在阿里云上将用户的权限控制开到了最大,但是依旧会出现这个错误,换了一个扩展包还是这个问题,到现在还没有解决,于是我就在laravel中写原生的。

首先从阿里云官网上下载关于短信服务的sdk包

SDK工具包中一共包含了2个类库,一个aliyun-php-sdk-core包,另外一个是alicom-dysms-api包,将这两个包添加到工程类库中依赖。

选择PHP版本的sdk包将压缩包解压,里面有四个文件夹:api_demo,api_sdk,msg_demo,msg_sdk

在laravel项目的app文件夹下新建一个名为libs的文件夹,将api_sdk和msg_sdk复制到libs文件夹下。

找到根目录下的composer.json文件,找到composer.json中定义的classmap选项,写入引入的两个包:

利用laravel怎么实现一个短信验证码功能

终端进入项目文件夹中运行:

composer dumpautoload

这样子就在laravel中引入了第三方类库。

创建代码文件

我将其简单的封装了一下:

<?php  // namespace App\Http\Controllers\sms;  use Aliyun\Core\Config;  use Aliyun\Core\Profile\DefaultProfile;  use Aliyun\Core\DefaultAcsClient;  use Aliyun\Api\Sms\Request\V20170525\SendSmsRequest;  use Aliyun\Api\Sms\Request\V20170525\QuerySendDetailsRequest;  use App\Http\Controllers\Controller;  // 加载区域结点配置  Config::load();  class SmsController extends Controller   {   /**    * 构造器    * @param string $accessKeyId 必填,AccessKeyId    * @param string $accessKeySecret 必填,AccessKeySecret    */   public function __construct($accessKeyId="######",$accessKeySecret="#######")   {    // 短信API产品名     $product = "Dysmsapi";    // 短信API产品域名     $domain = "dysmsapi.aliyuncs.com";     // 暂时不支持多Region     $region = "cn-hangzhou";     // 服务结点     $endPointName = "cn-hangzhou";     // 初始化用户Profile实例     $profile = DefaultProfile::getProfile($region, $accessKeyId, $accessKeySecret);     // 增加服务结点     DefaultProfile::addEndpoint($endPointName, $region, $product, $domain);     // 初始化AcsClient用于发起请求     $this->acsClient = new DefaultAcsClient($profile);   }   /**    * 发送短信范例    * @param [type] $phoneNumbers 必填, 短信接收号码    * @param string $signName 必填, 短信签名,应严格"签名名称"填写,    * @param string $templateCode 必填, 短信模板Code,应严格按"模板CODE"填写,    * @param [type] $outId  选填, 假如模板中存在变量需要替换则为必填项    * @return [type]    [description]    */   public function sendSms($phoneNumbers,$signName="XX软件",$templateCode="SMS_XXXXXX",$outId=null)   {     // 初始化SendSmsRequest实例用于设置发送短信的参数    $request = new SendSmsRequest;     // 必填,设置雉短信接收号码    $request->setPhoneNumbers($phoneNumbers);     // 必填,设置签名名称    $request->setSignName($signName);    // 必填,设置模板CODE    $request->setTemplateCode($templateCode);    $num = rand(100000,999999);     // 可选,设置模板参数    $request->setTemplateParam(json_encode(     Array(      "code" => "$num"     )    ));     // 可选,设置流水号    if($outId) {     $request->setOutId($outId);    }     // 发起访问请求    $acsResponse = $this->acsClient->getAcsResponse($request);   }   /**    * 查询短信发送情况范例    * @param [type] $phoneNumbers 必填, 短信接收号码    * @param [type] $sendDate  必填,短信发送日期,格式Ymd,支持近30天记录查询     * @param integer $pageSize 必填,分页大小    * @param integer $currentPage 必填,当前页码    * @param [type] $bizId  选填,短信发送流水号    * @return [type]    [description]    */   public function queryDetails($phoneNumbers,$sendDate,$pageSize=10,$currentPage=1,$bizId=null)   {     // 初始化QuerySendDetailsRequest实例用于设置短信查询的参数    $request = new QuerySendDetailsRequest();    $request->setPhoneNumber($phoneNumbers);    $request->setSendDate($sendDate);    $request->setPageSize($pageSize);    $request->setCurrentPage($currentPage);    if($bizId) {     $request->setBizId($bizId);    }    $acsResponse = $this->acsClient->getAcsResponse($request);   }  }

郑重声明:本文版权归原作者所有,转载文章仅为传播更多信息之目的,如作者信息标记有误,请第一时间联系我们修改或删除,多谢。