123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180
  1. <?php
  2. ini_set("display_errors", "on");
  3. require_once dirname(__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. * @property \Aliyun\Core\DefaultAcsClient acsClient
  15. */
  16. class Sms
  17. {
  18. /**
  19. * 构造器
  20. *
  21. * @param string $accessKeyId 必填,AccessKeyId
  22. * @param string $accessKeySecret 必填,AccessKeySecret
  23. */
  24. public function __construct($accessKeyId, $accessKeySecret)
  25. {
  26. // 短信API产品名
  27. $product = "Dysmsapi";
  28. // 短信API产品域名
  29. $domain = "dysmsapi.aliyuncs.com";
  30. // 暂时不支持多Region
  31. $region = "cn-hangzhou";
  32. // 服务结点
  33. $endPointName = "cn-hangzhou";
  34. // 初始化用户Profile实例
  35. $profile = DefaultProfile::getProfile($region, $accessKeyId, $accessKeySecret);
  36. // 增加服务结点
  37. DefaultProfile::addEndpoint($endPointName, $region, $product, $domain);
  38. // 初始化AcsClient用于发起请求
  39. $this->acsClient = new DefaultAcsClient($profile);
  40. }
  41. /**
  42. * 发送短信范例
  43. *
  44. * @param string $signName <p>
  45. * 必填, 短信签名,应严格"签名名称"填写,参考:<a href="https://dysms.console.aliyun.com/dysms.htm#/sign">短信签名页</a>
  46. * </p>
  47. * @param string $templateCode <p>
  48. * 必填, 短信模板Code,应严格按"模板CODE"填写, 参考:<a href="https://dysms.console.aliyun.com/dysms.htm#/template">短信模板页</a>
  49. * (e.g. SMS_0001)
  50. * </p>
  51. * @param string $phoneNumbers 必填, 短信接收号码 (e.g. 12345678901)
  52. * @param array|null $templateParam <p>
  53. * 选填, 假如模板中存在变量需要替换则为必填项 (e.g. Array("code"=>"12345", "product"=>"阿里通信"))
  54. * </p>
  55. * @param string|null $outId [optional] 选填, 发送短信流水号 (e.g. 1234)
  56. * @return stdClass
  57. */
  58. public function sendSms($signName, $templateCode, $phoneNumbers, $templateParam = null, $outId = null) {
  59. // 初始化SendSmsRequest实例用于设置发送短信的参数
  60. $request = new SendSmsRequest();
  61. // 必填,设置雉短信接收号码
  62. $request->setPhoneNumbers($phoneNumbers);
  63. // 必填,设置签名名称
  64. $request->setSignName($signName);
  65. // 必填,设置模板CODE
  66. $request->setTemplateCode($templateCode);
  67. // 可选,设置模板参数
  68. if($templateParam) {
  69. $request->setTemplateParam(json_encode($templateParam));
  70. }
  71. // 可选,设置流水号
  72. if($outId) {
  73. $request->setOutId($outId);
  74. }
  75. // 发起访问请求
  76. $acsResponse = $this->acsClient->getAcsResponse($request);
  77. // 打印请求结果
  78. // var_dump($acsResponse);
  79. return $acsResponse;
  80. }
  81. /**
  82. * 查询短信发送情况范例
  83. *
  84. * @param string $phoneNumbers 必填, 短信接收号码 (e.g. 12345678901)
  85. * @param string $sendDate 必填,短信发送日期,格式Ymd,支持近30天记录查询 (e.g. 20170710)
  86. * @param int $pageSize 必填,分页大小
  87. * @param int $currentPage 必填,当前页码
  88. * @param string $bizId 选填,短信发送流水号 (e.g. abc123)
  89. * @return stdClass
  90. */
  91. public function queryDetails($phoneNumbers, $sendDate, $pageSize = 10, $currentPage = 1, $bizId=null) {
  92. // 初始化QuerySendDetailsRequest实例用于设置短信查询的参数
  93. $request = new QuerySendDetailsRequest();
  94. // 必填,短信接收号码
  95. $request->setPhoneNumber($phoneNumbers);
  96. // 选填,短信发送流水号
  97. $request->setBizId($bizId);
  98. // 必填,短信发送日期,支持近30天记录查询,格式Ymd
  99. $request->setSendDate($sendDate);
  100. // 必填,分页大小
  101. $request->setPageSize($pageSize);
  102. // 必填,当前页码
  103. $request->setCurrentPage($currentPage);
  104. // 发起访问请求
  105. $acsResponse = $this->acsClient->getAcsResponse($request);
  106. // 打印请求结果
  107. // var_dump($acsResponse);
  108. return $acsResponse;
  109. }
  110. }
  111. // 调用示例:
  112. //header('Content-Type: text/plain; charset=utf-8');
  113. //
  114. //$demo = new SmsDemo(
  115. // "yourAccessKeyId",
  116. // "yourAccessKeySecret"
  117. //);
  118. //
  119. //echo "SmsDemo::sendSms\n";
  120. //$response = $demo->sendSms(
  121. // "短信签名", // 短信签名
  122. // "SMS_0000001", // 短信模板编号
  123. // "12345678901", // 短信接收者
  124. // Array( // 短信模板中字段的值
  125. // "code"=>"12345",
  126. // "product"=>"dsd"
  127. // ),
  128. // "123"
  129. //);
  130. //print_r($response);
  131. //
  132. //echo "SmsDemo::queryDetails\n";
  133. //$response = $demo->queryDetails(
  134. // "12345678901", // phoneNumbers 电话号码
  135. // "20170718", // sendDate 发送时间
  136. // 10, // pageSize 分页大小
  137. // 1 // currentPage 当前页码
  138. // // "abcd" // bizId 短信发送流水号,选填
  139. //);
  140. //
  141. //print_r($response);