vpay_notify.class.php 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121
  1. <?php
  2. /* *
  3. * 类名:EpayNotify
  4. * 功能:微易支付通知处理类
  5. * 详细:处理支付接口通知返回
  6. */
  7. require_once("vpay_core.function.php");
  8. require_once("vpay_md5.function.php");
  9. class AlipayNotify {
  10. var $alipay_config;
  11. function __construct($alipay_config){
  12. $this->alipay_config = $alipay_config;
  13. $this->http_verify_url = $this->alipay_config['apiurl'].'api.php?';
  14. }
  15. function AlipayNotify($alipay_config) {
  16. $this->__construct($alipay_config);
  17. }
  18. /**
  19. * 针对notify_url验证消息是否是支付宝发出的合法消息
  20. * @return 验证结果
  21. */
  22. function verifyNotify(){
  23. if(empty($_GET)) {//判断POST来的数组是否为空
  24. return false;
  25. }
  26. else {
  27. //生成签名结果
  28. $isSign = $this->getSignVeryfy($_GET, $_GET["sign"]);
  29. //获取支付宝远程服务器ATN结果(验证是否是支付宝发来的消息)
  30. $responseTxt = 'true';
  31. //if (! empty($_POST["notify_id"])) {$responseTxt = $this->getResponse($_POST["notify_id"]);}
  32. //验证
  33. //$responsetTxt的结果不是true,与服务器设置问题、合作身份者ID、notify_id一分钟失效有关
  34. //isSign的结果不是true,与安全校验码、请求时的参数格式(如:带自定义参数等)、编码格式有关
  35. if (preg_match("/true$/i",$responseTxt) && $isSign) {
  36. return true;
  37. } else {
  38. return false;
  39. }
  40. }
  41. }
  42. /**
  43. * 针对return_url验证消息是否是支付宝发出的合法消息
  44. * @return 验证结果
  45. */
  46. function verifyReturn(){
  47. if(empty($_GET)) {//判断POST来的数组是否为空
  48. return false;
  49. }
  50. else {
  51. //生成签名结果
  52. $isSign = $this->getSignVeryfy($_GET, $_GET["sign"]);
  53. //获取支付宝远程服务器ATN结果(验证是否是支付宝发来的消息)
  54. $responseTxt = 'true';
  55. //if (! empty($_GET["notify_id"])) {$responseTxt = $this->getResponse($_GET["notify_id"]);}
  56. //验证
  57. //$responsetTxt的结果不是true,与服务器设置问题、合作身份者ID、notify_id一分钟失效有关
  58. //isSign的结果不是true,与安全校验码、请求时的参数格式(如:带自定义参数等)、编码格式有关
  59. if (preg_match("/true$/i",$responseTxt) && $isSign) {
  60. return true;
  61. } else {
  62. return false;
  63. }
  64. }
  65. }
  66. /**
  67. * 获取返回时的签名验证结果
  68. * @param $para_temp 通知返回来的参数数组
  69. * @param $sign 返回的签名结果
  70. * @return 签名验证结果
  71. */
  72. function getSignVeryfy($para_temp, $sign) {
  73. //除去待签名参数数组中的空值和签名参数
  74. $para_filter = paraFilter($para_temp);
  75. //对待签名参数数组排序
  76. $para_sort = argSort($para_filter);
  77. //把数组所有元素,按照“参数=参数值”的模式用“&”字符拼接成字符串
  78. $prestr = createLinkstring($para_sort);
  79. $isSgin = false;
  80. $isSgin = md5Verify($prestr, $sign, $this->alipay_config['key']);
  81. return $isSgin;
  82. }
  83. /**
  84. * 获取远程服务器ATN结果,验证返回URL
  85. * @param $notify_id 通知校验ID
  86. * @return 服务器ATN结果
  87. * 验证结果集:
  88. * invalid命令参数不对 出现这个错误,请检测返回处理中partner和key是否为空
  89. * true 返回正确信息
  90. * false 请检查防火墙或者是服务器阻止端口问题以及验证时间是否超过一分钟
  91. */
  92. function getResponse($notify_id) {
  93. $transport = strtolower(trim($this->alipay_config['transport']));
  94. $partner = trim($this->alipay_config['partner']);
  95. $veryfy_url = '';
  96. if($transport == 'https') {
  97. $veryfy_url = $this->https_verify_url;
  98. }
  99. else {
  100. $veryfy_url = $this->http_verify_url;
  101. }
  102. $veryfy_url = $veryfy_url."partner=" . $partner . "&notify_id=" . $notify_id;
  103. $responseTxt = getHttpResponseGET($veryfy_url, $this->alipay_config['cacert']);
  104. return $responseTxt;
  105. }
  106. }
  107. ?>