Alipay_bak.php 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345
  1. <?php
  2. namespace app\api\controller;
  3. use addons\epay\library\Service;
  4. use app\api\model\CoinRecord;
  5. use app\api\model\Delivery;
  6. use app\api\model\DeliveryTrade;
  7. use app\api\model\Order;
  8. use app\api\model\Prizerecord;
  9. use app\api\model\RechargeOrder;
  10. use app\common\controller\Frontend;
  11. use think\Db;
  12. /**
  13. * 支付宝支付接口
  14. * Class Alipay
  15. * @package app\api\controller
  16. * @version 1.0
  17. * @author fuyelk <fuyelk@fuyelk.com>
  18. */
  19. class Alipay extends Frontend
  20. {
  21. protected $noNeedLogin = ['notifyx', 'boxpaysuccess', 'rechargesuccess'];
  22. protected $noNeedRight = ['*'];
  23. /**
  24. * 盲盒订单支付
  25. * @throws \Exception
  26. * @author fuyelk <fuyelk@fuyelk.com>
  27. */
  28. public function boxpay($orderid = '')
  29. {
  30. if (empty($orderid)) {
  31. $this->error('订单ID不能为空');
  32. }
  33. $order = Order::where('id', $orderid)->where('user_id', $this->auth->id)->where('status', 'unpay')->find();
  34. if (empty($order)) {
  35. $this->error('订单有误', '');
  36. }
  37. $params = [
  38. 'amount' => $order->rmb_amount,
  39. 'orderid' => $order->out_trade_no,
  40. 'type' => "alipay",
  41. 'title' => $order->box_name,
  42. 'notifyurl' => $this->request->domain() . '/api/alipay/notifyx/orderfrom/buybox',
  43. 'returnurl' => $this->request->domain() . '/api/alipay/boxpaysuccess',
  44. 'method' => "wap",
  45. ];
  46. $query = input('get.');
  47. if (isset($query['orderid'])) {
  48. unset($query['orderid']);
  49. }
  50. $this->auth->redis->set($order->out_trade_no, $query, 60 * 30); // 将参数存入缓存,30分钟
  51. echo \addons\epay\library\Service::submitOrder($params);
  52. }
  53. /**
  54. * 充值订单支付
  55. * @throws \Exception
  56. * @author fuyelk <fuyelk@fuyelk.com>
  57. */
  58. public function rechargepay($orderid = '')
  59. {
  60. if (empty($orderid)) {
  61. $this->error('订单ID不能为空');
  62. }
  63. $order = RechargeOrder::where('id', $orderid)->where('user_id', $this->auth->id)->where('status', 'unpay')->find();
  64. if (empty($order)) {
  65. $this->error('订单有误', '');
  66. }
  67. $params = [
  68. 'amount' => $order->rmb_amount,
  69. 'orderid' => $order->out_trade_no,
  70. 'type' => "alipay",
  71. 'title' => '充值',
  72. 'notifyurl' => $this->request->domain() . '/api/alipay/notifyx/orderfrom/recharge',
  73. 'returnurl' => $this->request->domain() . '/api/alipay/rechargesuccess',
  74. 'method' => "wap",
  75. ];
  76. $query = input('get.');
  77. if (isset($query['orderid'])) {
  78. unset($query['orderid']);
  79. }
  80. $this->auth->redis->set($order->out_trade_no, $query, 60 * 30); // 将参数存入缓存,30分钟
  81. echo \addons\epay\library\Service::submitOrder($params);
  82. }
  83. /**
  84. * 发货订单支付
  85. * @throws \Exception
  86. * @author fuyelk <fuyelk@fuyelk.com>
  87. */
  88. public function deliverypay($orderid = '')
  89. {
  90. if (empty($orderid)) {
  91. $this->error('订单ID不能为空');
  92. }
  93. $order = DeliveryTrade::where('id', $orderid)->where('user_id', $this->auth->id)->where('status', 'unpay')->find();
  94. if (empty($order)) {
  95. $this->error('订单有误', '');
  96. }
  97. $params = [
  98. 'amount' => $order->rmb_amount,
  99. 'orderid' => $order->out_trade_no,
  100. 'type' => "alipay",
  101. 'title' => '快递费用',
  102. 'notifyurl' => $this->request->domain() . '/api/alipay/notifyx/orderfrom/delivery',
  103. 'returnurl' => $this->request->domain() . '/api/alipay/deliverypaysuccess',
  104. 'method' => "wap",
  105. ];
  106. $query = input('get.');
  107. if (isset($query['orderid'])) {
  108. unset($query['orderid']);
  109. }
  110. $this->auth->redis->set($order->out_trade_no, $query, 60 * 30); // 将参数存入缓存,30分钟
  111. echo \addons\epay\library\Service::submitOrder($params);
  112. }
  113. /**
  114. * 盲盒、充值支付回调
  115. */
  116. public function notifyx($orderfrom = '')
  117. {
  118. // 回调只能来自于购买盲盒和充值
  119. if (!in_array($orderfrom, ['buybox', 'recharge', 'delivery'])) {
  120. dta(input(), '支付宝回调有误');
  121. echo '请求有误';
  122. return;
  123. }
  124. $pay = Service::checkNotify('alipay');
  125. if (!$pay) {
  126. dta('支付宝签名错误', __METHOD__ . ' ' . __LINE__);
  127. echo '签名错误';
  128. return;
  129. }
  130. Db::startTrans();
  131. try {
  132. $data = $pay->verify()->toArray();
  133. $usefulTemplate = array(
  134. 'invoice_amount' => '12.34',
  135. 'trade_status' => 'TRADE_SUCCESS',
  136. 'receipt_amount' => '12.34',
  137. 'buyer_pay_amount' => '12.34',
  138. 'notify_time' => '2021-07-16 14:40:39',
  139. 'out_trade_no' => '20210716144024',
  140. 'total_amount' => '12.34',
  141. 'trade_no' => '2021071622001413960501380461',
  142. );
  143. if ('TRADE_SUCCESS' != strtoupper($data['trade_status'])) {
  144. dta(array_intersect_key($data, $usefulTemplate), '支付宝支付失败');
  145. echo '支付失败';
  146. return;
  147. }
  148. // 购买盲盒订单,更新盲盒订单
  149. if ('buybox' == $orderfrom) {
  150. $order = Order::where('out_trade_no', $data['out_trade_no'])->where('status', 'unpay')->find();
  151. if (empty($order)) {
  152. dta(array_intersect_key($data, $usefulTemplate), '订单有误,支付失败');
  153. echo '支付失败';
  154. return;
  155. }
  156. $order->save([
  157. 'pay_method' => 'alipay',
  158. 'pay_rmb' => $data['total_amount'],
  159. 'alipay_trade_no' => $data['trade_no'],
  160. 'pay_time' => time(),
  161. 'status' => 'unused',
  162. 'backend_read' => 0,
  163. ]);
  164. }
  165. // 充值订单
  166. if ('recharge' == $orderfrom) {
  167. $order = RechargeOrder::where('out_trade_no', $data['out_trade_no'])->where('status', 'unpay')->find();
  168. if (empty($order)) {
  169. dta(array_intersect_key($data, $usefulTemplate), '订单有误,支付失败');
  170. echo '支付失败';
  171. return;
  172. }
  173. $order->save([
  174. 'pay_method' => 'alipay',
  175. 'pay_rmb' => $data['total_amount'],
  176. 'alipay_trade_no' => $data['trade_no'],
  177. 'pay_time' => time(),
  178. 'status' => 'paid',
  179. 'backend_read' => 0,
  180. ]);
  181. $user = \app\common\model\User::where('id', $order->user_id)->find();
  182. // 给账户充值前
  183. $coin_before = $user->coin;
  184. // 增加金币余额
  185. $user->setInc('coin', $order->coin_amount);
  186. // 创建金币记录
  187. CoinRecord::create([
  188. 'user_id' => $user->id,
  189. 'before' => $coin_before,
  190. 'after' => $user->coin,
  191. 'coin' => $order->coin_amount,
  192. 'order_id' => $order->id,
  193. 'type' => 'recharge', // 变更类型:pay_box=支付盲盒,recharge=充值,fromwallet=余额转入,refund=退款
  194. ]);
  195. }
  196. // 发货订单
  197. if ('delivery' == $orderfrom) {
  198. $trade = DeliveryTrade::where('out_trade_no', $data['out_trade_no'])->where('status', 'unpay')->find();
  199. if (empty($trade)) {
  200. dta(array_intersect_key($data, $usefulTemplate), '订单有误,支付失败');
  201. echo '支付失败';
  202. return;
  203. }
  204. // 变更发货交易订单状态
  205. $trade->save([
  206. 'pay_method' => 'alipay',
  207. 'pay_rmb' => $data['total_amount'],
  208. 'alipay_trade_no' => $data['trade_no'],
  209. 'pay_time' => time(),
  210. 'status' => 'paid'
  211. ]);
  212. // 变更发货订单状态
  213. $deliveryOrder = Delivery::where('delivery_trade_id', $trade->id)->select();
  214. $prizeIds = [];
  215. foreach ($deliveryOrder as $order) {
  216. $order->save(['status' => 'undelivered']);
  217. $prizeIds[] = $order->prize_id;
  218. }
  219. // 变更奖品状态
  220. Prizerecord::whereIn('id', $prizeIds)->update(['status' => 'delivery', 'delivery_time' => time()]);
  221. }
  222. } catch (\Exception $e) {
  223. Db::rollback();
  224. dta($e->getMessage(), '支付宝回调执行出错');
  225. echo '错误';
  226. return;
  227. }
  228. Db::commit();
  229. echo $pay->success();
  230. }
  231. /**
  232. * 盲盒支付成功后用户会被重定向到这里
  233. * @author fuyelk <fuyelk@fuyelk.com>
  234. */
  235. public function boxpaysuccess()
  236. {
  237. $out_trade_no = $this->request->param('out_trade_no');
  238. $pay = Service::checkReturn('alipay');
  239. // 读取缓存里的参数
  240. $query = $this->auth->redis->get($out_trade_no);
  241. if (!$query || !is_array($query)) {
  242. $query = [];
  243. }
  244. $query['status'] = 1;
  245. if (!$pay) {
  246. $query['status'] = 0;
  247. }
  248. $query['out_trade_no'] = $out_trade_no;
  249. $params = http_build_query($query);
  250. // 将用户重定向到前端页面
  251. $this->redirect($this->request->domain() . "/h5/#/pagesA/pages/camera?" . $params);
  252. }
  253. /**
  254. * 充值支付成功后用户会被重定向到这里
  255. * @author fuyelk <fuyelk@fuyelk.com>
  256. */
  257. public function rechargesuccess()
  258. {
  259. $out_trade_no = $this->request->param('out_trade_no');
  260. $pay = Service::checkReturn('alipay');
  261. // 读取缓存里的参数
  262. $query = $this->auth->redis->get($out_trade_no);
  263. if (!$query || !is_array($query)) {
  264. $query = [];
  265. }
  266. $query['status'] = 1;
  267. if (!$pay) {
  268. $query['status'] = 0;
  269. }
  270. $params = http_build_query($query);
  271. // 将用户重定向到前端页面
  272. $this->redirect($this->request->domain() . "/h5/#/pages/me/wallet?" . $params);
  273. }
  274. /**
  275. * 发货订单支付成功后用户会被重定向到这里
  276. * @author fuyelk <fuyelk@fuyelk.com>
  277. */
  278. public function deliverypaysuccess()
  279. {
  280. $out_trade_no = $this->request->param('out_trade_no');
  281. $pay = Service::checkReturn('alipay');
  282. // 读取缓存里的参数
  283. $query = $this->auth->redis->get($out_trade_no);
  284. if (!$query || !is_array($query)) {
  285. $query = [];
  286. }
  287. $query['status'] = 1;
  288. if (!$pay) {
  289. $query['status'] = 0;
  290. }
  291. $params = http_build_query($query);
  292. // 将用户重定向到前端页面
  293. $this->redirect($this->request->domain() . "/h5/#/pages/me/order?type=0?" . $params);
  294. }
  295. }