MsgDemo.php 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171
  1. <?php
  2. ini_set("display_errors", "on");
  3. require_once dirname(__DIR__) . '/msg_sdk/vendor/autoload.php';
  4. require_once __DIR__ . '/lib/TokenGetterForAlicom.php';
  5. require_once __DIR__ . '/lib/TokenForAlicom.php';
  6. use Aliyun\Core\Config;
  7. use AliyunMNS\Exception\MnsException;
  8. use AliyunMNS\Requests\BatchReceiveMessageRequest; // 批量拉取请求
  9. // 加载区域结点配置
  10. Config::load();
  11. /**
  12. * Class MsgDemo
  13. */
  14. class MsgDemo
  15. {
  16. /**
  17. * @var TokenGetterForAlicom
  18. */
  19. static $tokenGetter = null;
  20. public static function getTokenGetter() {
  21. $accountId = "1943695596114318"; // 此处不需要替换修改!
  22. // TODO 此处需要替换成开发者自己的AK (https://ak-console.aliyun.com/)
  23. $accessKeyId = "yourAccessKeyId"; // AccessKeyId
  24. $accessKeySecret = "yourAccessKeySecret"; // AccessKeySecret
  25. if(static::$tokenGetter == null) {
  26. static::$tokenGetter = new TokenGetterForAlicom(
  27. $accountId,
  28. $accessKeyId,
  29. $accessKeySecret);
  30. }
  31. return static::$tokenGetter;
  32. }
  33. /**
  34. * 获取消息
  35. *
  36. * @param string $messageType 消息类型
  37. * @param string $queueName 在云通信页面开通相应业务消息后,就能在页面上获得对应的queueName<br/>(e.g. Alicom-Queue-xxxxxx-xxxxxReport)
  38. * @param callable $callback <p>
  39. * 回调仅接受一个消息参数;
  40. * <br/>回调返回true,则工具类自动删除已拉取的消息;
  41. * <br/>回调返回false,消息不删除可以下次获取.
  42. * <br/>(e.g. function ($message) { return true; }
  43. * </p>
  44. */
  45. public static function receiveMsg($messageType, $queueName, callable $callback)
  46. {
  47. $i = 0;
  48. // 取回执消息失败3次则停止循环拉取
  49. while ( $i < 3)
  50. {
  51. try
  52. {
  53. // 取临时token
  54. $tokenForAlicom = static::getTokenGetter()->getTokenByMessageType($messageType, $queueName);
  55. // 使用MNSClient得到Queue
  56. $queue = $tokenForAlicom->getClient()->getQueueRef($queueName);
  57. // ------------------------------------------------------------------
  58. // 1. 单次接收消息,并根据实际情况设置超时时间
  59. $message = $queue->receiveMessage(2);
  60. // 计算消息体的摘要用作校验
  61. $bodyMD5 = strtoupper(md5(base64_encode($message->getMessageBody())));
  62. // 比对摘要,防止消息被截断或发生错误
  63. if ($bodyMD5 == $message->getMessageBodyMD5())
  64. {
  65. // 执行回调
  66. if(call_user_func($callback, json_decode($message->getMessageBody())))
  67. {
  68. // 当回调返回真值时,删除已接收的信息
  69. $receiptHandle = $message->getReceiptHandle();
  70. $queue->deleteMessage($receiptHandle);
  71. }
  72. }
  73. // ------------------------------------------------------------------
  74. // ------------------------------------------------------------------
  75. // 2. 批量接收消息
  76. // $res = $queue->batchReceiveMessage(new BatchReceiveMessageRequest(10, 5)); // 每次拉取10条,超时等待时间5秒
  77. // /* @var \AliyunMNS\Model\Message[] $messages */
  78. // $messages = $res->getMessages();
  79. // foreach($messages as $message) {
  80. // // 计算消息体的摘要用作校验
  81. // $bodyMD5 = strtoupper(md5(base64_encode($message->getMessageBody())));
  82. // // 比对摘要,防止消息被截断或发生错误
  83. // if ($bodyMD5 == $message->getMessageBodyMD5())
  84. // {
  85. // // 执行回调
  86. // if(call_user_func($callback, json_decode($message->getMessageBody())))
  87. // {
  88. // // 当回调返回真值时,删除已接收的信息
  89. // $receiptHandle = $message->getReceiptHandle();
  90. // $queue->deleteMessage($receiptHandle);
  91. // }
  92. // }
  93. // }
  94. // ------------------------------------------------------------------
  95. return; // 整个取回执消息流程完成后退出
  96. }
  97. catch (MnsException $e)
  98. {
  99. $i++;
  100. echo "ex:{$e->getMnsErrorCode()}\n";
  101. echo "ReceiveMessage Failed: {$e}\n";
  102. }
  103. }
  104. }
  105. }
  106. // 调用示例:
  107. header('Content-Type: text/plain; charset=utf-8');
  108. echo "消息接口查阅短信状态报告返回结果:\n";
  109. MsgDemo::receiveMsg(
  110. // 消息类型,SmsReport: 短信状态报告
  111. "SmsReport",
  112. // 在云通信页面开通相应业务消息后,就能在页面上获得对应的queueName
  113. "Alicom-Queue-xxxxxxxx-SmsReport",
  114. /**
  115. * 回调
  116. * @param stdClass $message 消息数据
  117. * @return bool 返回true,则工具类自动删除已拉取的消息。返回false,消息不删除可以下次获取
  118. */
  119. function ($message) {
  120. print_r($message);
  121. return false;
  122. }
  123. );
  124. echo "消息接口查阅短信服务上行返回结果:\n";
  125. MsgDemo::receiveMsg(
  126. // 消息类型,SmsUp: 短信服务上行
  127. "SmsUp",
  128. // 在云通信页面开通相应业务消息后,就能在页面上获得对应的queueName
  129. "Alicom-Queue-xxxxxxxx-SmsUp",
  130. /**
  131. * 回调
  132. * @param stdClass $message 消息数据
  133. * @return bool 返回true,则工具类自动删除已拉取的消息。返回false,消息不删除可以下次获取
  134. */
  135. function ($message) {
  136. print_r($message);
  137. return false;
  138. }
  139. );