掃二維碼與項(xiàng)目經(jīng)理溝通
我們在微信上24小時期待你的聲音
解答本文疑問/技術(shù)咨詢/運(yùn)營咨詢/技術(shù)建議/互聯(lián)網(wǎng)交流
隨著微信小程序的發(fā)展,越來越多的移動端應(yīng)用選擇了微信產(chǎn)品作為媒介。無論是公眾號開發(fā)還是小程序開發(fā),微信支付永遠(yuǎn)都是繞不開的話題。由于微信支付涉及了很多場景,本文我們只學(xué)習(xí)如何在公眾號、小程序中接入微信支付。

創(chuàng)新互聯(lián)公司服務(wù)項(xiàng)目包括貢嘎網(wǎng)站建設(shè)、貢嘎網(wǎng)站制作、貢嘎網(wǎng)頁制作以及貢嘎網(wǎng)絡(luò)營銷策劃等。多年來,我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢、行業(yè)經(jīng)驗(yàn)、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機(jī)構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,貢嘎網(wǎng)站推廣取得了明顯的社會效益與經(jīng)濟(jì)效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到貢嘎省份的部分城市,未來相信會繼續(xù)擴(kuò)大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!
微信公眾號大體上可以分為服務(wù)號和訂閱號,訂閱號和服務(wù)號的具體區(qū)別在以前寫過的一篇文章Spring Boot開發(fā)微信公眾號中具體介紹了,這里就不再贅述,總的來說就是服務(wù)號提供了更高級的功能。
微信支付接入需要已經(jīng)完成微信認(rèn)證的服務(wù)號。如果是小程序的話,也需要完成微信認(rèn)證。
公眾號可以關(guān)聯(lián)同一主體的10個小程序,不同主體的3個小程序,如果是和公眾號同一主體的小程序并且公眾號已經(jīng)完成認(rèn)證,則直接可以在公眾號后臺的小程序管理中,進(jìn)行快速注冊并認(rèn)證,這樣就無需重復(fù)支付微信認(rèn)證所需的300RMB了。
微信認(rèn)證完成后,在公眾號后臺的 微信支付 中開通微信支付功能。提交微信支付申請后,3-5個工作日內(nèi),會進(jìn)行審核,審核通過后會往你填寫的郵箱里發(fā)送一份包含商戶號信息的郵件,同時會往你填寫的對公賬戶中打幾毛錢的匯款,需要你查看具體金額后在商戶平臺中驗(yàn)證。
商戶分為普通商戶和服務(wù)商商戶,千萬不要申請錯了。
普通商戶是可以進(jìn)行交易,但是不能拓展商戶。
服務(wù)商可以拓展商戶,但是不能交易。
服務(wù)商就是提供統(tǒng)一的支付入口,它需要綁定具體的普通商戶,微信支付時會在支付接口中攜帶普通商戶參數(shù),支付成功后金額會直接到具體的普通商戶賬戶上。
申請時直接申請普通商戶就可以了。
微信支付發(fā)起依賴于公眾號、小程序等應(yīng)用與商戶號的綁定關(guān)系。因此在進(jìn)行開發(fā)前,需要將商戶與具體應(yīng)用進(jìn)行綁定。
如果商戶和需要綁定的AppID是同一主體,只需要以下步驟即可完成綁定。
如果商戶和需要綁定的AppID是不同主體,步驟和上述一樣,除了輸入AppId之外,還需要填入AppId的認(rèn)證信息。
1. 付款碼支付
用戶打開微信錢包-付款碼的界面,商戶掃碼后提交完成支付。
2. JSAPI支付
用戶通過微信掃碼,關(guān)注公眾號等方式進(jìn)入商家H5頁面,并在微信內(nèi)調(diào)用JSSDK完成支付。
3. Native支付
用戶打開微信掃一掃,掃描商戶的二維碼后完成支付。
4. APP支付
商戶APP中集成微信SDK,用戶點(diǎn)擊后跳轉(zhuǎn)到微信內(nèi)完成支付。
5. H5支付
用戶在微信以外的手機(jī)瀏覽器請求微信支付的場景喚起微信支付。
6. 小程序支付
用戶在微信小程序中使用微信支付的場景。
7. 刷臉支付
無需掏出手機(jī),刷臉完成支付,適合線下各種場景。
在商戶平臺-產(chǎn)品中心-我的產(chǎn)品中申請開通支付產(chǎn)品。
在商戶平臺-產(chǎn)品中心-開發(fā)配置中進(jìn)行支付授權(quán)目錄的配置(即你開發(fā)的下單接口地址),需要注意的是授權(quán)目錄最多可以配置五個,在開發(fā)過程中請合理定義支付接口。
在商戶平臺-賬戶中心-API安全中設(shè)置API密鑰。
第一次設(shè)置時,需要安裝操作證書,傻瓜式安裝,按照提示一步一步操作就可以。
API密鑰需要一個32位的隨機(jī)字符串,記得不要隨意更改API密鑰。
在微信API v3版本中,除了要配置API密鑰外,還需要配置APIv3密鑰和申請CA頒發(fā)的API證書。
如果使用開源的微信開發(fā)包,請了解是否支持v3版本。
在公眾號后臺-開發(fā)-基本配置-服務(wù)器配置中啟用并填寫服務(wù)器信息。
在公眾號后臺-開發(fā)-基本配置-公眾號開發(fā)信息中配置開發(fā)者密鑰,同時填寫IP白名單。
在公眾號后臺-公眾號設(shè)置-功能設(shè)置中設(shè)置JS接口安全域名。
上面的配置是基于公眾號支付配置的,小程序支付沒有這么麻煩,小程序支付不用配置支付授權(quán)目錄和授權(quán)域名。
由于微信升級了API接口,在API v3接口中,需要加載申請的API證書,微信已經(jīng)封裝了相關(guān)jar包,并且提供了加載示例,具體可參考“https://pay.weixin.qq.com/wiki/doc/apiv3/open/pay/chapter2_3.shtml”,這里就不再贅述。我們以API v2為例詳細(xì)學(xué)習(xí)一下微信接入的主要流程(因?yàn)锳PI v3的一些接口還在持續(xù)升級,v2接口相對完整)。
上面的這張圖片來自微信開發(fā)文檔,我們詳細(xì)分析一下支付流程。
用戶通過微信客戶端發(fā)起支付,在商戶后臺生成訂單,然后調(diào)用微信下單接口,生成預(yù)支付訂單,返回訂單號!
下單接口涉及到的主要參數(shù),只列舉重要的幾個參數(shù):
sign的簽名也比較通用,涉及了一個保證簽名不可預(yù)測的nonce_str
拉起微信支付,輸入密碼,完成支付。這一步需要在H5網(wǎng)頁中執(zhí)行JS調(diào)起支付。
需要以下參數(shù),因此在預(yù)付訂單返回時,需要將下列參數(shù)封裝后響應(yīng)給頁面,由頁面完成支付。
簽名和下單接口的簽名方式一樣。
JS偽代碼如下:
- function onBridgeReady(){
- WeixinJSBridge.invoke(
- 'getBrandWCPayRequest', {
- // 公眾號ID,由商戶傳入
- "appId":"wx2421b1c4370ec43b",
- // 時間戳,自1970年以來的秒數(shù)
- "timeStamp":"1395712654",
- // 隨機(jī)串
- "nonceStr":"e61463f8efa94090b1f366cccfbbb444",
- "package":"prepay_id=u802345jgfjsdfgsdg888",
- // 微信簽名方式
- "signType":"MD5",
- // 微信簽名
- "paySign":"70EA570631E4BB79628FBCA90534C63FF7FADD89"
- },
- function(res){
- if(res.err_msg == "get_brand_wcpay_request:ok" ){
- // 使用以上方式判斷前端返回,微信團(tuán)隊(duì)鄭重提示:
- // res.err_msg將在用戶支付成功后返回ok,但并不保證它絕對可靠。
- }
- });
- }
- if (typeof WeixinJSBridge == "undefined"){
- if( document.addEventListener ){
- document.addEventListener('WeixinJSBridgeReady', onBridgeReady, false);
- }else if (document.attachEvent){
- document.attachEvent('WeixinJSBridgeReady', onBridgeReady);
- document.attachEvent('onWeixinJSBridgeReady', onBridgeReady);
- }
- }else{
- onBridgeReady();
- }
注意偽代碼中的這句話// res.err_msg將在用戶支付成功后返回ok,但并不保證它絕對可靠。為什么這么說呢,我舉個例子應(yīng)該就明白了。假如你去超市買東西,是不是你說支付成功了你就可以把東西帶走呢?肯定不是,是當(dāng)商家收到錢后才算你支付成功,你才可以把東西帶走。也就是說,這里提示的成功并不能說一定支付成功了,具體是否成功,微信平臺會以異步的方式給你進(jìn)行通知。
異步通知是比較重要的一步,在這里你可以根據(jù)通知結(jié)果處理你的業(yè)務(wù)邏輯。但是,可能會由于網(wǎng)絡(luò)波動等原因通知不到,或者說微信接收到的響應(yīng)不符合API的規(guī)定,微信會持續(xù)發(fā)起多次通知(請?jiān)诨卣{(diào)通知接口中合理處理,避免重復(fù)通知造成業(yè)務(wù)重復(fù)處理),直到成功為止,通知頻率為15s/15s/30s/3m/10m/20m/30m/30m/30m/60m/3h/3h/3h/6h/6h - 總計 24h4m)。但是微信不保證通知最終一定會成功。
異步通知響應(yīng)參數(shù)如下:
如果微信一直通知不成功怎么?還是剛才那個例子,你明明支付成功了,但是商家卻一直說她沒收到錢,這時候你怎么辦?肯定是去看一下她的手機(jī)是否真的沒有收到錢!這里也一樣。
本文主要以公眾號支付為例,總結(jié)了接入微信支付需要的相關(guān)配置和支付流程。其他支付像APP支付也是開發(fā)中比較常見的應(yīng)用場景,APP支付需要在 微信開放平臺 去創(chuàng)建應(yīng)用來接入微信支付。除此之外,微信支付API在向v3平滑升級,有些接口也還沒有升級完成,升級完的接口相較于v2發(fā)生了一些數(shù)據(jù)格式方面的變化。如果引用第三方開發(fā)包進(jìn)行開發(fā),需要注意接口對應(yīng)的版本。

我們在微信上24小時期待你的聲音
解答本文疑問/技術(shù)咨詢/運(yùn)營咨詢/技術(shù)建議/互聯(lián)網(wǎng)交流