微信支付細節

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;      }        }      }
相關文章
相關標籤/搜索