系统城装机大师 - 固镇县祥瑞电脑科技销售部宣传站!

当前位置:首页 > 网络编程 > ASP.NET > 详细页面

ASP.NET MVC 开发微信支付H5的实现示例(外置浏览器支付)

时间:2020-02-03来源:系统城作者:电脑系统城

H5支付是指商户在微信客户端外的移动端网页展示商品或服务,用户在前述页面确认使用微信支付时,商户发起本服务呼起微信客户端进行支付。

主要用于触屏版的手机浏览器请求微信支付的场景。可以方便的从外部浏览器唤起微信支付。

微信开放平台上的也只是简单的介绍了一下逻辑和常见问题,网上查看了很多,说的都不够具体

首先需要在微信商户平台里开通 H5支付

申请入口:登录商户平台-->产品中心-->我的产品-->支付产品-->H5支付

代码逻辑:

1、用户在商户侧完成下单,使用微信支付进行支付

2、由商户后台向微信支付发起下单请求(调用统一下单接口)注:交易类型trade_type=MWEB

3、统一下单接口返回支付相关参数给商户后台,如支付跳转url(参数名“mweb_url”),商户通过mweb_url调起微信支付中间页

4、中间页进行H5权限的校验,安全性检查

5、如支付成功,商户后台会接收到微信侧的异步通知

6、用户在微信支付收银台完成支付或取消支付,返回商户页面(默认为返回支付发起页面)

7、商户在展示页面,引导用户主动发起支付结果的查询

8,9、商户后台判断是否接到收微信侧的支付结果通知,如没有,后台调用我们的订单查询接口确认订单状态

10、展示最终的订单支付结果给用户

我们需要用到的参数:

  • AppID(应用ID)
  • AppSecret(应用密钥)
  • 微信支付商户号
  • 微信商户支付密钥

我这里使用了第三方封装的SDK。谢谢开发者SDK的帮助。

Senparc.Weixin

献上地址:https://weixin.senparc.com/

H5支付其实就是生成一个链接,点击后会激活微信APP,弹出支付窗口

所以需要生成一个符合规则的Url,引入SDK


 
  1. Com.Wxpay.WxPayConfig wxConfig = new Com.Wxpay.WxPayConfig();
  2. Senparc.Weixin.MP.TenPayLibV3.RequestHandler packageReqHandler = newSenparc.Weixin.MP.TenPayLibV3.RequestHandler(null);
  3. packageReqHandler.SetParameter("appid", wxConfig.appid);//APPID
  4. packageReqHandler.SetParameter("mch_id", wxConfig.mchid);//商户号
  5. packageReqHandler.SetParameter("nonce_str",Senparc.Weixin.MP.TenPayLibV3.TenPayV3Util.GetNoncestr());
  6. packageReqHandler.SetParameter("body", "测试商品");
  7. packageReqHandler.SetParameter("out_trade_no", model.OrderID);//订单号
  8. packageReqHandler.SetParameter("total_fee", cost.ToString()); //金额,以分为单位
  9. packageReqHandler.SetParameter("spbill_create_ip", Request.UserHostAddress);//IP
  10. packageReqHandler.SetParameter("notify_url", "http://" + HttpContext.Request.Url.Host +"/WxPay/PayNotifyUrl"); //回调地址
  11. packageReqHandler.SetParameter("trade_type", "MWEB");//这个不可以改。固定为Mweb
  12. packageReqHandler.SetParameter("sign", packageReqHandler.CreateMd5Sign("key",wxConfig.key));
  13. string data = packageReqHandler.ParseXML();
  14. var urlFormat = "https://api.mch.weixin.qq.com/pay/unifiedorder";
  15. var formDataBytes = data == null ? new byte[0] : Encoding.UTF8.GetBytes(data);
  16. MemoryStream ms = new MemoryStream();
  17. ms.Write(formDataBytes, 0, formDataBytes.Length);
  18. ms.Seek(0, SeekOrigin.Begin);
  19. var result = RequestUtility.HttpPost(urlFormat, null, ms);
  20.  
  21. var res = System.Xml.Linq.XDocument.Parse(result);
  22. string mweb_url = res.Element("xml").Element("mweb_url").Value;
  23.  

然后我们会得到下面的Xml


 
  1. <xml>
  2. <return_code><![CDATA[SUCCESS]]></return_code>
  3. <return_msg><![CDATA[OK]]></return_msg>
  4. <appid><![CDATA[wx***********]]></appid>
  5. <mch_id><![CDATA[1*******]]></mch_id>
  6. <nonce_str><![CDATA[4rN3Sy63EsAErTq7]]></nonce_str>
  7. <sign><![CDATA[0E34B9B750778540436A5CDF005212CF]]></sign>
  8. <result_code><![CDATA[SUCCESS]]></result_code>
  9. <prepay_id><![CDATA[wx201********************************]]></prepay_id>
  10. <trade_type><![CDATA[MWEB]]></trade_type>
  11. <mweb_url><![CDATA[https://wx.tenpay.com/cgi-bin/mmpayweb-bin/checkmweb?prepay_id=*******71655&package=1******9]]></mweb_url>
  12. </xml>

提取到   mweb_url,绑定到href上即可。

<a href="https://wx.tenpay.com/cgi-bin/mmpayweb-bin/checkmweb?prepay_id=*******71655&package=1******9" rel="external nofollow" >立即支付</a>

支付成功之后,在回调地址里处理业务逻辑


 
  1. /// <summary>
  2. /// 支付结果回调地址
  3. /// </summary>
  4. /// <returns></returns>
  5. [HttpPost]
  6. public virtual ActionResult PayNotifyUrl()
  7. {
  8.  
  9. Com.Wxpay.WxPayConfig wxConfig = new Com.Wxpay.WxPayConfig();
  10. Senparc.Weixin.MP.TenPayLibV3.ResponseHandler payNotifyRepHandler = newSenparc.Weixin.MP.TenPayLibV3.ResponseHandler(null);
  11. payNotifyRepHandler.SetKey(wxConfig.key);
  12.  
  13. string return_code = payNotifyRepHandler.GetParameter("return_code");
  14. string return_msg = payNotifyRepHandler.GetParameter("return_msg");
  15. string xml = string.Format(@"<xml><return_code><![CDATA[{0}]]></return_code><return_msg><![CDATA[{1}]]></return_msg></xml>", return_code, return_msg);
  16.  
  17. if (return_code.ToUpper() != "SUCCESS")
  18. {
  19. return Content(xml, "text/xml");
  20. }
  21.  
  22. string out_trade_no = payNotifyRepHandler.GetParameter("out_trade_no");
  23. //微信服务器可能会多次推送到本接口,这里需要根据out_trade_no去查询订单是否处理,如果处理直接返回:return Content(xml, "text/xml"); 不跑下面代码
  24.  
  25. //验证请求是否从微信发过来(安全)
  26. if (payNotifyRepHandler.IsTenpaySign())
  27. {
  28. //TO DO
  29. }
  30. else
  31. {
  32.  
  33. }
  34. return Content(xml, "text/xml");
  35. }
  36.  

注意:

不要使用此url直接打开,会提示错误。

微信官方文档地址:https://pay.weixin.qq.com/wiki/doc/api/H5.php?chapter=15_1

分享到:

相关信息

系统教程栏目

栏目热门教程

人气教程排行

站长推荐

热门系统下载