您的位置:首页 > 其它

【短信接口】阿里大于迁移到阿里云之后使用方法

2017-08-15 10:03 801 查看
之前阿里大于短信用着挺爽的,也挺方便,,自从迁移到阿里云之后,各种不好找,虽然功能强大了。体验太差了

PS: 之前我自己玩在阿里大于充了五块钱的短信,后来找不到了。虽是小钱,但是他们却没处理好。

特写此笔记,指引你前行!



1 首先下载 短信接口SDK
https://help.aliyun.com/document_detail/55359.html?spm=5176.doc56189.6.569.B9djtA
解压 文件目录如下:



2 部署:

api_sdk 是整个文档的库文件,留存,

进入api_demo 文件夹 ,把这个文件复制一份出来 :smsdemo.php,命名: Alisms.class.php

把文件里下方的调用实例删除

最终形成的目录: sms 文件夹



Alisms.class.php文件内容: 绿色部分我修改过,可根据项目自行修改路径

<?php

ini_set("display_errors", "on");

require_once (ROOT_PATH . 'sms/api_sdk/vendor/autoload.php');
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;

// 加载区域结点配置
Config::load();

/**
* Class Sms
*
* athor: 依然范儿特西
* todo: 阿里大于短信接口
*/
class Alisms
{

/**
* 构造器
*
* @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 string $signName <p>
* 必填, 短信签名,应严格"签名名称"填写,参考:<a href="https://dysms.console.aliyun.com/dysms.htm#/sign">短信签名页</a>
* </p>
* @param string $templateCode <p>
* 必填, 短信模板Code,应严格按"模板CODE"填写, 参考:<a href="https://dysms.console.aliyun.com/dysms.htm#/template">短信模板页</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;

}

/**
* 查询短信发送情况范例
*
* @param string $phoneNumbers 必填, 短信接收号码 (e.g. 12345678901)
* @param string $sendDate 必填,短信发送日期,格式Ymd,支持近30天记录查询 (e.g. 20170710)
* @param int $pageSize 必填,分页大小
* @param int $currentPage 必填,当前页码
* @param string $bizId 选填,短信发送流水号 (e.g. abc123)
* @return stdClass
*/
public function queryDetails($phoneNumbers, $sendDate, $pageSize = 10, $currentPage = 1, $bizId=null) {

// 初始化QuerySendDetailsRequest实例用于设置短信查询的参数
$request = new QuerySendDetailsRequest();

// 必填,短信接收号码
$request->setPhoneNumber($phoneNumbers);

// 选填,短信发送流水号
$request->setBizId($bizId);

// 必填,短信发送日期,支持近30天记录查询,格式Ymd
$request->setSendDate($sendDate);

// 必填,分页大小
$request->setPageSize($pageSize);

// 必填,当前页码
$request->setCurrentPage($currentPage);

// 发起访问请求
$acsResponse = $this->acsClient->getAcsResponse($request);

// 打印请求结果
// var_dump($acsResponse);

return $acsResponse;
}

}


3 调用实例: 绿色部分修改过,要根据你短信模板的值来改

/* 发送手机验证码 */
require_once (ROOT_PATH . 'sms/Alisms.class.php');
header('Content-Type: text/plain; charset=utf-8');
$demo = new Alisms(
"",  // AccessKeyID
""   //AccessKeySecret
);
$mobile_code =""; //验证码
$response = $demo->sendSms(
"", // 短信签名
"", // 短信模板编号
"", // 短信接收者,多个手机号用英文逗号隔开
Array(  // 短信模板中字段的值
"number"=>$mobile_code
),
"123"
);

$result = $response->Code;
if($result == 'OK'){
echo "success";
  }else{
echo "fail";
  }
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: