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 [
        '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 
  1. $phone 指接受短信方的短信號碼,
  2. $name 指短信簽名 可以在阿里大魚短信簽名 http://www.alidayu.com/admin/service/sign 找到
  3. $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); } }
 
        
之后用就實例化調用方法就可以了。

 

 

 

 

 
        

 

 
        





免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM