如何用微信公眾號收款,公眾號收款開發(fā)流程
前幾天因為公司項目需求,要做一個用微信在線充值的功能,就是在微信的瀏覽器里面點擊一個網(wǎng)頁調(diào)起微信支付,現(xiàn)在大致來說一下如何用微信公眾號收款,微信支付之公眾號支付的開發(fā)流程:
首先你的公眾號必須是認證服務(wù)號,要開通了微信支付的權(quán)限;在開發(fā)寫代碼之前我們要把支付相關(guān)的一些信息設(shè)置做好,以利于后續(xù)操作,開通之后微信那邊就會給你發(fā)一封郵件,里面包含了你公眾號商戶平臺的后臺登陸相關(guān)的一些信息,登陸商戶平臺之后在->賬戶設(shè)置->API安全里面設(shè)置密鑰,這個在后面會用到;
賬戶參數(shù)說明
郵件中參數(shù)API參數(shù)名詳細說明
APPIDappidappid是微信公眾賬號或開放平臺APP的唯一標識,在公眾平臺申請公眾賬號或者在開放平臺申請APP賬號后,微信會自動分配對應(yīng)的appid,用于標識該應(yīng)用。商戶的微信支付審核通過郵件中也會包含該字段值。
微信支付商戶號mch_id商戶申請微信支付后,由微信支付分配的商戶收款賬號。
API密鑰key交易過程生成簽名的密鑰,僅保留在商戶系統(tǒng)和微信支付后臺,不會在網(wǎng)絡(luò)中傳播。商戶妥善保管該Key,切勿在網(wǎng)絡(luò)中傳輸,不能在其他客戶端中存儲,保證key不會被泄漏。商戶可根據(jù)郵件提示登錄微信商戶平臺進行設(shè)置。
AppsecretsecretAppSecret是APPID對應(yīng)的接口密碼,用于獲取接口調(diào)用憑證access_token時使用。在微信支付中,先通過OAuth2.0接口獲取用戶openid,此openid用于微信內(nèi)網(wǎng)頁支付模式下單接口使用。在開發(fā)模式中獲取AppSecret(成為開發(fā)者且?guī)ぬ枦]有異常狀態(tài))。
這些完成之后我們還要了解一下公眾號支付的一個業(yè)務(wù)流程:
商戶系統(tǒng)和微信支付系統(tǒng)主要交互:
1.商戶server調(diào)用統(tǒng)一下單接口請求訂單,api參見公共api【統(tǒng)一下單API】;在請求預(yù)支付訂單之前我們要調(diào)用微信OAuth2.0網(wǎng)頁授權(quán)獲取用戶微信OpenId,這里就不詳細說明了,下面是預(yù)支付下單的代碼實現(xiàn):
1 string timeStamp = TenPayUtil.GetTimestamp();
2 string nonceStr = TenPayUtil.GetNoncestr();
3 string paySign = string.Empty;
4
5 //創(chuàng)建支付應(yīng)答對象
6 var packageReqHandler = new RequestHandler(null);
7
8 string spbill_create_ip = Request.UserHostAddress;
9
10 //初始化
11 //packageReqHandler.Init();
12 //packageReqHandler.SetKey(TenPayInfo.Key);
13 //設(shè)置package訂單參數(shù)
14 packageReqHandler.SetParameter("appid", appID); //公眾賬號ID
15 packageReqHandler.SetParameter("body", StrUtil.GetCutString(productName, 100)); //不能超過127個字符
16 packageReqHandler.SetParameter("mch_id", mchid); //商戶號
17 packageReqHandler.SetParameter("nonce_str", nonceStr.ToLower()); //隨機字符串
18 packageReqHandler.SetParameter("notify_url", notifyUrl); //接收財付通通知的URL
19 packageReqHandler.SetParameter("openid", openId); //openid
20 packageReqHandler.SetParameter("out_trade_no", sp_billno); //商家訂單號
21 // packageReqHandler.SetParameter("attach", ""); //附加數(shù)據(jù) 未來可用于區(qū)分不同微信支付業(yè)務(wù)
22 packageReqHandler.SetParameter("spbill_create_ip", spbill_create_ip); //用戶的公網(wǎng)ip,不是商戶服務(wù)器IP
23 packageReqHandler.SetParameter("total_fee", (onlinePayMoney * 100).ToString("0")); //商品金額,以分為單位(money * 100).ToString()
24 packageReqHandler.SetParameter("trade_type", "JSAPI"); //交易類型
25
26 //獲取package包
27 string sign = packageReqHandler.CreateMd5Sign("key", TenPayInfo.Key);
28 packageReqHandler.SetParameter("sign", sign); //交易類型
29 string data = packageReqHandler.ParseXML();
30 LoggerHelper.Log(data);
31
32 //調(diào)用統(tǒng)一下單接口請求訂單
33 var result = TenPayV3Service.Unifiedorder(data);
34 LoggerHelper.Log(result);
35
36 var res = XDocument.Parse(result);
37
38 string prepayId = string.Empty;
39 if (res.Element("xml").Element("return_code").Value == "SUCCESS")
40 {
41 prepayId = res.Element("xml").Element("prepay_id").Value;
42 }
43
44 string package = string.Format("prepay_id={0}", prepayId);
45 timeStamp = TenPayUtil.GetTimestamp();
46
47 //設(shè)置支付參數(shù)
48 var paySignReqHandler = new RequestHandler(null);
49 paySignReqHandler.SetParameter("appId", appID);
50 paySignReqHandler.SetParameter("timeStamp", timeStamp);
51 paySignReqHandler.SetParameter("nonceStr", nonceStr);
52 paySignReqHandler.SetParameter("package", package);
53 paySignReqHandler.SetParameter("signType", "MD5");
54 paySign = paySignReqHandler.CreateMd5Sign("key", TenPayInfo.Key);
55
56 //將信息傳遞給支付頁面
57 ViewBag.appId = appID;
58 ViewBag.timeStamp = timeStamp;
59 ViewBag.nonceStr = nonceStr;
60 ViewBag.package = package;
61 ViewBag.paySign = paySign;
下面是頁面js相關(guān)代碼:
2.商戶server接收支付通知,api參見公共api【支付結(jié)果通知API】
1 [HttpPost]
2 public void NoticeUrl()
3 {
4 string xmlString = HttpClientHelper.GetPostString(Request); 5
6 //此處應(yīng)記錄日志
7 LoggerHelper.Log(string.Format("【微支付】異步通知參數(shù):{0}", xmlString)); 8
9 var returnMsg = new ReturnMessage() { Return_Code = "SUCCESS", Return_Msg = string.Empty };
12 //通知消息實體
13 NotifyMessage message = null;
15 //訂單處理相關(guān)的方法內(nèi)全局變量
16 bool isNeedDeal = false; //標識訂單是否需要處理
17 string orderNo = string.Empty; //訂單編號 (需要根據(jù)商家數(shù)據(jù)包字段判斷所屬訂單)
18 CorpSalesOrder saleOrder = null;
20 try
21 {
22 message = HttpClientHelper.XmlDeserialize
23 26 //訂單號 獲得
27 orderNo = message.Out_Trade_No;
28
29 if (string.IsNullOrEmpty(orderNo))
30 {
31 throw new InvalidOperationException("未找到該訂單信息.");
32 } 45 var doc = new XmlDocument();
46 doc.LoadXml(xmlString);
48 var dic = new Dictionary
49 string sign = string.Empty;
50 foreach (XmlNode node in doc.FirstChild.ChildNodes)
51 {
52 if (node.Name.ToLower() != "sign")
53 dic.Add(node.Name, node.InnerText);
54 else
55 sign = node.InnerText;
56 }
57 UnifiedWxPayModel model = UnifiedWxPayModel.CreateUnifiedModel(xddAppId, xddMchid, xddWxkey);
58 if (model.ValidateMD5Signature(dic, sign))
59 {
60 //處理通知 業(yè)務(wù)邏輯:
61 if (message.Return_Code == "SUCCESS")
62 {
63 if (message.Result_Code == "SUCCESS")
64 { //此處處理支付成功后的業(yè)務(wù)邏輯
78 }
79 else
80 {
81 throw new InvalidOperationException(string.Format("{0}:{1}", message.Err_Code, message.Err_Code_Des));
82 }
83 }
84 else
85 {
86 throw new InvalidOperationException(message.Return_Msg);
87 }
88 }
89 }
90 catch (InvalidOperationException e)
91 {
92 //此處記錄異常日志
93 returnMsg.Return_Code = "FAIL";
94 returnMsg.Return_Msg = e.Message;
95 LoggerHelper.Log("【微信支付異步通知】出錯,訂單編號:" + orderNo + ",錯誤原因:" + e.Message);
96 }
97 catch (Exception e)
98 {
99 //此處記錄異常日志
100 returnMsg.Return_Code = "FAIL";
101 returnMsg.Return_Msg = e.Message;
102 LoggerHelper.Log("【微信支付異步通知】出錯,訂單編號:" + orderNo + ",錯誤原因:" + (e.InnerException == null ? e.Message : e.InnerException.ToString()));
103 }
104 Response.Write(returnMsg.ToXmlString());
105 Response.End();
106 }
以上就是如何用微信公眾號收款,公眾號收款開發(fā)流程的內(nèi)容,更多更熱門的微信公眾號素材,歡迎瀏覽Hi商學(xué)院。