| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347 | <?phpnamespace App\Http\Controllers\Wechat\Pay;use EasyWeChat\Payment\Order;use App\Http\Requests;use App\Http\Controllers\WechatController;use App\Http\Controllers\Controller;use Illuminate\Http\Request;use EasyWeChat\Foundation\Application;use EasyWeChat\Message\Text;/** * 微信支付 */class PaysController extends WechatController{	public $payment;	public $options;	public function __construct()	{		$this->options = array();		parent::__construct();	}		function set_options($appid){	    $this->options = [];				return $this->options;	}	    /**     * 接收微信回调     * @return Response     */    public function index(Request $request)    {//     	if($request->has('echostr')) exit($request->input('echostr'));echostr    	v('start_check_sign');    	v($request->all());    	$echostr = $request->get('echostr');    	if(!empty($echostr)){    		echo $echostr;exit();    	}        if(!$this->checkSignature($request)){        	v('return_fail:');//         	exit;        }else{        	v('return_success:');        }    	    	v('start_setmessagehander:'.$this->local_test);    	    	if(env('DEVELOP_MODE') == 'local'){    		$notify = $this->get_fake_data();    		$res = $this->deal_callback($notify,true);    	}else{    		v('start-payment');			$response = $this->payment->handleNotify(function($notify, $successful){			    return $this->deal_callback($notify,$successful);			});			return $response;    	}    			v('last_echo');    }        function deal_callback($notify,$successful){    	    v('wxpay_deal_callback_in');    	    v('notify:');v($notify);v('successful:'.$successful);			return true; // 返回处理完成    }        function notify(Request $request){    	v('wxpay_notify');v($request->all());    	echo 'success';    }        /**     * @api {get} /create_wxpay_order?body=:body&detail=:detail&total_fee=:total_fee&open_id=:open_id 创建交易订单     * @apiName create_wxpay_order     * @apiGroup Bag     * @apiDescription     * 创建订单,返回的是支付的config数组     * @apiParam {String} body 支付简要描述.     * @apiParam {String} detail 支付详细描述.     * @apiParam {String} total_fee 支付金额(单位分).     * @apiParam {String} open_id 用户open_id.     * @apiSuccess {String} appId .     * @apiSuccess {String} nonceStr  .     * @apiSuccess {String} package  .     * @apiSuccess {String} signType  .     * @apiSuccess {String} paySign .     * @apiSuccess {String} timestamp  .     */  /**http://auth.aizhuishu.com/pay/create_wxpay_order?out_trade_no=2017120917571001&body=%E6%B5%8B%E8%AF%95%E4%B8%8B%E8%80%8C%E5%B7%B2&detail=%E6%B5%8B%E8%AF%95%E4%B8%8B%E7%88%B1%E8%BF%BD%E4%B9%A6%E5%BE%AE%E4%BF%A1%E6%94%AF%E4%BB%98&total_fee=1&appid=wx2538d0bc2ea3089e&open_id=oc5mg0xkIlKEMDkQL39RSLXhfatM¬ify_url=http%3A%2F%2Fpay.aizhuishu.com%2Fpay%2Fnotify×tamp=1512788565&sign=c2da337c73393dbd51ef2d58559daa15http://zydy/pay/create_wxpay_order?out_trade_no=2017120917571001&body=%E6%B5%8B%E8%AF%95%E4%B8%8B%E8%80%8C%E5%B7%B2&detail=%E6%B5%8B%E8%AF%95%E4%B8%8B%E7%88%B1%E8%BF%BD%E4%B9%A6%E5%BE%AE%E4%BF%A1%E6%94%AF%E4%BB%98&total_fee=1&appid=wx2538d0bc2ea3089e&open_id=oc5mg0xkIlKEMDkQL39RSLXhfatM¬ify_url=http%3A%2F%2Fpay.aizhuishu.com%2Fpay%2Fnotify×tamp=1512788565&sign=c2da337c73393dbd51ef2d58559daa15http://zydy/pay/create_wxpay_order?out_trade_no=2017120917571002&body=%E6%B5%8B%E8%AF%95%E4%B8%8B%E8%80%8C%E5%B7%B2&detail=%E6%B5%8B%E8%AF%95%E4%B8%8B%E7%88%B1%E8%BF%BD%E4%B9%A6%E5%BE%AE%E4%BF%A1%E6%94%AF%E4%BB%98&total_fee=1&appid=wx2538d0bc2ea3089e&open_id=oc5mg0xkIlKEMDkQL39RSLXhfatM¬ify_url=http%3A%2F%2Fauth.aizhuishu.com%2Fpay%2Fnotify×tamp=1512788565&sign=c2da337c73393dbd51ef2d58559daa15    */    function create_wxpay_order(Request $request){    	$result = array('code'=>1,'msg'=>'','data'=>'');    	$body = $request->get('body');    	$detail = $request->get('detail');    	$total_fee = $request->get('total_fee');    	$open_id = $request->get('open_id');    	$appid = $request->get('appid');    	$out_trade_no = $request->get('out_trade_no');    	$attach = $request->get('attach');    	$is_call_pay = $request->get('is_call_pay');//是否直接唤起    	$notify_url = $request->get('notify_url');    	$redirect_url = $request->get('redirect_url');    	    	if(empty($open_id) || empty($notify_url)  || empty($redirect_url) || empty($appid) || empty($out_trade_no)){    		$result['code'] = 0;    		$result['msg'] = 'invalid param';    		v('invalid_param_open_id:'.$open_id);    		json_echo($result);    	}    	    	$this->set_options($appid);    	if(empty($this->options)){    		$result['code'] = 0;    		$result['msg'] = 'invalid appid';    		v('invalid_param_open_id:'.$open_id.' appid:'.$appid);    		json_echo($result);    	}    	    	$check_result = $this->check_sign_params($request);    	if($check_result['code'] == 0){    		$result['code'] = 0;    		$result['msg'] = $check_result['msg'];    		json_echo($result);    	}    	$attributes = [	    	'trade_type'       => 'JSAPI', // JSAPI,NATIVE,APP...	    	'body'             => $body,	    	'detail'           => $detail,	    	'out_trade_no'     => $out_trade_no,	    	'total_fee'        => $total_fee, // 单位:分	    	'attach'        => $attach	, // 附加参数,127字符	    	'openid'           => $open_id, // trade_type=JSAPI,此参数必传,用户在商户appid下的唯一标识,	    	// ...    	];    	v('attributes:');v($attributes);    	$order = new Order($attributes);    	    	$this->options['payment']['notify_url'] = urldecode($notify_url);    	$app = new Application($this->options);    	$this->payment = $app->payment;    	    	// 创建订单    	$prepare_result = $this->payment->prepare($order);    	v('$prepare_result:');v($prepare_result);    	$prepayId = '';    	if ($prepare_result->return_code == 'SUCCESS' && $prepare_result->result_code == 'SUCCESS'){    		$prepayId = $prepare_result->prepay_id;    	}else{    		$result['code'] = 0;    		$result['msg'] = 'prepare order fail';    		v('prepare_order_fail:'.$attributes['out_trade_no']);    		json_echo($result);    	}    	v('prepayId:'.$prepayId);    	    	$config = $this->payment->configForJSSDKPayment($prepayId); // 返回数组    	v('config:');v($config);    	    	// 状态没问题则创建订单    	if(!empty($config)){    	}else{    		$result['code'] = 0;    		$result['msg'] = 'configForJSSDKPayment fail';    		v('configForJSSDKPayment_fail:'.$attributes['out_trade_no']);    		json_echo($result);    	}    	$result['data'] = $config;    	    	v('create_result:');v($result);    	if(!$is_call_pay){    		json_echo($result);    	}else{    		$pay_info = array();    		$pay_info['appId'] = $config['appId'];    		$pay_info['timeStamp'] = $config['timestamp'];    		$pay_info['nonceStr'] = $config['nonceStr'];    		$pay_info['package'] = $config['package'];    		$pay_info['paySign'] = $config['paySign'];    		$pay_info['pay_redirect_url'] = $redirect_url;    		     		return view('pay.order.index',compact('pay_info'));    	}    	    }            /**     * @api {get} /bag/create_wxpay_order_refund?out_trade_no=:out_trade_no×tamp=:timestamp&sign=:sign 交易退款     * @apiName create_wxpay_order_refund     * @apiGroup Bag     * @apiDescription     * 创建微信退款订单(暂时不需要)     * @apiParam {String} out_trade_no 支付订单号.     * @apiParam {String} timestamp 时间戳.     * @apiParam {String} sign 签名.         */    // 暂时不管:可能会遇到这个问题,交易未结算资金不足,请使用可用余额退款    function create_wxpay_order_refund(Request $request){    	$result = array('code'=>1,'msg'=>'','data'=>'');    	$out_trade_no = $request->get('out_trade_no');    	$timestamp = $request->get('timestamp');    	$sign = $request->get('sign');    	     	if(empty($out_trade_no) || empty($timestamp) || empty($sign)){    		$result['code'] = 0;    		$result['msg'] = 'invalid param';    		v('invalid_param_out_trade_no:'.$out_trade_no);    		json_echo($result);    	}    	    	$param = array();    	$param['out_trade_no'] = $out_trade_no;    	$param['timestamp'] = $timestamp;    	$my_sign = $this->WxSign->get_sign($param);    	if($sign != $my_sign){    		$result['code'] = 0;    		$result['msg'] = 'invalid sign';    		v('create_wxpay_order_refund_sign_error:'.$out_trade_no.' $sign:'.$sign.' $my_sign:'.$my_sign);    		json_echo($result);    	}    	$refund_no = get_orderno_by_time();    	$total_fee = $wx_pay_record->total_fee;    	$refund_fee = $total_fee;    	$open_id = $wx_pay_record->open_id;    	v('refund:out_trade_no:'.$out_trade_no.' refund_no:'.$refund_no.' total_fee:'.$total_fee.' refund_fee:'.$refund_fee.' open_id:'.$open_id);            $refund_result = $this->payment->refund($out_trade_no, $refund_no, $total_fee, $total_fee); //         $refund_result = $this->get_fake_refund_data();        v('$refund_result');v($refund_result);                if ($refund_result->return_code == 'SUCCESS' && $refund_result->result_code == 'SUCCESS'){        	$refund_result->open_id = $open_id;//         	WxRefundRecord::save_wx_refund_record($refund_result);        }else{        	$result['code'] = 0;        	$result['msg'] = 'refund fail';        	v('refund_fail:'.$out_trade_no);        	json_echo($result);        }            	$result['data'] = 'refund success';    	json_echo($result);    }        /**     * 查询退款结果     */    //http://wread/pay/query_refund?out_trade_no=201705171025468688026×tamp=12&sign=2cb2d01ae367265a1dbdd663e1d32415    function query_refund(Request $request){    	$out_trade_no = $request->get('out_trade_no');    	$timestamp = $request->get('timestamp');    	$sign = $request->get('sign');    	if(empty($out_trade_no) || empty($timestamp) || empty($sign)){    		$result['code'] = 0;    		$result['msg'] = 'invalid param';    		v('invalid_param_out_trade_no:'.$out_trade_no);    		json_echo($result);    	}    	    	$param = array();    	$param['out_trade_no'] = $out_trade_no;    	$param['timestamp'] = $timestamp;    	$my_sign = $this->WxSign->get_sign($param);    	if($sign != $my_sign){    		$result['code'] = 0;    		$result['msg'] = 'invalid sign';    		v('query_refund_sign_error:'.$out_trade_no.' $sign:'.$sign.' $my_sign:'.$my_sign);    		json_echo($result);    	}    	    	$query_refund_result = $this->payment->queryRefund($out_trade_no);    	v('query_refund_result:');v($query_refund_result);    	     }            private function checkSignature($request)    {    	$signature = $request->get('signature');    	$timestamp = $request->get('timestamp');    	$nonce = $request->get('nonce');    	$echostr = $request->get('echostr');    	     	//     	$token = 'd4352c0225d5da500b176cf3464e9822';    	$tmpArr = array($this->token, $timestamp, $nonce);    	sort($tmpArr, SORT_STRING);    	$tmpStr = implode( $tmpArr );    	$tmpStr = sha1( $tmpStr );    	v('$tmpStr:'.$tmpStr);        	if( $tmpStr == $signature ){    		return true;    	}else{    		return false;    	}    }        function get_fake_data(){    	$message = new \stdClass();    	$message->out_trade_no = '201705261556493599255';    	     	return $message;    }        //"return_code":"SUCCESS","return_msg":"OK","appid":"wx27c650c50a36cc46","mch_id":"1468320702","nonce_str":"DNMs2GFrmZilOy8w","sign":"B1F25F070184B94202D67D3722057850","result_code":"SUCCESS","transaction_id":"4005562001201705171197097763","out_trade_no":"201705171025468688026","out_refund_no":"201705181118027912184","refund_id":"50000302912017051801101133889","refund_channel":null,"refund_fee":"500","coupon_refund_fee":"0","total_fee":"500","cash_fee":"500","coupon_refund_count":"0","cash_refund_fee":"500"}    function get_fake_refund_data(){    	$refund_result = new \stdClass();    	$refund_result->return_code = 'SUCCESS';    	$refund_result->result_code = 'SUCCESS';    	$refund_result->transaction_id = '4005562001201705171197097763';    	$refund_result->out_trade_no = '201705171025468688026';    	$refund_result->out_refund_no = '201705181118027912184';    	$refund_result->refund_id = '50000302912017051801101133889';    	$refund_result->refund_channel = '';    	$refund_result->refund_fee = '500';    	$refund_result->coupon_refund_fee = '0';    	$refund_result->total_fee = '500';    	$refund_result->cash_fee = '500';    	$refund_result->coupon_refund_count = '0';    	$refund_result->cash_refund_fee = '500';    	$refund_result->return_msg = 'OK';    	$refund_result->appid = 'wx27c650c50a36cc46';    	$refund_result->mch_id = '1468320702';    	$refund_result->nonce_str = 'DNMs2GFrmZilOy8w';    	$refund_result->sign = 'B1F25F070184B94202D67D3722057850';    	    	return $refund_result;    }    }
 |