之前阿里大于短信用着挺爽的,也挺方便,,自从迁移到阿里云之后,各种不好找,虽然功能强大了。体验太差了
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* 必填, 短信签名,应严格"签名名称"填写,参考:短信签名页 *
* @param string $templateCode* 必填, 短信模板Code,应严格按"模板CODE"填写, 参考:短信模板页 * (e.g. SMS_0001) *
* @param string $phoneNumbers 必填, 短信接收号码 (e.g. 12345678901) * @param array|null $templateParam* 选填, 假如模板中存在变量需要替换则为必填项 (e.g. Array("code"=>"12345", "product"=>"阿里通信")) *
* @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";
}