如何用微信公眾號收款,公眾號收款開發(fā)流程

2017-04-07|HiShop
導(dǎo)讀:前幾天因為公司項目需求,要做一個用微信在線充值的功能,就是在微信的瀏覽器里面點擊一個網(wǎng)頁調(diào)起微信支付,現(xiàn)在大致來說一下 如何用微信公眾號收款 ,微信支付之公眾號支付的...

  前幾天因為公司項目需求,要做一個用微信在線充值的功能,就是在微信的瀏覽器里面點擊一個網(wǎng)頁調(diào)起微信支付,現(xiàn)在大致來說一下如何用微信公眾號收款,微信支付之公眾號支付的開發(fā)流程:

  首先你的公眾號必須是認證服務(wù)號,要開通了微信支付的權(quán)限;在開發(fā)寫代碼之前我們要把支付相關(guān)的一些信息設(shè)置做好,以利于后續(xù)操作,開通之后微信那邊就會給你發(fā)一封郵件,里面包含了你公眾號商戶平臺的后臺登陸相關(guān)的一些信息,登陸商戶平臺之后在->賬戶設(shè)置->API安全里面設(shè)置密鑰,這個在后面會用到;

  

如何用微信公眾號收款,公眾號收款開發(fā)流程

 

  賬戶參數(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ù)流程:

  

如何用微信公眾號收款,公眾號收款開發(fā)流程

 

  商戶系統(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(xmlString);

  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é)院

TAGS: