alipay_notify_url.php 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142
  1. <?php
  2. /* *
  3. * 功能:支付宝服务器异步通知页面
  4. * 版本:3.3
  5. * 日期:2012-07-23
  6. * 说明:
  7. * 以下代码只是为了方便商户测试而提供的样例代码,商户可以根据自己网站的需要,按照技术文档编写,并非一定要使用该代码。
  8. * 该代码仅供学习和研究支付宝接口使用,只是提供一个参考。
  9. *************************页面功能说明*************************
  10. * 创建该页面文件时,请留心该页面文件中无任何HTML代码及空格。
  11. * 该页面不能在本机电脑测试,请到服务器上做测试。请确保外部可以访问该页面。
  12. * 该页面调试工具请使用写文本函数logResult,该函数已被默认关闭,见alipay_notify_class.php中的函数verifyNotify
  13. * 如果没有收到该页面返回的 success 信息,支付宝会在24小时内按一定的时间策略重发通知
  14. */
  15. define('ALIPAY_PATH', BASE_MOBILE_PATH . '/api/payment/alipay');
  16. require_once(ALIPAY_PATH . "/alipay.config.php");
  17. require_once(ALIPAY_PATH . "/lib/alipay_notify.class.php");
  18. require_once('control/app_pay.php');
  19. Log::record(">>>>>ENTER alipay_notify_url : out_trade_no={$out_trade_no}");
  20. //计算得出通知验证结果
  21. $alipayNotify = new AlipayNotify($alipay_config);
  22. $verify_result = $alipayNotify->verifyNotify();
  23. if ($verify_result) {//验证成功
  24. Log::record(">>>>>verify notify success : out_trade_no={$out_trade_no}");
  25. //商户订单号
  26. $out_trade_no = $_POST['out_trade_no'];
  27. //支付宝交易号
  28. $trade_no = $_POST['trade_no'];
  29. //交易状态
  30. $trade_status = $_POST['trade_status'];
  31. // 交易完成
  32. if ($_POST['trade_status'] == 'TRADE_FINISHED') { // 交易成功
  33. //判断该笔订单是否在商户网站中已经做过处理
  34. //如果没有做过处理,根据订单号(out_trade_no)在商户网站的订单系统中查到该笔订单的详细,并执行商户的业务程序
  35. //如果有做过处理,不执行商户的业务程序
  36. //注意:
  37. //退款日期超过可退款期限后(如三个月可退款),支付宝系统发送该交易状态通知
  38. //请务必判断请求时的total_fee、seller_id与通知时获取的total_fee、seller_id为一致的
  39. //调试用,写文本函数记录程序运行情况是否正常
  40. //logResult("这里写入想要调试的代码变量值,或其他运行的结果记录");
  41. // 支付类型
  42. $payment_type = $_POST['payment_type'];
  43. // 交易金额
  44. $total_fee = $_POST['total_fee'];
  45. // 购买数量
  46. $quantity = $_POST['quantity'];
  47. // 商品单价
  48. $price = $_POST['price'];
  49. // 交易付款时间
  50. $gmt_payment = $_POST['gmt_payment'];
  51. // 支付宝支付金额检查
  52. // $ret = app_payControl::alipay_check();
  53. $cb_info = app_payControl::update_order($out_trade_no, $trade_no, 'alipay');
  54. if ($cb_info['state'] == false) {
  55. fcgi_echo('fail');
  56. Log::record(">>>>alipay fail: trade_no={$trade_no}");
  57. } else {
  58. fcgi_echo('success');
  59. Log::record(">>>>>alipay success: trade_no={$trade_no}");
  60. }
  61. } else if ($_POST['trade_status'] == 'TRADE_SUCCESS') { // 交易成功
  62. //判断该笔订单是否在商户网站中已经做过处理
  63. //如果没有做过处理,根据订单号(out_trade_no)在商户网站的订单系统中查到该笔订单的详细,并执行商户的业务程序
  64. //如果有做过处理,不执行商户的业务程序
  65. //注意:
  66. //付款完成后,支付宝系统发送该交易状态通知
  67. //请务必判断请求时的total_fee、seller_id与通知时获取的total_fee、seller_id为一致的
  68. //调试用,写文本函数记录程序运行情况是否正常
  69. //logResult("这里写入想要调试的代码变量值,或其他运行的结果记录");
  70. // 支付类型
  71. $payment_type = $_POST['payment_type'];
  72. // 交易金额
  73. $total_fee = $_POST['total_fee'];
  74. // 购买数量
  75. $quantity = $_POST['quantity'];
  76. // 商品单价
  77. $price = $_POST['price'];
  78. // 交易付款时间
  79. $gmt_payment = $_POST['gmt_payment'];
  80. $cb_info = app_payControl::update_order($out_trade_no, $trade_no, 'alipay');
  81. if ($cb_info['state'] == false) {
  82. fcgi_echo('fail');
  83. Log::record(">>>>alipay success: trade_no={$trade_no}");
  84. } else {
  85. fcgi_echo('success');
  86. Log::record(">>>>>alipay success: trade_no={$trade_no}");
  87. }
  88. } else if ($_POST['trade_status'] == 'WAIT_BUYER_PAY'){ // 交易创建
  89. }
  90. //——请根据您的业务逻辑来编写程序(以上代码仅作参考)——
  91. fcgi_echo("success"); //请不要修改或删除
  92. Log::record(">>>>>alipay success: out_trade_no={$out_trade_no}");
  93. /////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
  94. } else {
  95. //验证失败
  96. fcgi_echo("fail");
  97. Log::record(">>>>verify notify fail : out_trade_no={$out_trade_no}");
  98. //调试用,写文本函数记录程序运行情况是否正常
  99. }
  100. ?>