阿里大魚短信配置非常簡單,只需引入阿里大魚完整SDK,然后在自己的項目里面引用SDK目錄autoload.php文件,然后在接口調用demo接口就好了!
一,先說具體實現方法,最后附加源碼包!
1.下載SDK,接口在阿里大魚官網,本人使用版本為2017年10月下載,不保證后續官方SDK會相同,本人SDK版本地址百度雲:http://pan.baidu.com/s/1eRPzmro 密碼:oy7c;下載后放到TP5擴展目錄extend下,如圖:
2,仿照SDK的demo,編寫自己的短信發送接口,這里的前提是引入SDK目錄autoload.php文件,APP_EXTEND宏定義目錄+SDK路徑;APP_EXTEND定義位置在入口文件index.php中,define('APP_EXTEND',__DIR__.'/extend/');
定義后,我們就可以引入SDK加載路徑了,我們在home控制器新建sms控制器,然后引入SDK需要的命名空間如圖
到這一步,引入SDK就完成了,剩下的就是復制sdk的 demo函數,構建一個自己的startSendSms()發送函數就行了。
下面是SMS接口代碼,需要的網友可以直接下載http://pan.baidu.com/s/1skGVp2t 密碼:5w1x
namespaceapp\home\controller;
usethink\Controller;
usethink\Session;
ini_set("display_errors","on");
require_onceAPP_EXTEND.'Alidayu/api_sdk/vendor/autoload.php';
useAliyun\Core\Config;
useAliyun\Core\Profile\DefaultProfile;
useAliyun\Core\DefaultAcsClient;
useAliyun\Api\Sms\Request\V20170525\SendSmsRequest;
useAliyun\Api\Sms\Request\V20170525\QuerySendDetailsRequest;
//加載區域結點配置
Config::load();
/**
* Class SmsDemo
*
*@property\Aliyun\Core\DefaultAcsClient acsClient
*/
classSmsextendsController
{
/**
*構造器
*
*@paramstring $accessKeyId必填,AccessKeyId
*@paramstring $accessKeySecret必填,AccessKeySecret
*/
public function__construct($accessKeyId='這里要寫你自己的短信accessKeyId',$accessKeySecret='這里要寫你自己的短信accessKeySecret')
{
//短信API產品名
$product="Dysmsapi";
//短信API產品域名
$domain="http://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=newDefaultAcsClient($profile);
}
/**
*發送短信范例
*
*@paramstring $signName
*必填,短信簽名,應嚴格"簽名名稱"填寫,參考:短信簽名頁
*
*@paramstring $templateCode
*必填,短信模板Code,應嚴格按"模板CODE"填寫,參考:短信模板頁
* (e.g. SMS_0001)
*
*@paramstring $phoneNumbers必填,短信接收號碼(e.g. 12345678901)
*@paramarray|null $templateParam
*選填,假如模板中存在變量需要替換則為必填項(e.g. Array("code"=>"12345", "product"=>"阿里通信"))
*
*@paramstring|null $outId [optional]選填,發送短信流水號(e.g. 1234)
*@returnstdClass
*/
public functionsendSms($signName,$templateCode,$phoneNumbers,$templateParam,$outId=null){
//初始化SendSmsRequest實例用於設置發送短信的參數
$request=newSendSmsRequest();
//必填,設置雉短信接收號碼
$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;
}
//調用發送短信接口
public function startSendSms(){ //這里是自己寫的發送函數,里面直接調用SDK的sendSms接口就行了
$signName='這里寫簽名';//簽名
$templateCode='這里寫短信模板';//短信模板 如:SMS_105200000
$mobile=input('phone');//傳遞的號碼
if($mobile==""){
returnApiError('手機號碼不能為空');
return;
}
if(checkMobile($mobile)){
returnApiError('手機號碼格式不正確');
return;
}
$phoneNumbers=$mobile;
$verifycode=strval(rand(1000,9999));//驗證碼數字4位 驗證碼按照自己需要編寫
$templateParam=array('code'=>$verifycode);
$result=$this->sendSms($signName,$templateCode,$phoneNumbers,$templateParam,$outId=null); //調用SDK接口
$result=json_decode(json_encode($result),true);
if($result['Message']!='OK'){
returnApiError('驗證碼發送失敗:'.$result['Message']);
return;
}
session('home_reg.verifycode',$verifycode);
session('home_reg.phone',$phoneNumbers);
session('home_reg.time',time()+600);//10分鍾
returnApiSuccess('驗證碼發送成功,請注意查收');
}
}
這樣整個短信配置就完成了,前端只需要調用你的這個sms/startSendSms接口就可以發短信了!可能會遇到的問題SDK autoload.PHP引入不正確。
轉載於: