最近公司需要開發(fā)支付功能,經(jīng)過這兩天的工作成功集成了app微信支付、支付寶支付。本文主要講述微信支付的流程和在集成過程中遇到的坑,和大家分享,共同進(jìn)步。
一、首先了解一下微信支付的流程
圖中展示了整個微信支付的流程:
1.用戶使用iOS客戶端,選擇商品下單。
2.iOS客戶端將用戶的商品數(shù)據(jù)傳給商戶服務(wù)器,請求生成支付訂單。
3.商戶后臺調(diào)用統(tǒng)一下單API向微信的服務(wù)器發(fā)送請求,微信服務(wù)器生成預(yù)付單,并生成一個prepay_id返回給商戶后臺。
4.商戶后臺將這個prepay_id返回給商戶客戶端。
5.用戶點擊確認(rèn)支付,這時候商戶客戶端調(diào)用SDK打開微信客戶端,進(jìn)行微信支付。
6.微信客戶端向微信服務(wù)器發(fā)起支付請求并返回支付結(jié)果(他們之間交互用的就是prepay_id這個參數(shù),微信的服務(wù)器要驗證微信客戶端傳過去的參數(shù)是否跟第三步中生成的那個id一致)。
7.用戶輸入支付密碼后,微信客戶端提交支付授權(quán),跟微信服務(wù)器交互,完成支付
8.微信服務(wù)器給微信客戶端發(fā)送支付結(jié)果提示,并異步給商戶服務(wù)器發(fā)送支付結(jié)果通知。
9.商戶客戶端通過支付結(jié)果回調(diào)接口查詢支付結(jié)果,并向后臺檢查支付結(jié)果是否正確,后臺返回支付結(jié)果。
10.商戶客戶端顯示支付結(jié)果,完成訂單,發(fā)貨。
調(diào)用微信支付前,需要下單、簽名等操作,以便獲取微信支付所必要的參數(shù)。為了提高安全性,下單、簽名操作一般是在后臺完成。
總結(jié)起來在iOS客戶端的所關(guān)注的支付流程分為三步
1.用戶點擊支付按鈕,生成商品訂單發(fā)給我們的服務(wù)器,
2.服務(wù)器返回支付必須的參數(shù),iOS客戶端去調(diào)用微信app
3.處理支付結(jié)果,展示給用戶。
相信大家肯定都在手機(jī)app上使用過微信或者支付寶支付過,可以動手去試驗一下。
二、微信支付的集成
1.要想集成微信支付首先需要商戶向微信開放平臺申請開發(fā)APP應(yīng)用,微信開放平臺會生成APP的唯一標(biāo)識APPID。然后利用這個APPID向微信sdk注冊支付。
2.下載微信支付SDK和demo:下載SDK和demo
3.把下載的支付SDK拖到項目工程中,然后添加項目支付SDK依賴的庫,TARGETS-->Build Phases -->Link Binary With Libraries
4.設(shè)置iOS客戶端的URL,identifier為weixin URL schemes設(shè)置為申請到的APPID
5.在Info.plist中設(shè)置app訪問白名單和支持HTTP協(xié)議
6.在appdelegate中注冊微信支付
導(dǎo)入頭文件#import"WXApi.h",
7.在需要支付的類的方法中發(fā)起支付請求
為了提高安全性,下單、簽名操作一般是在后臺完成。所以上面用到的參數(shù)中處理APPID是固定的,其他參數(shù)最后都由后臺返回給我們直接使用。
8.處理支付結(jié)果,最好在回調(diào)用請求我們的服務(wù)器然后根據(jù)這個請求判斷支付是否成功。
不管支付成功與否,都是走下面的方法,當(dāng)我們發(fā)送一個sendReq后,就會收到一個來自微信的處理結(jié)果。
9.大功告成。
三、在支付過程中可能會遇到的問題
1.在集成過程中如果遇到這樣的錯誤
可以修改為配置
2.點擊支付按鈕不能打開微信app,原因是參數(shù)大多是錯誤的,在調(diào)用微信app時SDK會判斷,不通過則不能打開app。
3.打開app之后只有一個白色的確定的按鈕,點擊它會返回iOS客戶端,
引起這個問題的主要原因就是調(diào)用微信app時,參數(shù)設(shè)置的不正確,而且多半是因為簽名的問題,就是參數(shù)中的sign值的問題,在后臺向微信后臺請求賬單的時候有過一次簽名,而客戶端吊起支付的簽名和那個簽名是不同的,多半是后臺直接把那個簽名發(fā)送給客戶端,并沒有進(jìn)行二次簽名,可以和后臺協(xié)商,再簽一次,因為兩次簽名的規(guī)則都一樣,所以就沒必要再讓客戶端寫一遍簽名規(guī)則了.
4.如果項目中集成了友盟和shareSDK分享,那就不用再導(dǎo)入SDK了,因為分享的SDK中已經(jīng)包括了微信的SDK,如果再次導(dǎo)入會出現(xiàn)很多意想不到的問題。
5.如果支付完成之后不能返回iOS客戶端,多半是URL schemes的設(shè)置問題。
6.在支付的回調(diào)中最好不要直接以回調(diào)的errcode來判斷支付成功與否,應(yīng)該請求我們的服務(wù)器看時候支付成功,然后展示支付結(jié)果給用戶。
7.微信支付的金額是以分為單位。
8.微信官方提供的調(diào)用微信app所需參數(shù)配置的鏈接,http://wxpay.weixin.qq.com/pub_v2/app/app_pay.php,用于調(diào)試支付接口的參數(shù)設(shè)置;這里所獲取到的參數(shù)可以全部由我們的后臺提供。示例: