国内流行的内容管理系统(CMS)多端全媒体解决方案 https://www.dedebiz.com
No puede seleccionar más de 25 temas Los temas deben comenzar con una letra o número, pueden incluir guiones ('-') y pueden tener hasta 35 caracteres de largo.

83 líneas
3.8KB

  1. <?php
  2. /**
  3. * 支付返回页
  4. *
  5. * @version $id:return.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. if ($moRow['product'] === "card") {
  44. $row = $dsql->GetOne("SELECT * FROM `#@__moneycard_type` WHERE tid='{$moRow['pid']}'");
  45. $query = "UPDATE `#@__member_operation` SET sta = '2' WHERE buyid = '$buyid'";
  46. $dsql->ExecuteNoneQuery($query);
  47. $query = "UPDATE `#@__member` SET money = money+{$row['num']} WHERE mid = '{$moRow['mid']}'";
  48. $dsql->ExecuteNoneQuery($query);
  49. } else if ($moRow['product'] === "member") {
  50. $row = $dsql->GetOne("SELECT * FROM `#@__member_type` WHERE aid='{$moRow['pid']}'");
  51. $rank = $row['rank'];
  52. $exptime = $row['exptime'];
  53. $rs = $dsql->GetOne("SELECT uptime,exptime FROM `#@__member` WHERE mid='".$moRow['mid']."'");
  54. if ($rs['uptime']!=0 && $rs['exptime']!=0) {
  55. $nowtime = time();
  56. $mhasDay = $rs['exptime'] - ceil(($nowtime - $rs['uptime'])/3600/24) + 1;
  57. $mhasDay=($mhasDay>0)? $mhasDay : 0;
  58. }
  59. $memrank = $dsql->GetOne("SELECT money,scores FROM `#@__arcrank` WHERE `rank`='$rank'");
  60. //更新会员信息
  61. $sqlm = "UPDATE `#@__member` SET `rank`='$rank',`money`=`money`+'{$memrank['money']}',scores=scores+'{$memrank['scores']}',exptime='$exptime'+'$mhasDay',uptime='".time()."' WHERE mid='".$moRow['mid']."'";
  62. $sqlmo = "UPDATE `#@__member_operation` SET sta='2',oldinfo='会员升级成功' WHERE buyid='{$moRow['pid']}' ";
  63. if (!($dsql->ExecuteNoneQuery($sqlm) && $dsql->ExecuteNoneQuery($sqlmo))) {
  64. ShowMsg("升级会员失败", "javascript:;");
  65. exit;
  66. }
  67. }
  68. ShowMsg("已经完成付款", $cfg_memberurl."/index.php");
  69. exit;
  70. }
  71. } else {
  72. ShowMsg("尚未完成付款操作", $cfg_memberurl."/index.php");
  73. exit;
  74. }
  75. } catch (Exception $e) {
  76. ShowMsg("付款失败,请检查支付接口设置", "javascript:;");
  77. exit;
  78. }
  79. } else {
  80. ShowMsg("未知付款,请检查支付接口设置", "javascript:;");
  81. exit;
  82. }
  83. ?>