AlipayNotify.class.php 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145
  1. <?php
  2. /* *
  3. * 类名:AlipayNotify
  4. * 功能:支付宝通知处理类
  5. * 详细:处理支付宝各接口通知返回
  6. * 版本:3.2
  7. * 日期:2011-03-25
  8. * 说明:
  9. * 以下代码只是为了方便商户测试而提供的样例代码,商户可以根据自己网站的需要,按照技术文档编写,并非一定要使用该代码。
  10. * 该代码仅供学习和研究支付宝接口使用,只是提供一个参考
  11. *************************注意*************************
  12. * 调试通知返回时,可查看或改写log日志的写入TXT里的数据,来检查通知返回是否正常
  13. */
  14. require_once("alipay_core.function.php");
  15. require_once("alipay_md5.function.php");
  16. require_once("alipay_rsa.function.php");
  17. class AlipayNotify {
  18. /**
  19. * HTTPS形式消息验证地址
  20. */
  21. var $https_verify_url = 'https://mapi.alipay.com/gateway.do?service=notify_verify&';
  22. /**
  23. * HTTP形式消息验证地址
  24. */
  25. var $http_verify_url = 'http://notify.alipay.com/trade/notify_query.do?';
  26. var $alipay_config;
  27. function __construct($alipay_config) {
  28. $this->alipay_config = $alipay_config;
  29. }
  30. function AlipayNotify($alipay_config) {
  31. $this->__construct($alipay_config);
  32. }
  33. /**
  34. * 针对notify_url验证消息是否是支付宝发出的合法消息
  35. *
  36. *
  37. */
  38. function verifyNotify() {
  39. if (empty($_POST)) {//判断POST来的数组是否为空
  40. return false;
  41. } else {
  42. //生成签名结果
  43. $isSign = $this->getSignVerify($_POST, $_POST["sign"], $_POST['sign_type']);
  44. //获取支付宝远程服务器ATN结果(验证是否是支付宝发来的消息)
  45. $responseTxt = 'true';
  46. if (!empty($_POST["notify_id"])) {
  47. $responseTxt = $this->getResponse($_POST["notify_id"]);
  48. }
  49. //验证
  50. //$responsetTxt的结果不是true,与服务器设置问题、合作身份者ID、notify_id一分钟失效有关
  51. //isSign的结果不是true,与安全校验码、请求时的参数格式(如:带自定义参数等)、编码格式有关
  52. if (preg_match("/true$/i", $responseTxt) && $isSign) {
  53. return true;
  54. } else {
  55. return false;
  56. }
  57. }
  58. }
  59. /**
  60. * 针对return_url验证消息是否是支付宝发出的合法消息
  61. *
  62. * @return bool 验证结果
  63. */
  64. function verifyReturn() {
  65. if (empty($_GET)) {//判断POST来的数组是否为空
  66. return false;
  67. } else {
  68. //生成签名结果
  69. $isSign = $this->getSignVerify($_GET, $_GET["sign"], $_GET["sign_type"]);
  70. //获取支付宝远程服务器ATN结果(验证是否是支付宝发来的消息)
  71. $responseTxt = 'true';
  72. if (!empty($_GET["notify_id"])) {
  73. $responseTxt = $this->getResponse($_GET["notify_id"]);
  74. }
  75. if (preg_match("/true$/i", $responseTxt) && $isSign) {
  76. return true;
  77. } else {
  78. return false;
  79. }
  80. }
  81. }
  82. /**
  83. * 获取返回时的签名验证结果
  84. *
  85. * @param array $para_temp 通知返回来的参数数组
  86. * @param string $sign 返回的签名结果
  87. *
  88. * @param string $sign_type 签名类型
  89. *
  90. * @return bool 验证结果
  91. */
  92. function getSignVerify($para_temp, $sign, $sign_type) {
  93. //除去待签名参数数组中的空值和签名参数
  94. $para_filter = paraFilter($para_temp);
  95. //对待签名参数数组排序
  96. $para_sort = argSort($para_filter);
  97. //把数组所有元素,按照“参数=参数值”的模式用“&”字符拼接成字符串
  98. $_pre_str = createLinkString($para_sort);
  99. switch (strtoupper(trim($sign_type))) {
  100. case "MD5" :
  101. $_sign_rs = md5Verify($_pre_str, $sign, $this->alipay_config['key']);
  102. break;
  103. case "RSA" :
  104. $_sign_rs = rsaVerify($_pre_str, $sign, $this->alipay_config['public_key_path']);
  105. break;
  106. default :
  107. $_sign_rs = false;
  108. }
  109. return $_sign_rs;
  110. }
  111. /**
  112. * 获取远程服务器ATN结果,验证返回URL
  113. *
  114. * @param string $notify_id 通知校验ID
  115. *
  116. * @return mixed 服务器ATN结果
  117. *
  118. * 验证结果集:* 验证结果集:
  119. * invalid命令参数不对 出现这个错误,请检测返回处理中partner和key是否为空
  120. * true 返回正确信息
  121. * false 请检查防火墙或者是服务器阻止端口问题以及验证时间是否超过一分钟
  122. */
  123. function getResponse($notify_id) {
  124. $transport = strtolower(trim($this->alipay_config['transport']));
  125. $partner = trim($this->alipay_config['partner']);
  126. if ($transport == 'https') {
  127. $verify_url = $this->https_verify_url;
  128. } else {
  129. $verify_url = $this->http_verify_url;
  130. }
  131. $verify_url = $verify_url."partner=".$partner."&notify_id=".$notify_id;
  132. $responseTxt = getHttpResponseGET($verify_url, $this->alipay_config['cacert']);
  133. return $responseTxt;
  134. }
  135. }