最近公司研發了幾個電商小程序,還有一個核心的電商直播,只要是電商通常都會涉及到交易信息,離不開支付系統,這裏咱們統一實現小程序的支付流程(與服務號實現步驟同樣)。php
目錄
一、開通小程序的支付能力
二、商戶後臺綁定同一主體的APPID並受權
三、預先設置回調地址,商戶後臺設置開發的配置
四、代碼實現統一支付五、微信支付回調
六、總結
前端
開通小程序的支付能力小程序
開通小程序支付功能比較簡單,基本上按微信文檔一步一步的申請就好,如圖後端
以上三個步驟就申請完成微信小程序
一、提交資料給微信api
二、微信審覈並簽署協議安全
三、商戶後臺綁定同主體的APPID微信
商戶後臺綁定同一主體的APPID並受權app
一、登陸商戶後臺https://pay.weixin.qq.com,進入產品中心—APPID受權管理,進入受權頁面如圖:學習
二、填寫相關已認證APPID信息,閱讀並簽署《微信支付商戶號與APPID受權協議》,點擊「確認」提交,發起受權申請,以下圖:
三、發起受權申請後,商戶需自行前往對應平臺確認受權申請。
小程序:前往公衆平臺,點擊「微信支付-商戶號管理」,查看相關商戶號信息,確認受權申請,或在「公衆平臺安全助手」下發的模板消息中確認受權信息;
公衆號/訂閱號:前往公衆平臺,點擊「微信支付-商戶號管理」,查看相關商戶號信息,確認受權申請;
APP:前往開放平臺,點擊「管理中心-查看-微信支付-商戶號管理」,查看相關商戶號信息,確認受權申請;
4. 以上步驟綁定成功,能夠實現微信支付功能。
預先設置回調地址,商戶後臺設置開發的配置
預先設置好回調地址後,方便支付成功後收到微信通知來處理業務,設置也比較簡單不用多說,如圖:
根據本身的需求設置不一樣的回調地址。
代碼實現統一支付
一、統一支付,只要是微信公衆號平臺的同一主體均可以使用同一個支付,只須要在商戶後臺綁定APPID便可。
微信小程序支付官方圖:
微信支付文檔說明地址:https://pay.weixin.qq.com/wiki/doc/api/native.php?chapter=9_1
引用包:
Senparc.Weixin.WxOpen
Senparc.Weixin.TenPay
註冊公衆號,小程序信息
services.AddSenparcGlobalServices(Configuration)
.AddSenparcWeixinServices(Configuration);
前端調用統一下單接口,獲取prepayId
IRegisterService register = RegisterService.Start(env, senparcSetting.Value).UseSenparcGlobal(false, null); register.UseSenparcWeixin(senparcWeixinSetting.Value, senparcSetting.Value) .RegisterTenpayV3(senparcWeixinSetting.Value, "appid");
部分前端代碼以下:
後端部分代碼截圖獲取prepayId,如需代碼請與我聯繫
提交統一支付成功後,會出現以下圖:
注:通常正常獲取到prepayid就能夠發起支付,請確保所給的參數正確。
微信支付回調
微信支付回調規則以下:
回調代碼實現
///<summary> /// 微信支付回調地址 /// </summary> /// <returns></returns> [HttpPost("PayNotifyUrl")] public ActionResult PayNotifyUrl() { ResponseResult result = new ResponseResult(); ResponseHandler resHandler = new ResponseHandler(HttpContext); string return_code = resHandler.GetParameter("return_code"); string return_msg = resHandler.GetParameter("return_msg"); try { var mch_key = Senparc.Weixin.Config.SenparcWeixinSetting.TenPayV3_Key; resHandler.SetKey(mch_key); var notifyXml = resHandler.ParseXML(); bool signFlag = resHandler.IsTenpaySign(); if (signFlag && return_code.ToUpper() == "SUCCESS") { string attach = resHandler.GetParameter("attach"); string device_info = resHandler.GetParameter("device_info"); string out_trade_no = resHandler.GetParameter("out_trade_no"); string transaction_id = resHandler.GetParameter("transaction_id"); string total_fee = resHandler.GetParameter("total_fee"); PayOrderNotifyParam param = new PayOrderNotifyParam() { PayNo = out_trade_no, Attach = attach, PayPrice = decimal.Parse(total_fee) / 100, TransactionNo = transaction_id, }; //回調參數說明:https://pay.weixin.qq.com/wiki/doc/api/app/app.php?chapter=9_7&index=3 //Logger.Info(string.Format("支付回調接收參數成功,notifyXml={0},param={1}", notifyXml, param.SerializeObject())); result = Service.PayNotifyUrl(param); if (result.errno != 0) { //回調處理邏輯失敗 Logger.Error(string.Format("支付回調處理失敗:支付單號:{0},{1}", param.PayNo, result.errmsg)); } else { Logger.Info(string.Format("支付回調處理成功,支付單號:{0}", param.PayNo)); string xml = string.Format(@"<xml> <return_code><![CDATA[{0}]]></return_code> <return_msg><![CDATA[{1}]]></return_msg> </xml>", return_code, return_msg); return Content(xml, "text/xml"); } } else { //錯誤的訂單處理 Logger.Error(string.Format("支付回調接失敗,signFlag={0},notifyXml={1}", signFlag, notifyXml)); } } catch (Exception ex) { Logger.Error(string.Format("支付回調異常:Message={0},StackTrace={1}", ex.Message, ex.StackTrace)); } return Content("fail", "text/xml"); }
回調接口最好驗證下簽名是否正確,驗證簽名請先設置下商戶KEY,如簽名成功,微信支付成功,這時能夠處理業務數據。
注:若是業務處理成功最好返回SUCCESS告訴微信,不然微信會隔一段時間就會回調一次,直到回調次數用盡,這裏也須要本身業務處理好狀態。
總結
以上流程就是微信支付過程,以上步驟因爲一些隱私問題部分代碼採用了截圖,若有不明白之處請與我聯繫,咱們一塊兒交流學習,下一篇文章咱們將實現微信退款功能。