tp5短信接口的使用


阿里大魚短信配置非常簡單,只需引入阿里大魚完整SDK,然后在自己的項目里面引用SDK目錄autoload.php文件,然后在接口調用demo接口就好了!

一,先說具體實現方法,最后附加源碼包!

1.下載SDK,接口在阿里大魚官網,本人使用版本為2017年10月下載,不保證后續官方SDK會相同,本人SDK版本地址百度雲: 密碼: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接口代碼,需要的網友可以直接下載 密碼: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="";

//暫時不支持多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引入不正確。

轉載於:

PHP程序員


免責聲明!

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



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