讀古今文學網 > 微信公眾平台開發:從零基礎到ThinkPHP5高性能框架實踐 > 17.3.2 模式二:動態鏈接 >

17.3.2 模式二:動態鏈接

掃碼支付模式二與模式一相比,流程更為簡單,不依賴設置的回調支付URL。商戶後台系統先調用微信支付的統一下單接口,微信後台系統返回鏈接參數code_url,商戶後台系統將code_url值生成二維碼圖片,用戶使用微信客戶端掃碼後發起支付。

模式二的接口類代碼如下,主要功能是設置參數、生成鏈接以及獲得URL。


 1 /**
 2  * 靜態鏈接二維碼
 3  */
 4 class NativeLink_pub  extends Common_util_pub
 5 {
 6     var $parameters;        // 靜態鏈接參數
 7     var $url;                // 靜態鏈接
 8 
 9     function __construct
10     {
11     }
12 
13     /**
14      * 設置參數
15      */
16     function setParameter($parameter, $parameterValue)
17     {
18         $this->parameters[$this->trimString($parameter)] = $this->trimString($parameterValue);
19     }
20 
21     /**
22      * 生成Native支付鏈接二維碼
23      */
24     function createLink
25     {
26         try
27         {
28             if($this->parameters["product_id"] == null)
29             {
30                 throw new SDKRuntimeException("缺少Native支付二維碼鏈接必填參數product_
                   id!"."<br>");
31             }
32                $this->parameters["appid"] = WxPayConf_pub::APPID;// 公眾賬號ID
33                $this->parameters["mch_id"] = WxPayConf_pub::MCHID;// 商戶號
34                $time_stamp = time;
35                $this->parameters["time_stamp"] = "$time_stamp";// 時間戳
36             $this->parameters["nonce_str"] = $this->createNoncestr;// 隨機字符串
37             $this->parameters["sign"] = $this->getSign($this->parameters);// 簽名
38             $bizString = $this->formatBizQueryParaMap($this->parameters, false);
39             $this->url = "weixin:// wxpay/bizpayurl?".$bizString;
40         }catch (SDKRuntimeException $e)
41         {
42             die($e->errorMessage);
43         }
44     }
45 
46     /**
47      * 返回鏈接
48      */
49     function getUrl
50     {
51         $this->createLink;
52         return $this->url;
53     }
54 }
  

掃碼支付模式二生成二維碼的流程如下。

首先設置支付相關參數,其中需要自己指定的參數是商品的名稱和價格,以及交易號。其他由系統自動獲取或自動生成。其代碼如下。


// 使用統一支付接口
$unifiedOrder = new UnifiedOrder_pub;

// 設置統一支付接口參數
// 設置必填參數
// appid已填,商戶無須重複填寫
// mch_id已填,商戶無須重複填寫
// noncestr已填,商戶無須重複填寫
// spbill_create_ip已填,商戶無須重複填寫
// sign已填,商戶無須重複填寫
$unifiedOrder->setParameter("body","貢獻一分錢");        // 商品描述
// 自定義訂單號,此處僅作舉例
$timeStamp = time;
$out_trade_no = WxPayConf_pub::APPID."$timeStamp";
$unifiedOrder->setParameter("out_trade_no","$out_trade_no");        // 商戶訂單號
$unifiedOrder->setParameter("total_fee","1");        // 總金額
$unifiedOrder->setParameter("notify_url",WxPayConf_pub::NOTIFY_URL);        // 通知地址
$unifiedOrder->setParameter("trade_type","NATIVE");        // 交易類型
// 非必填參數,商戶可根據實際情況選填
// $unifiedOrder->setParameter("sub_mch_id","XXXX");        // 子商戶號  
// $unifiedOrder->setParameter("device_info","XXXX");        // 設備號 
// $unifiedOrder->setParameter("attach","XXXX");        // 附加數據 
// $unifiedOrder->setParameter("time_start","XXXX");        // 交易起始時間
// $unifiedOrder->setParameter("time_expire","XXXX");        // 交易結束時間 
// $unifiedOrder->setParameter("goods_tag","XXXX");        // 商品標記 
// $unifiedOrder->setParameter("openid","XXXX");        // 用戶標識
// $unifiedOrder->setParameter("product_id","XXXX");        // 商品ID

// 獲取統一支付接口結果
$unifiedOrderResult = $unifiedOrder->getResult;
  

參數生成之後,將生成如下XML數據。


<xml>
    <body><![CDATA[貢獻一分錢]]></body>
    <out_trade_no><![CDATA[100001_1433009089]]></out_trade_no>
    <total_fee>1</total_fee>
    <notify_url><![CDATA[http:// www.doucube.com/weixin/demo/notify_url.php]]></notify_url>
    <trade_type><![CDATA[NATIVE]]></trade_type>
    <device_info>100001</device_info>
    <appid><![CDATA[wx1d065b0628e21103]]></appid>
    <mch_id>1237905502</mch_id>
    <spbill_create_ip><![CDATA[61.129.47.79]]></spbill_create_ip>
    <nonce_str><![CDATA[gwpdlnn0zlfih21gipjj5z53i7vea8e8]]></nonce_str>
    <sign><![CDATA[C5A1E210F9B4402D8254F731882F41AC]]></sign>
</xml>
  

將該XML數據向統一下單接口提交,返回的XML數據如下。


<xml>
    <return_code><![CDATA[SUCCESS]]></return_code>  
    <return_msg><![CDATA[OK]]></return_msg>  
    <appid><![CDATA[wx1d065b0628e21103]]></appid>  
    <mch_id><![CDATA[1237905502]]></mch_id>  
    <device_info><![CDATA[100001]]></device_info>  
    <nonce_str><![CDATA[6u8ovTtFupTagsiY]]></nonce_str>  
    <sign><![CDATA[E84D8BC2331766DD685591F908367FF1]]></sign>  
    <result_code><![CDATA[SUCCESS]]></result_code>  
    <prepay_id><![CDATA[wx20150531020450bb586eb2f70717331240]]></prepay_id>  
    <trade_type><![CDATA[NATIVE]]></trade_type>  
    <code_url><![CDATA[weixin:// wxpay/bizpayurl?pr=dNp7omD]]></code_url> 
</xml>
  

其中包含code_url參數,code_url就是最終要生成的二維碼的鏈接。當用戶掃瞄二維碼時,就能直接拉取到商戶信息並完成支付。