Lumen集成最新版(截止到20170810)阿里大于

說明:本文采用的環境為Lumen5.4,阿里大于官方SDK(非框架組件)

1. 去官網下載最新版阿里大于SDK

下載地址:最新版阿里大于SDK

2. 將SDK整合到項目中

說明: 以下存放目錄可以改變,但要注意配置加載的路徑,建議和我一樣.

以下是我的存放目錄結構:


官方SDK目錄結構.png

自己封裝整理的發送驗證碼類:

<?php
/**
 * Created by cxs
 * User: cxy
 * Date: 17-8-1
 * Time: 上午10:52
 */

namespace App\Tools\AliYun\Message;

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 Aliyun\Core\Regions\EndpointProvider;

// 加載區域結點配置(重點,切勿忘記)
Config::load();

/**
 * 用于發送驗證碼的類
 *
 * Class SendMessage
 * @package App\Tools\AliYun\Message
 */
class SendMessage
{
    /**
     * 構造器
     *
     * @param string $accessKeyId 必填,AccessKeyId
     * @param string $accessKeySecret 必填,AccessKeySecret
     */
    public function __construct()
    {

        $accessKeyId = env('ACCESSKEYID');
        $accessKeySecret = env('ACCESSKEYSECRET');

        // 短信API產品名
        $product = "Dysmsapi";

        // 短信API產品域名
        $domain = "dysmsapi.aliyuncs.com";

        // 暫時不支持多Region
        $region = "cn-hangzhou";
        //$region = "cn-beijing";

        // 服務結點
        $endPointName = "cn-hangzhou";

        // 初始化用戶Profile實例
        $profile = DefaultProfile::getProfile($region, $accessKeyId, $accessKeySecret);


        // 增加服務結點
        DefaultProfile::addEndpoint($endPointName, $region, $product, $domain);

        // 初始化AcsClient用于發起請求
        $this->acsClient = new DefaultAcsClient($profile);
    }

    /**
     * 發送短信范例
     *
     * @param string $signName <p>
     * 必填, 短信簽名,應嚴格"簽名名稱"填寫,參考:<a >短信簽名頁</a>
     * </p>
     * @param string $templateCode <p>
     * 必填, 短信模板Code,應嚴格按"模板CODE"填寫, 參考:<a >短信模板頁</a>
     * (e.g. SMS_0001)
     * </p>
     * @param string $phoneNumbers 必填, 短信接收號碼 (e.g. 12345678901)
     * @param array|null $templateParam <p>
     * 選填, 假如模板中存在變量需要替換則為必填項 (e.g. Array("code"=>"12345", "product"=>"阿里通信"))
     * </p>
     * @param string|null $outId [optional] 選填, 發送短信流水號 (e.g. 1234)
     * @return stdClass
     */
    public function sendSms($signName, $templateCode, $phoneNumbers, $templateParam = null, $outId = null) {

        // 初始化SendSmsRequest實例用于設置發送短信的參數
        $request = new SendSmsRequest();

        // 必填,設置雉短信接收號碼
        $request->setPhoneNumbers($phoneNumbers);

        // 必填,設置簽名名稱
        $request->setSignName($signName);

        // 必填,設置模板CODE
        $request->setTemplateCode($templateCode);

        // 可選,設置模板參數
        if($templateParam) {
            $request->setTemplateParam(json_encode($templateParam));
        }

        // 可選,設置流水號
        if($outId) {
            $request->setOutId($outId);
        }

        // 發起訪問請求
        $acsResponse = $this->acsClient->getAcsResponse($request);

        // 打印請求結果
        // var_dump($acsResponse);

        return $acsResponse;

    }
}

3. 在項目根目錄的composer.json中加入sdk存放路徑

composer.json.png

4. 在項目根目錄執行composer install

composer install

5. env文件配置

ACCESSKEYID=Access Key ID
ACCESSKEYSECRET=Access Key Secret
ALIYUN_SMS_SING=模板簽名
ALIYUN_SMS_VIEW_CODE=模版CODE

6. 驗證碼發送飛起(在Lumen中的寫法,Laravel中類似,基本上差不多)

use App\Tools\AliYun\Message\SendMessage;

/**
     * 最新版阿里大于獲取驗證碼的方法
     *
     * @param $phone
     * @return \Illuminate\Http\Response|\Laravel\Lumen\Http\ResponseFactory
     */
    public function sendSms($phone)
    {
        // 判斷條件是否合法
        if (empty($phone)) {
            return ['ServerNo' => 400, 'ResultData' => '參數錯誤'];
        }

        // 驗證填寫手機號是否正確
        $phoneNum = Common::checkCellphone($phone);
        if (!$phoneNum) {
            return ['ServerNo' => 400, 'ResultData' => '不正確的手機號碼'];
        }

        // 短信簽名
        $smsSing = env('ALIYUN_SMS_SING');

        // 短信模板編號
        $smsViewId = env('ALIYUN_SMS_VIEW_CODE');

        $verificationCode = rand(100000,999999);

        //選填-假如模板中存在變量需要替換則為必填
        $smsParams = [
            "number"    => "$verificationCode"
        ];

        // 選填, 發送短信流水號
        $streamNo = time();

        // 調用發送短信的方法
        $response = self::$sendMessage->sendSms($smsSing, $smsViewId, $phone, $smsParams, $streamNo);


        if ($response->Code == 'OK' || $response->Code == 'ok') {
            // 發送成功
            // 存cache
            $time = $_SERVER['REQUEST_TIME'] + self::$lift;
            app('cache')->put(self::$tel . $phone, $verificationCode, $time);
            app('log')->info(json_encode(self::$tel . $phone, $verificationCode));
            app('log')->info(json_encode($verificationCode));
            return ['ServerNo' => 200, 'ResultData' => $verificationCode];
        } else {
            // 發送失敗
            return ['ServerNo' => 400, 'ResultData' => '發送驗證碼錯誤!'];
        }
    }
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容