最近做微信支付遇到的幾個問題,記錄一下
1.成功支付后回調
支付成后回調,由于是用wcf寫的restful風格的api,原本官方demo返回的是一個xml數據,讀取方法是通過
HttpContext.Current.Request.InputStream來讀取的,監(jiān)聽到回調方法獲取到InputStream的Length為0,
但是從WebServiceHostFactory監(jiān)聽到的這個對象是有值的,于是就考慮是不是要修改webconfig配置,來
修改behavior,結果無功而返,后來從網上找到,wcf讀取post報文是用OperationContext.Current.RequestContext.RequestMessage,成功讀到對應的值
2.退款問題
一開始退款功能開發(fā)參看支付訂單的接口,直接用postman測試接口,發(fā)現接口怎么都調不通,一度想去咨詢微信客服,后來在開發(fā)文檔中發(fā)現,是需要雙向證書驗證的,如圖
按照步驟去下載證書文件,并且按照指示雙擊安裝,下載了官方的demo正常跑起來,
然后把同樣的方法寫入自己的接口,結果還是連不通微信接口的,基礎連接關閉,百思不得其解,
同樣的代碼官方的winform程序能跑起來,我的接口跑不起來??代碼如下
于是就考慮是不是又和wcf的配置有關,按照網上找的資料修改了webconfig,把aspNetCompatibilityEnabled="true",結果還是不行,后面想到會不會和iis有關,上網一找,
基礎連接已關閉 連接被意外關閉 其實是沒訪問到證書,會不會和IIS有關系能,后來得證果然證書是需要添加IIS_User角色,配置完成后,終于,正常調用了
解決方法是
1.開始-運行 輸入mmc
2.文件-添加/刪除管理單元 在可用的管理單元中選擇 證書 添加到右側 彈框選擇計算機帳戶
3.展開個人-證書 選擇你導入的證書或從這里右鍵導入
4.右擊證書-所有任務-管理私鑰
5.添加IIS_IUser 勾選讀取就行
3.退款回調
這里也是一個小坑,退款回調里面有一個req_info的加密值,根據官方的介紹,需要base64解碼后根據商戶號相關的秘鑰再AES解密,如圖
后按照步驟base64解碼再AES解密,發(fā)現一只保存,提示存在非base64字符,于是監(jiān)聽發(fā)現,原來req_info本來就是base64,直接用MD5的key進行AES解密,得到相關的信息
4.回調告知微信
2個回調通知,一個是退款回調,需在微信后臺設置url,一個是支付回調,在申請訂單的時候帶上,另外就是回調后如何告知微信端我已經收到回調,官方的解釋是返回一傳xml數據如下:
但是實際上回復succes或者fail即可,中間遇到的問題是我回復了結果后,微信還是會多次回調結果給我,用SNAP抓包軟件查看一切正常,(微信IP->我的IP,我的IP返回結果給微信IP)后面把回調后我這邊的邏輯代碼注銷掉,回復結果就正常結束支付.再觀察SNAP,發(fā)現我的邏輯中間有一次調用第三方的接口,多了一個HttpWebRequest請求第三方充值的功能,(微信ip->我的IP,我的IP->第三方接口ip,第三方接口回復結果到我的ip,我的ip最后把處理結果反饋給微信ip)我把這一句注銷掉后也是正常,后面就考慮是否超時或者HTTPCONTEXT被改變了,結果我把這段邏輯代碼用asyn/await去做協(xié)程處理(之前有一個老哥告訴了我kotlin有協(xié)程這樣的一個概念,剛好運用上了),于是加上了異步處理,把支付回調反饋給微信端的結果馬上response回去,這下就正常了,asyn的task也照樣能跑,但是最后還是搞不懂為什么同步下去的不會正常回饋給微信端……
最后
終于,完成了所有支付到退款的流程,感覺微信的策略還是很嚴謹靠譜的,但是坑太多,個人感覺還是阿里的API寫得比較穩(wěn)一點,以上還是把支付流程封住成一個類,并且記錄一下,以免以后再遇到同樣的坑,接下來繼續(xù)研究sip,開源的C++項目……