掃碼支付模式二與模式一相比,流程更為簡單,不依賴設置的回調支付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就是最終要生成的二維碼的鏈接。當用戶掃瞄二維碼時,就能直接拉取到商戶信息並完成支付。