1.配置php
//微信支付配置
"wx_pay_config" => [
'appId' => '********',
'mchId' => '**********',
'key' => '**********',
'notify_url' => config('app.notify_url').'wxCallback',
],
2.下單前端
掃碼支付json
$config = config('dailian.wx_pay_config'); $wPay = new \WxControl($config); $pay_arr = $wPay->unifiedorder('雲頂之弈代練', $order['order_num'], 1??$order['price'], 'NATIVE'); if (isset($pay_arr['err_code']) ||$pay_arr['return_code'] != 'SUCCESS' || $pay_arr['result_code'] != 'SUCCESS') return wx_errorReturn(null, -1201, $pay_arr['err_code_des']); $pay_str = $pay_arr['code_url'];
APP支付api
$config = config('dailian.wx_pay_config'); $wPay = new \WxControl($config); $pay_arr = $wPay->unifiedorder('雲頂之弈代練', $order['order_num'], 1??$order['price'], 'APP'); if (isset($pay_arr['err_code']) ||$pay_arr['return_code'] != 'SUCCESS' || $pay_arr['result_code'] != 'SUCCESS') return wx_errorReturn(null, -1201, $pay_arr['err_code_des']); $pay_str = $wPay->returnWxPayParams($pay_arr);
工具類微信
class WxControl { public $appId; public $mchId; public $notify_url; public $secret; public function __construct($config = []){ $config || $config = config('const.wx_pay_config'); $this->appId = $config['appId']; $this->mchId = $config['mchId']; $this->key = $config['key']; $this->notify_url = $config['notify_url']; $this->secret = config('const.wx_app_config')['secret']; } /** * 微信統一下單 */ public function unifiedorder($body, $out_trade_no, $total_price, $trade_type = "JSAPI") { $url = "https://api.mch.weixin.qq.com/pay/unifiedorder"; $qdata = [ 'appid' => $this->appId, 'mch_id' => $this->mchId, 'nonce_str' => getNonceStr(), 'body' => $body, 'out_trade_no' => $out_trade_no, 'total_fee' => $total_price, 'spbill_create_ip' => $_SERVER['REMOTE_ADDR'], 'notify_url' => $this->notify_url, 'trade_type' => $trade_type, // 'openid' => $openid, ]; //簽名步驟一:去除空字符 $signData = array_filter($qdata); //簽名步驟二:按字典序排序參數 ksort($signData); $string = toUrlParams($signData); //簽名步驟二:在string後加入KEY $string = $string . "&key=" . $this->key; //簽名步驟三:MD5加密 $string = md5($string); //簽名步驟四:全部字符轉爲大寫 $sign = strtoupper($string); //添加簽名 $qdata['sign'] = $sign; $xml = toXml($qdata); //發送請求 $http = new \HttpClient(); $result = $http->postXmlCurl($xml, $url); return $resultArr = xmlToArray($result); } //檢查回調參數驗證簽名 public function checkSign($data){ $sign = $data['sign']; $data['sign']=""; // $data['sign']=""; //簽名步驟一:去除空字符 $signData = array_filter($data); //簽名步驟二:按字典序排序參數 ksort($signData); $string = toUrlParams($signData); //簽名步驟二:在string後加入KEY $string = $string . "&key=" . $this->key; //簽名步驟三:MD5加密 $string = md5($string); //簽名步驟四:全部字符轉爲大寫 $signA = strtoupper($string); //添加簽名 if($sign == $signA) return true; return false; } /** * 返回微信支付的參數 */ public function returnWxPayParams($param) { //根據返回的字段再進行一次簽名 $arr = [ 'appid' => $param['appid'], 'partnerid' => $param['mch_id'], 'prepayid' => $param['prepay_id'], 'package' => 'Sign=WXPay', 'noncestr' => $param['nonce_str'], 'timestamp' => time(), ]; ksort($arr); $arr = array_filter($arr); $str = ""; foreach ($arr as $k=>$v){ if($str) $str .= "&"; $str.="{$k}={$v}"; } $str.="&key=".$this->key; $sign = strtoupper(md5($str)); $arr['sign'] = $sign; return $arr; }
3.前端調起支付app
4.回調工具
回調裏面要驗證簽名參數和金額是否與商戶所保存的金額數據相等post
$str = file_get_contents('php://input'); $data = simplexml_load_string($str, 'SimpleXMLElement', LIBXML_NOCDATA); $data = json_decode(json_encode($data), true); $config = config('const.wx_pay_config'); //驗證商戶號 if($config['mchId']!=$data['mch_id']) { Log::error('商戶號不對');exit; } //驗籤 $wx = new \WxControl($config); $flage = $wx->checkSign($data); if($flage) {
$status = $data['return_code'] == 'SUCCESS' || $data['code'] = 10000;
if($status){ $order = Db::name('order')->where('order_num', $order_num)->where('status',0)->find(); if($order['price']*100 != $money){ Log::error('金額不對');//exit; } } }