SmsDemo.php 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187
  1. <?php
  2. // ini_set("display_errors", "on");
  3. require_once __DIR__ . '/api_sdk/vendor/autoload.php';
  4. use Aliyun\Core\Config;
  5. use Aliyun\Core\Profile\DefaultProfile;
  6. use Aliyun\Core\DefaultAcsClient;
  7. use Aliyun\Api\Sms\Request\V20170525\SendSmsRequest;
  8. use Aliyun\Api\Sms\Request\V20170525\QuerySendDetailsRequest;
  9. // 加载区域结点配置
  10. Config::load();
  11. /**
  12. * Class SmsDemo
  13. *
  14. * Created on 17/10/17.
  15. * 短信服务API产品的DEMO程序,工程中包含了一个SmsDemo类,直接通过
  16. * 执行此文件即可体验语音服务产品API功能(只需要将AK替换成开通了云通信-短信服务产品功能的AK即可)
  17. * 备注:Demo工程编码采用UTF-8
  18. */
  19. class SmsDemo
  20. {
  21. static $acsClient = null;
  22. /**
  23. * 取得AcsClient
  24. *
  25. * @return DefaultAcsClient
  26. */
  27. public static function getAcsClient() {
  28. //产品名称:云通信流量服务API产品,开发者无需替换
  29. $product = "Dysmsapi";
  30. //产品域名,开发者无需替换
  31. $domain = "dysmsapi.aliyuncs.com";
  32. // TODO 此处需要替换成开发者自己的AK (https://ak-console.aliyun.com/)
  33. $accessKeyId = "LTAIVw9XVaF4nPch"; // AccessKeyId
  34. $accessKeySecret = "R7gq2EPE1qUbpF6EHB4uaakXmoT34M"; // AccessKeySecret
  35. // 暂时不支持多Region
  36. $region = "cn-hangzhou";
  37. // 服务结点
  38. $endPointName = "cn-hangzhou";
  39. if(static::$acsClient == null) {
  40. //初始化acsClient,暂不支持region化
  41. $profile = DefaultProfile::getProfile($region, $accessKeyId, $accessKeySecret);
  42. // 增加服务结点
  43. DefaultProfile::addEndpoint($endPointName, $region, $product, $domain);
  44. // 初始化AcsClient用于发起请求
  45. static::$acsClient = new DefaultAcsClient($profile);
  46. }
  47. return static::$acsClient;
  48. }
  49. /**
  50. * 发送短信
  51. *
  52. * @param string $signName <p>
  53. * 必填, 短信签名,应严格"签名名称"填写,参考:<a href="https://dysms.console.aliyun.com/dysms.htm#/sign">短信签名页</a>
  54. * </p>
  55. * @param string $templateCode <p>
  56. * 必填, 短信模板Code,应严格按"模板CODE"填写, 参考:<a href="https://dysms.console.aliyun.com/dysms.htm#/template">短信模板页</a>
  57. * (e.g. SMS_0001)
  58. * </p>
  59. * @param string $phoneNumbers 必填, 短信接收号码 (e.g. 12345678901)
  60. * @param array|null $templateParam <p>
  61. * 选填, 假如模板中存在变量需要替换则为必填项 (e.g. Array("code"=>"12345", "product"=>"阿里通信"))
  62. * </p>
  63. * @param string|null $outId [optional] 选填, 发送短信流水号 (e.g. 1234)
  64. * @return stdClass
  65. */
  66. public static function sendSms($signName, $templateCode, $phoneNumbers, $templateParam = null, $outId = null) {
  67. // 初始化SendSmsRequest实例用于设置发送短信的参数
  68. $request = new SendSmsRequest();
  69. // 必填,设置雉短信接收号码
  70. $request->setPhoneNumbers($phoneNumbers);
  71. // 必填,设置签名名称
  72. $request->setSignName($signName);
  73. // 必填,设置模板CODE
  74. $request->setTemplateCode($templateCode);
  75. // 可选,设置模板参数
  76. if($templateParam) {
  77. $request->setTemplateParam(json_encode($templateParam));
  78. }
  79. // 可选,设置流水号
  80. if($outId) {
  81. $request->setOutId($outId);
  82. }
  83. // 发起访问请求
  84. $acsResponse = static::getAcsClient()->getAcsResponse($request);
  85. // 打印请求结果
  86. // var_dump($acsResponse);
  87. return $acsResponse;
  88. }
  89. /**
  90. * 短信发送记录查询
  91. *
  92. * @param string $phoneNumbers 必填, 短信接收号码 (e.g. 12345678901)
  93. * @param string $sendDate 必填,短信发送日期,格式Ymd,支持近30天记录查询 (e.g. 20170710)
  94. * @param int $pageSize 必填,分页大小
  95. * @param int $currentPage 必填,当前页码
  96. * @param string $bizId 选填,短信发送流水号 (e.g. abc123)
  97. * @return stdClass
  98. */
  99. public function queryDetails($phoneNumbers, $sendDate, $pageSize = 10, $currentPage = 1, $bizId=null) {
  100. // 初始化QuerySendDetailsRequest实例用于设置短信查询的参数
  101. $request = new QuerySendDetailsRequest();
  102. // 必填,短信接收号码
  103. $request->setPhoneNumber($phoneNumbers);
  104. // 选填,短信发送流水号
  105. $request->setBizId($bizId);
  106. // 必填,短信发送日期,支持近30天记录查询,格式Ymd
  107. $request->setSendDate($sendDate);
  108. // 必填,分页大小
  109. $request->setPageSize($pageSize);
  110. // 必填,当前页码
  111. $request->setCurrentPage($currentPage);
  112. // 发起访问请求
  113. $acsResponse = static::getAcsClient()->getAcsResponse($request);
  114. // 打印请求结果
  115. // var_dump($acsResponse);
  116. return $acsResponse;
  117. }
  118. }
  119. // 调用示例:
  120. // set_time_limit(0);
  121. // header('Content-Type: text/plain; charset=utf-8');
  122. // $response = SmsDemo::sendSms(
  123. // "豹哥健身", // 短信签名
  124. // "SMS_107890013", // 短信模板编号
  125. // "15913196454", // 短信接收者
  126. // Array( // 短信模板中字段的值
  127. // "code"=>"8886",
  128. // // "product"=>"dsd"
  129. // ),
  130. // "001" // 流水号,选填
  131. // );
  132. // echo "发送短信(sendSms)接口返回的结果:\n";
  133. // print_r($response);
  134. // sleep(2);
  135. // $response = SmsDemo::queryDetails(
  136. // "15913196454", // phoneNumbers 电话号码
  137. // "20171102", // sendDate 发送时间
  138. // 10, // pageSize 分页大小
  139. // 1 // currentPage 当前页码
  140. // // "abcd" // bizId 短信发送流水号,选填
  141. // );
  142. // echo "查询短信发送情况(queryDetails)接口返回的结果:\n";
  143. // print_r($response);