| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374 | <?phpnamespace app\api\controller\h5;use app\hander\HelpHander;use EasyWeChat\Factory;use think\Controller;use think\Db;use think\Exception;class Notify extends Controller{    public function phorder(){        $config = config('app.wx_config');        $app = Factory::payment($config);        $response = $app->handlePaidNotify(function ($message, $fail) {            if ($message['return_code'] === 'SUCCESS' && $message['result_code'] === 'SUCCESS') { // return_code 表示通信状态,不代表支付状态                // 用户是否支付成功                $tradeNo = $message['out_trade_no'];                // 使用通知里的 "微信支付订单号" 或者 "商户订单号" 去自己的数据库找到订单                $order = Db::name('ph_order_pay')->where('sn',$tradeNo)->find();                if (!$order || $order['status'] != 0) { // 如果订单不存在 或者 订单已经支付过了                    return true; // 告诉微信,我已经处理完了,订单没找到,别再通知我了                }                $ret = model('PhOrderPay')->paySuccess($order['id'],2);                if(!$ret){                    trace('订单修改失败');                    $fail('订单修改失败');                }            } else {                return $fail('通信失败,请稍后再通知我');            }            return true; // 返回处理完成        });        $response->send();    }    public function xshopOrder(){        $config = config('app.wx_config');        $app = Factory::payment($config);        $response = $app->handlePaidNotify(function ($message, $fail) {            if ($message['return_code'] === 'SUCCESS' && $message['result_code'] === 'SUCCESS') { // return_code 表示通信状态,不代表支付状态                // 用户是否支付成功                $tradeNo = $message['out_trade_no'];                // 使用通知里的 "微信支付订单号" 或者 "商户订单号" 去自己的数据库找到订单                $order = Db::name('g_orders')->where('order_sn',$tradeNo)->find();                if (!$order || $order['status'] != 0) { // 如果订单不存在 或者 订单已经支付过了                    return true; // 告诉微信,我已经处理完了,订单没找到,别再通知我了                }                $ret = Db::name('g_orders')->where('id',$order['id'])->update(['status'=>1,'pay_time'=>date('Y-m-d H:i:s')]);                $goods = Db::name('g_order_goods')->where('order_id',$order['id'])->select();               //增加销量                foreach ($goods as $k=>$v){                   Db::name('g_goods')                        ->where('id',$v['id'])                        ->inc('sale',$v['nums'])                        ->update();                }                if(!$ret){                    trace('订单修改失败');                    $fail('订单修改失败');                }            } else {                return $fail('通信失败,请稍后再通知我');            }            return true; // 返回处理完成        });        $response->send();    }}
 |