Pay.php 7.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | ThinkAdmin
  4. // +----------------------------------------------------------------------
  5. // | 版权所有 2014~2019 广州楚才信息科技有限公司 [ http://www.cuci.cc ]
  6. // +----------------------------------------------------------------------
  7. // | 官方网站: http://demo.thinkadmin.top
  8. // +----------------------------------------------------------------------
  9. // | 开源协议 ( https://mit-license.org )
  10. // +----------------------------------------------------------------------
  11. // | gitee 代码仓库:https://gitee.com/zoujingli/ThinkAdmin
  12. // | github 代码仓库:https://github.com/zoujingli/ThinkAdmin
  13. // +----------------------------------------------------------------------
  14. namespace app\api\controller;
  15. use EasyWeChat\Factory;
  16. use think\Controller;
  17. use think\Db;
  18. use think\Exception;
  19. use app\api\controller\Evaluate;
  20. use AlibabaCloud\Client\AlibabaCloud;
  21. use AlibabaCloud\Client\Exception\ClientException;
  22. use AlibabaCloud\Client\Exception\ServerException;
  23. /**
  24. * 支付管理类
  25. * Class Refund
  26. * @package app\api\controller\Refund
  27. */
  28. class Pay extends Controller
  29. {
  30. //小程序微信支付(type为1时是货主端微信配置,type为2时是接单端微信配置)
  31. public static function wxPay($name='订单支付',$out_trade_no,$total_fee,$notify_url,$trade_type = 'JSAPI',$openid,$type = 1){
  32. try{
  33. if(empty($out_trade_no) || empty($total_fee) || empty($notify_url)) return false;
  34. if($type == 1){
  35. $app = Factory::payment(config('app.wx_pay'));
  36. }else{
  37. $app = Factory::payment(config('app.worker_wx_pay'));
  38. }
  39. $parameter = array(
  40. 'body' => $name,
  41. 'out_trade_no' => $out_trade_no,
  42. 'total_fee' => $total_fee*100,
  43. 'notify_url' => $notify_url, // 支付结果通知网址,如果不设置则会使用配置里的默认地址
  44. 'trade_type' => $trade_type, // 请对应换成你的支付方式对应的值类型
  45. );
  46. if($trade_type != 'APP'){
  47. $parameter['openid'] = $openid;
  48. }
  49. $result = $app->order->unify($parameter);
  50. $jssdk = $app->jssdk;
  51. $config = $jssdk->sdkConfig($result['prepay_id']);
  52. return $config;
  53. }catch (Exception $e){
  54. return false;
  55. }
  56. }
  57. /**
  58. * 商品订单支付回调
  59. */
  60. public function goodsOrderNotify()
  61. {
  62. $app = Factory::payment(config('app.wx_pay'));
  63. $response = $app->handlePaidNotify(function ($message, $fail) {
  64. $this->payResultLog($message,'goods_order');
  65. // 使用通知里的 "微信支付订单号" 或者 "商户订单号" 去自己的数据库找到订单
  66. $pay_no = $message['out_trade_no'];
  67. $order_info = Db::name('goods_order')->where('pay_no',$pay_no)->find();
  68. // 如果订单不存在 或者 订单已经支付过了 告诉微信,我已经处理完了,订单没找到,别再通知我了
  69. if ($message['result_code'] == 'SUCCESS') { // return_code 表示通信状态,不代表支付状态
  70. Db::startTrans();
  71. $goods_info = Db::table('store_goods')->find($order_info['goods_id']);
  72. $collect_num = Db::table('goods_collect')
  73. ->where(['goods_id'=>$goods_info['id']])
  74. ->where('status','in',[1,3])->count();
  75. $serial = intval($collect_num) + 1;
  76. $user_info =Db::table('store_member')->find( $order_info['uid']);
  77. $collect_info = [
  78. 'user_id'=> $order_info['uid'],
  79. 'goods_id'=> $order_info['goods_id'],
  80. 'goods_cover'=> $order_info['goods_cover'],
  81. 'goods_name'=> $order_info['goods_name'],
  82. 'serial' => $serial,
  83. 'from_id' => $order_info['id'],
  84. 'sc_name' =>$user_info['name'],//收藏者
  85. 'issuer' =>$goods_info['issuer'],//发行方
  86. 'framer' =>$goods_info['goods_auth'],//framer
  87. 'coll_intro'=>$goods_info['coll_intro'],//作品介绍
  88. ];
  89. $collect_info = array_merge($collect_info,get_goods_hash($order_info['uid'],$goods_info['id'],$serial));
  90. Db::table('goods_collect')->insert($collect_info);
  91. goods_sell_info($goods_info,$order_info['uid'],$order_info['id']);
  92. $res = Db::table('goods_order')->where('id',$order_info['id'])->update(['pay_time'=>date('Y-m-d H:i:s'),'pay_state'=>1,'pay_type'=>1,'status'=>1]);
  93. if(!$res){
  94. Db::rollback();
  95. }else{
  96. Db::commit();
  97. }
  98. return true; // 返回处理完成
  99. } else if ($message['return_code'] != 'SUCCESS'){
  100. return $fail('通信失败,请稍后再通知我');
  101. }
  102. });
  103. $response->send();
  104. }
  105. /**
  106. *元石充值
  107. */
  108. public function crystalRecharge()
  109. {
  110. $app = Factory::payment(config('app.wx_pay'));
  111. $response = $app->handlePaidNotify(function ($message, $fail) {
  112. $this->payResultLog($message,'crystal_order');
  113. // 使用通知里的 "微信支付订单号" 或者 "商户订单号" 去自己的数据库找到订单
  114. $pay_no = $message['out_trade_no'];
  115. $order_info = Db::name('crystal_order')->where('pay_no',$pay_no)->find();
  116. // 如果订单不存在 或者 订单已经支付过了 告诉微信,我已经处理完了,订单没找到,别再通知我了
  117. if ($message['result_code'] == 'SUCCESS') { // return_code 表示通信状态,不代表支付状态
  118. Db::startTrans();
  119. $user_info = Db::table('store_member')->find($order_info['uid']);
  120. // 更新会员余额
  121. Db::table('store_member')->where('id',$order_info['uid'])->update(['crystal'=>bcadd($user_info['crystal'],$order_info['crystal'],2)]);
  122. // 元石明细
  123. crystal_log($order_info['uid'],$order_info['crystal'],'元石充值',1,$order_info['id']);
  124. // 更新订单状态
  125. $res = Db::table('crystal_order')->where('id',$order_info['id'])
  126. ->update(['pay_at'=>date('Y-m-d H:i:s'),'pay_state'=>1,'pay_type'=>1,'status'=>1]);
  127. if(!$res){
  128. Db::rollback();
  129. }else{
  130. Db::commit();
  131. }
  132. return true; // 返回处理完成
  133. } else if ($message['return_code'] != 'SUCCESS'){
  134. return $fail('通信失败,请稍后再通知我');
  135. }
  136. });
  137. $response->send();
  138. }
  139. /**
  140. * 记录支付日志
  141. * @param $message
  142. * @param $table_name
  143. */
  144. public function payResultLog($message,$table_name)
  145. {
  146. // 回调记录
  147. $ret_arr = [];
  148. $ret_arr['transaction_id'] = isset($message['transaction_id']) ?$message['transaction_id']: '';
  149. $ret_arr['trade_no'] = isset($message['out_trade_no']) ?$message['out_trade_no']: '';
  150. $ret_arr['return_code'] = isset($message['return_code']) ?$message['return_code']: '';
  151. $ret_arr['result_code'] = isset($message['result_code']) ?$message['result_code']: '';
  152. $ret_arr['create_at'] = date('Y-m-d H:i:s');
  153. $ret_arr['order_table'] = $table_name;
  154. $ret_arr['result'] = json_encode($message);
  155. Db::table('order_pay_result')->insert($ret_arr);
  156. }
  157. }