首頁 >後端開發 >php教程 >laravel中簡訊發送驗證碼的實作方法php實例

laravel中簡訊發送驗證碼的實作方法php實例

jacklove
jacklove原創
2018-06-26 17:16:222021瀏覽

在做用戶註冊和個人中心的安全管理時常常需要用到短信發送驗證碼,下面這篇文章主要給大家介紹了關於laravel中短信發送驗證碼的實現方法,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考借鑒,下面隨著小編來一起學習學習吧。

前言

前段時間想實作一個簡訊驗證碼的功能,但卡了很久。

首先我用的是阿里雲的簡訊服務業務,其首次接入流程如下:

在阿里雲上開通簡訊服務後面需要做的:

1,申請簽章  2,申請範本   3,創建Accesskey ,值得說的是,可以透過阿里雲提供的子使用者進行Accesskey的創建,這樣可以更安全  4 ,充值

laravel有很多的進行短信業務的擴展包,之前我用的是阿里大於,使用如下:

1,從終端或者命令進入您的項,運行:composer require iscms/alisms-for-laravel

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

3,執行:php artisan vendor:publish,這樣會在config資料夾下新增一個alisms.php文件,內容如下:

<?php
 return [
  &#39;KEY&#39; =>env(&#39;ALISMS_KEY&#39;,null),
  &#39;SECRETKEY&#39;=>env(&#39;ALISMS_SECRETKEY&#39;,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 指短信簽名可以在阿里大魚短信簽名http://www.alidayu.com/admin/service/sign 找到

  • $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選項,寫入引入的兩個套件:

終端進入專案資料夾中運行:


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);
  }
 }

之後用就實例化呼叫方法就可以了。

總結

您可能感興趣的文章:

PHP receiveMail實現收郵件功能php實例

PHP分享圖片的產生方法php技巧

laravel 5.4 vue vux element的環境搭配過程介紹php實例

#

以上是laravel中簡訊發送驗證碼的實作方法php實例的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn