Notify.php 7.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173
  1. <?php
  2. namespace addons\service\controller;
  3. use think\addons\Controller;
  4. use addons\epay\library\Service;
  5. use app\api\model\service\PremiumOrder;
  6. use app\api\model\service\SkillEnsurePay;
  7. use app\api\model\service\Skill;
  8. use app\api\model\service\ShopEnsurePay;
  9. use app\api\model\service\Shop;
  10. use app\api\model\service\Order;
  11. use addons\service\library\WxPay;
  12. use app\api\model\service\AddOrder;
  13. use app\api\model\service\PlusPay;
  14. use app\common\model\User;
  15. use Exception;
  16. use think\Log;
  17. class Notify extends Controller
  18. {
  19. public function notifyx()
  20. {
  21. $paytype = $this->request->param('paytype');
  22. $pay = Service::checkNotify($paytype);
  23. if (!$pay) {
  24. echo '签名错误';
  25. return;
  26. }
  27. $data = Service::isVersionV3() ? $pay->callback() : $pay->verify();
  28. try {
  29. $payamount = $paytype == 'alipay' ? $data['total_amount'] : $data['total_fee'] / 100;
  30. $out_trade_no = $data['out_trade_no'];
  31. $trade_no = $data['transaction_id'];
  32. if (strpos($out_trade_no,'remium')){
  33. $info = db('service_premium_order')->field('id,user_id,payprice,state')->where('orderId',$out_trade_no)->find();
  34. if($info['state'] == 0){
  35. db('service_premium_order')->where('orderId',$out_trade_no)->update(['trade_no'=>$trade_no,'state'=>1,'paytime'=>time()]);
  36. (new PremiumOrder)->finishPay($info['id']);
  37. }
  38. }elseif (strpos($out_trade_no,'oodsOrd')){
  39. $info = db('service_order')->where('orderId',$out_trade_no)->find();
  40. if($info['status'] == 0){
  41. db('service_order')->where('orderId',$out_trade_no)->update(['trade_no'=>$trade_no,'status'=>1,'paytime'=>time()]);
  42. Order::finishPay($info['id']);
  43. }
  44. }elseif (strpos($out_trade_no,'oodsAdd')){
  45. $info = db('service_add_order')->where('orderId',$out_trade_no)->find();
  46. if($info['state'] == 0){
  47. db('service_add_order')->where('orderId',$out_trade_no)->update(['trade_no'=>$trade_no,'state'=>1,'paytime'=>time()]);
  48. AddOrder::finishPay($info['id']);
  49. }
  50. }elseif (strpos($out_trade_no,'echarge')){
  51. $info = db('service_recharge')->where('orderId',$out_trade_no)->find();
  52. if($info['state'] == 0){
  53. db('service_recharge')->where('orderId',$out_trade_no)->update(['trade_no'=>$trade_no,'state'=>1,'paytime'=>time()]);
  54. User::money($info['price'],$info['user_id'],'充值余额到账');
  55. if($info['gift_price']>0)
  56. {
  57. User::money($info['gift_price'],$info['user_id'],'充值余额赠送金额到账');
  58. }
  59. }
  60. }elseif(strpos($out_trade_no,'lusPay')){
  61. $info = db('service_plus_pay')->where('orderId',$out_trade_no)->find();
  62. if($info['state'] == 0){
  63. db('service_plus_pay')->where('orderId',$out_trade_no)->update(['trade_no'=>$trade_no,'state'=>1,'paytime'=>time()]);
  64. PlusPay::handlePlus($info['id']);
  65. }
  66. }elseif(strpos($out_trade_no,'ackageOr')){
  67. $info = db('service_package_order')->where('orderId',$out_trade_no)->find();
  68. if($info['state'] == 0){
  69. db('service_package_order')->where('orderId',$out_trade_no)->update(['trade_no'=>$trade_no,'status'=>1,'paytime'=>time()]);
  70. if($info['coupon_id'])
  71. {
  72. db('service_user_coupon')->where('id',$params['coupon_id'])->update(['state'=>1,'updatetime'=>time()]);
  73. }
  74. }
  75. }
  76. //你可以在此编写订单逻辑
  77. } catch (Exception $e) {
  78. }
  79. //下面这句必须要执行,且在此之前不能有任何输出
  80. if (Service::isVersionV3()) {
  81. return $pay->success()->getBody()->getContents();
  82. } else {
  83. return $pay->success()->send();
  84. }
  85. }
  86. public function fromXml($xml)
  87. {
  88. // 禁止引用外部xml实体
  89. libxml_disable_entity_loader(true);
  90. return json_decode(json_encode(simplexml_load_string($xml, 'SimpleXMLElement', LIBXML_NOCDATA)), true);
  91. }
  92. /**
  93. * 支付回调
  94. * @return \Psr\Http\Message\ResponseInterface|string|\Symfony\Component\HttpFoundation\Response|void
  95. * @throws \Yansongda\Pay\Exception\ContainerException
  96. * @throws \Yansongda\Pay\Exception\InvalidParamsException
  97. * @throws \Yansongda\Pay\Exceptions\InvalidArgumentException
  98. * @throws \Yansongda\Pay\Exceptions\InvalidConfigException
  99. * @throws \Yansongda\Pay\Exceptions\InvalidSignException
  100. */
  101. public function notify()
  102. {
  103. $data = file_get_contents('php://input');
  104. $wxPay = new WxPay();
  105. $res = $wxPay->xmlToArray($data);
  106. $sign = $res['sign'];
  107. // sign不参与签名算法
  108. unset($res['sign']);
  109. // 生成签名
  110. $signature = $wxPay->getSign($res);
  111. if($sign != $signature)
  112. {
  113. echo '签名错误';
  114. return;
  115. }
  116. if ($res['return_code'] != 'SUCCESS') {
  117. echo '支付失败';
  118. return;
  119. }
  120. $paytype = $this->request->param('paytype');
  121. try {
  122. $payamount = $paytype == 'alipay' ? $res['total_amount'] : $res['total_fee'] / 100;
  123. $out_trade_no = $res['out_trade_no'];
  124. $trade_no = $res['transaction_id'];
  125. if (strpos($out_trade_no,'killEn')){
  126. $info = db('service_skill_ensure_pay')->field('id,user_id,price,state')->where('orderId',$out_trade_no)->find();
  127. if($info['state'] == 0){
  128. db('service_skill_ensure_pay')->where('orderId',$out_trade_no)->update(['trade_no'=>$trade_no,'state'=>1,'paytime'=>time()]);
  129. Skill::where(['user_id'=>$info['user_id']])->setInc('ensure_price',$info['price']);
  130. (new SkillEnsurePay)->updateSkillEnsure($info['user_id'],$info['price']);
  131. }
  132. }elseif (strpos($out_trade_no,'hopEn')){
  133. $info = db('service_shop_ensure_pay')->field('id,user_id,price,state')->where('orderId',$out_trade_no)->find();
  134. if($info['state'] == 0){
  135. db('service_shop_ensure_pay')->where('orderId',$out_trade_no)->update(['trade_no'=>$trade_no,'state'=>1,'paytime'=>time()]);
  136. Shop::where(['user_id'=>$info['user_id']])->setInc('ensure_price',$info['price']);
  137. (new ShopEnsurePay)->updateShopEnsure($info['user_id'],$info['price']);
  138. }
  139. }
  140. } catch (Exception $e) {
  141. }
  142. return '<xml><return_code><![CDATA[SUCCESS]]></return_code><return_msg><![CDATA[OK]]></return_msg></xml>';
  143. }
  144. /**
  145. * 支付返回,仅供开发测试
  146. */
  147. public function returnx()
  148. {
  149. $paytype = $this->request->param('paytype');
  150. $out_trade_no = $this->request->param('out_trade_no');
  151. $pay = Service::checkReturn($paytype);
  152. if (!$pay) {
  153. $this->error('签名错误', '');
  154. }
  155. //你可以在这里通过out_trade_no去验证订单状态
  156. //但是不可以在此编写订单逻辑!!!
  157. $this->success("请返回网站查看支付结果", addon_url("epay/index/index"));
  158. }
  159. }