說明:本文采用的環(huán)境為Lumen5.4,阿里大于官方SDK(非框架組件)
1. 去官網(wǎng)下載最新版阿里大于SDK
下載地址:最新版阿里大于SDK
2. 將SDK整合到項目中
說明: 以下存放目錄可以改變,但要注意配置加載的路徑,建議和我一樣.
以下是我的存放目錄結(jié)構(gòu):
自己封裝整理的發(fā)送驗證碼類:
<?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;
// 加載區(qū)域結(jié)點配置(重點,切勿忘記)
Config::load();
/**
* 用于發(fā)送驗證碼的類
*
* Class SendMessage
* @package App\Tools\AliYun\Message
*/
class SendMessage
{
/**
* 構(gòu)造器
*
* @param string $accessKeyId 必填匙隔,AccessKeyId
* @param string $accessKeySecret 必填,AccessKeySecret
*/
public function __construct()
{
$accessKeyId = env('ACCESSKEYID');
$accessKeySecret = env('ACCESSKEYSECRET');
// 短信API產(chǎn)品名
$product = "Dysmsapi";
// 短信API產(chǎn)品域名
$domain = "dysmsapi.aliyuncs.com";
// 暫時不支持多Region
$region = "cn-hangzhou";
//$region = "cn-beijing";
// 服務結(jié)點
$endPointName = "cn-hangzhou";
// 初始化用戶Profile實例
$profile = DefaultProfile::getProfile($region, $accessKeyId, $accessKeySecret);
// 增加服務結(jié)點
DefaultProfile::addEndpoint($endPointName, $region, $product, $domain);
// 初始化AcsClient用于發(fā)起請求
$this->acsClient = new DefaultAcsClient($profile);
}
/**
* 發(fā)送短信范例
*
* @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] 選填, 發(fā)送短信流水號 (e.g. 1234)
* @return stdClass
*/
public function sendSms($signName, $templateCode, $phoneNumbers, $templateParam = null, $outId = null) {
// 初始化SendSmsRequest實例用于設置發(fā)送短信的參數(shù)
$request = new SendSmsRequest();
// 必填苛秕,設置雉短信接收號碼
$request->setPhoneNumbers($phoneNumbers);
// 必填城看,設置簽名名稱
$request->setSignName($signName);
// 必填潘飘,設置模板CODE
$request->setTemplateCode($templateCode);
// 可選乐严,設置模板參數(shù)
if($templateParam) {
$request->setTemplateParam(json_encode($templateParam));
}
// 可選瘤袖,設置流水號
if($outId) {
$request->setOutId($outId);
}
// 發(fā)起訪問請求
$acsResponse = $this->acsClient->getAcsResponse($request);
// 打印請求結(jié)果
// var_dump($acsResponse);
return $acsResponse;
}
}
3. 在項目根目錄的composer.json中加入sdk存放路徑
4. 在項目根目錄執(zhí)行composer install
composer install
5. env文件配置
ACCESSKEYID=Access Key ID
ACCESSKEYSECRET=Access Key Secret
ALIYUN_SMS_SING=模板簽名
ALIYUN_SMS_VIEW_CODE=模版CODE
6. 驗證碼發(fā)送飛起(在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' => '參數(shù)錯誤'];
}
// 驗證填寫手機號是否正確
$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"
];
// 選填, 發(fā)送短信流水號
$streamNo = time();
// 調(diào)用發(fā)送短信的方法
$response = self::$sendMessage->sendSms($smsSing, $smsViewId, $phone, $smsParams, $streamNo);
if ($response->Code == 'OK' || $response->Code == 'ok') {
// 發(fā)送成功
// 存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 {
// 發(fā)送失敗
return ['ServerNo' => 400, 'ResultData' => '發(fā)送驗證碼錯誤!'];
}
}