国内流行的内容管理系统(CMS)多端全媒体解决方案 https://www.dedebiz.com
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

91 lines
3.5KB

  1. <?php
  2. /**
  3. * 支付回调
  4. *
  5. * @version $id:notify.php$
  6. * @package DedeBIZ.Site
  7. * @copyright Copyright (c) 2023 DedeBIZ.COM
  8. * @license https://www.dedebiz.com/license
  9. * @link https://www.dedebiz.com
  10. */
  11. require_once(dirname(__FILE__)."/../system/common.inc.php");
  12. $dopost = isset($dopost)? $dopost : '';
  13. $buyid = isset($out_trade_no)? HtmlReplace($out_trade_no, 1) : '';
  14. if ($dopost === 'alipay') {
  15. $moRow = $dsql->GetOne("SELECT * FROM `#@__member_operation` WHERE buyid='$buyid'");
  16. if (empty($moRow)) {
  17. ShowMsg("订单查询错误,请确保是您自己发起的订单", "javascript:;");
  18. exit;
  19. }
  20. if ($moRow['sta'] == 2) {
  21. ShowMsg("已完成支付,无需重复付款", "javascript:;");
  22. exit;
  23. }
  24. $pInfo = $dsql->GetOne("SELECT * FROM `#@__sys_payment` WHERE id = 2");
  25. $pData = (array)json_decode($pInfo['config']);
  26. $config = array(
  27. "sign_type" => $pData['SignType'],
  28. "appid" => $pData['APPID'],
  29. "private_key" => $pData['PrivateKey'],
  30. "public_key" => $pData['CertPublicKey'],
  31. );
  32. //支付宝
  33. try {
  34. // 实例支付对象
  35. $pay = \AliPay\Web::instance($config);
  36. unset($_REQUEST['dopost']);
  37. unset($_REQUEST['sign_type']);
  38. $data = $pay->notify(false, $_REQUEST);
  39. if (isset($data['trade_no']) && !empty($data['trade_no'])) {
  40. // $pay = \AliPay\Transfer::instance($config);
  41. $result = $pay->query($data['out_trade_no']);
  42. if ($result['trade_status']=== "TRADE_SUCCESS") {
  43. $row = $dsql->GetOne("SELECT * FROM `#@__moneycard_type` WHERE tid='{$moRow['pid']}'");
  44. $query = "UPDATE `#@__member_operation` SET sta = '2' WHERE buyid = '$buyid'";
  45. $dsql->ExecuteNoneQuery($query);
  46. $query = "UPDATE `#@__member` SET money = money+{$row['num']} WHERE mid = '{$moRow['mid']}'";
  47. $dsql->ExecuteNoneQuery($query);
  48. ShowMsg("已经完成付款", $cfg_memberurl."/index.php");
  49. exit;
  50. }
  51. } else {
  52. ShowMsg("尚未完成付款操作", $cfg_memberurl."/index.php");
  53. exit;
  54. }
  55. } catch (Exception $e) {
  56. ShowMsg("付款错误", "javascript:;");
  57. exit;
  58. }
  59. } else if ($dopost === 'wechat') {
  60. $pInfo = $dsql->GetOne("SELECT * FROM `#@__sys_payment` WHERE id = 1");
  61. $pData = (array)json_decode($pInfo['config']);
  62. $config = array(
  63. "appid" => $pData['AppID'],
  64. "mch_id" => $pData['MchID'],
  65. "mch_key" => $pData['APIv2Secret'],
  66. );
  67. $wechat = new \WeChat\Pay($config);
  68. $data = $wechat->getNotify();
  69. if ($data['return_code'] === 'SUCCESS' && $data['result_code'] === 'SUCCESS') {
  70. $buyid = $data['out_trade_no'];
  71. $moRow = $dsql->GetOne("SELECT * FROM `#@__member_operation` WHERE buyid='$buyid'");
  72. if (empty($moRow)) {
  73. ShowMsg("订单查询错误,请确保是您自己发起的订单", "javascript:;");
  74. exit;
  75. }
  76. $row = $dsql->GetOne("SELECT * FROM `#@__moneycard_type` WHERE tid='{$moRow['pid']}'");
  77. $query = "UPDATE `#@__member_operation` SET sta = '2' WHERE buyid = '$buyid'";
  78. $dsql->ExecuteNoneQuery($query);
  79. $query = "UPDATE `#@__member` SET money = money+{$row['num']} WHERE mid = '{$moRow['mid']}'";
  80. $dsql->ExecuteNoneQuery($query);
  81. echo "success";
  82. exit;
  83. } else {
  84. echo "error";
  85. exit;
  86. }
  87. } else {
  88. ShowMsg("未知支付方式", "javascript:;");
  89. exit;
  90. }
  91. ?>