alipay_notify.class.php 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140
  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. class AlipayNotify {
  16. /**
  17. * HTTPS形式消息验证地址
  18. */
  19. var $https_verify_url = 'https://www.alipay.com/cooperate/gateway.do?service=notify_verify&';
  20. /**
  21. * HTTP形式消息验证地址
  22. */
  23. var $http_verify_url = 'http://notify.alipay.com/trade/notify_query.do?';
  24. var $aliapy_config;
  25. function __construct($aliapy_config){
  26. $this->aliapy_config = $aliapy_config;
  27. }
  28. function AlipayNotify($aliapy_config) {
  29. $this->__construct($aliapy_config);
  30. }
  31. /**
  32. * 针对notify_url验证消息是否是兑换宝发出的合法消息
  33. * @return 验证结果
  34. */
  35. function verifyNotify(){
  36. if(empty($_POST)) {//判断POST来的数组是否为空
  37. return false;
  38. }
  39. else {
  40. //生成签名结果
  41. $mysign = $this->getMysign($_POST);
  42. //获取兑换宝远程服务器ATN结果(验证是否是兑换宝发来的消息)
  43. $responseTxt = 'true';
  44. if (! empty($_POST["notify_id"])) {$responseTxt = $this->getResponse($_POST["notify_id"]);}
  45. //写日志记录
  46. //$log_text = "responseTxt=".$responseTxt."\n notify_url_log:sign=".$_POST["sign"]."&mysign=".$mysign.",";
  47. //$log_text = $log_text.createLinkString($_POST);
  48. //logResult($log_text);
  49. //验证
  50. //$responsetTxt的结果不是true,与服务器设置问题、合作身份者ID、notify_id一分钟失效有关
  51. //mysign与sign不等,与安全校验码、请求时的参数格式(如:带自定义参数等)、编码格式有关
  52. if (preg_match("/true$/i",$responseTxt) && $mysign == $_POST["sign"]) {
  53. return true;
  54. } else {
  55. return false;
  56. }
  57. }
  58. }
  59. /**
  60. * 针对return_url验证消息是否是兑换宝发出的合法消息
  61. * @return 验证结果
  62. */
  63. function verifyReturn(){
  64. if(empty($_GET)) {//判断POST来的数组是否为空
  65. return false;
  66. }
  67. else {
  68. //生成签名结果
  69. $mysign = $this->getMysign($_GET);
  70. //获取兑换宝远程服务器ATN结果(验证是否是兑换宝发来的消息)
  71. $responseTxt = 'true';
  72. if (! empty($_GET["notify_id"])) {$responseTxt = $this->getResponse($_GET["notify_id"]);}
  73. //写日志记录
  74. //$log_text = "responseTxt=".$responseTxt."\n notify_url_log:sign=".$_GET["sign"]."&mysign=".$mysign.",";
  75. //$log_text = $log_text.createLinkString($_GET);
  76. //logResult($log_text);
  77. //验证
  78. //$responsetTxt的结果不是true,与服务器设置问题、合作身份者ID、notify_id一分钟失效有关
  79. //mysign与sign不等,与安全校验码、请求时的参数格式(如:带自定义参数等)、编码格式有关
  80. if (preg_match("/true$/i",$responseTxt) && $mysign == $_GET["sign"]) {
  81. return true;
  82. } else {
  83. return false;
  84. }
  85. }
  86. }
  87. /**
  88. * 根据反馈回来的信息,生成签名结果
  89. * @param $para_temp 通知返回来的参数数组
  90. * @return 生成的签名结果
  91. */
  92. function getMysign($para_temp) {
  93. //除去待签名参数数组中的空值和签名参数
  94. $para_filter = paraFilter($para_temp);
  95. //对待签名参数数组排序
  96. $para_sort = argSort($para_filter);
  97. //生成签名结果
  98. $mysign = buildMysign($para_sort, trim($this->aliapy_config['key']), strtoupper(trim($this->aliapy_config['sign_type'])));
  99. return $mysign;
  100. }
  101. /**
  102. * 获取远程服务器ATN结果,验证返回URL
  103. * @param $notify_id 通知校验ID
  104. * @return 服务器ATN结果
  105. * 验证结果集:
  106. * invalid命令参数不对 出现这个错误,请检测返回处理中partner和key是否为空
  107. * true 返回正确信息
  108. * false 请检查防火墙或者是服务器阻止端口问题以及验证时间是否超过一分钟
  109. */
  110. function getResponse($notify_id) {
  111. $transport = strtolower(trim($this->aliapy_config['transport']));
  112. $partner = trim($this->aliapy_config['partner']);
  113. $veryfy_url = '';
  114. if($transport == 'https') {
  115. $veryfy_url = $this->https_verify_url;
  116. }
  117. else {
  118. $veryfy_url = $this->http_verify_url;
  119. }
  120. $veryfy_url = $veryfy_url."partner=" . $partner . "&notify_id=" . $notify_id;
  121. $responseTxt = getHttpResponse($veryfy_url);
  122. return $responseTxt;
  123. }
  124. }
  125. ?>