今天为大家带来比较简单的支付后台处理

首先下载官方的c#模板(WxPayAPI),将模板(WxPayAPI)添加到服务器上,然后在WxPayAPI项目目录中添加两个“一般处理程序” (改名为GetOpenid.ashx、pay.ashx)

之后打开business目录下的JsApiPay.cs,在JsApiPay.cs中修改如下两处

然后在GetOpenid.ashx中加入代码如下:

  1. public class GetOpenid : IHttpHandler
  2. {
  3. public string openid { get; set; }
  4.  
  5. public void ProcessRequest(HttpContext context)
  6. {
  7.  
  8. string code = HttpContext.Current.Request.QueryString["code"];
  9. WxPayData data = new WxPayData();
  10. data.SetValue("appid", WxPayConfig.APPID);
  11. data.SetValue("secret", WxPayConfig.APPSECRET);
  12. data.SetValue("code", code);
  13. data.SetValue("grant_type", "authorization_code");
  14. string url = "https://api.weixin.qq.com/sns/oauth2/access_token?" + data.ToUrl();
  15.  
  16. //请求url以获取数据
  17. string result = HttpService.Get(url);
  18.  
  19. Log.Debug(this.GetType().ToString(), "GetOpenidAndAccessTokenFromCode response : " + result);
  20.  
  21. //保存access_token,用于收货地址获取
  22. JsonData jd = JsonMapper.ToObject(result);
  23. //access_token = (string)jd["access_token"];
  24.  
  25. //获取用户openid
  26. openid = (string)jd["openid"];
  27. context.Response.Write(openid);//获取H5调起JS API参数
  28.  
  29. }

在pay.ashx中加入代码如下:

  1. public class pay : IHttpHandler
  2. {
  3.  
  4. public void ProcessRequest(HttpContext context)
  5. {
  6. context.Response.ContentType = "text/plain";
  7.  
  8. string openid = HttpContext.Current.Request.QueryString["openid"];
  9. string total_fee = HttpContext.Current.Request.QueryString["total_fee"];
  10. JsApiPay jsApiPay = new JsApiPay(context);
  11. jsApiPay.openid = openid;
  12. jsApiPay.total_fee = int.Parse(total_fee);
  13. WxPayData unifiedOrderResult = jsApiPay.GetUnifiedOrderResult();
  14. context.Response.Write(jsApiPay.GetJsApiParameters());//获取H5调起JS API参数
  15. }

然后发布就可以了(记得将相关的信息appid等填好)

微信小程序的代码如下:

  1. wxpay: function () {
  2. var that = this
  3. //登陆获取code
  4. wx.login({
  5. success: function (res) {
  6. console.log(res.code)
  7. //获取openid
  8. that.getOpenId(res.code)
  9. }
  10. });
  11. },
  12. getOpenId: function (code) {
  13. //获取openID
  14.  
  15. var that = this;
  16. wx.request({
  17. url: 'http://*******/WxPayAPI/GetOpenid.ashx?code='+ code , //改为自己的域名
  18. data: {},
  19. // method: 'GET',
  20. success: function (res) {
  21. var a12=res.data
  22. that.generateOrder(a12)
  23. //console.log(a12)
  24. },
  25. fail: function () {
  26. // fail
  27. },
  28. complete: function () {
  29. // complete
  30. }
  31. })
  32. },
  33. /**生成商户订单 */
  34. generateOrder: function (openid) {
  35. var that = this;
  36. //console.log(openid)
  37. //统一支付
  38. wx.request({
  39. url: 'http://*******/WxPayAPI/pay.ashx', //改为自己的域名
  40. //method: 'GET',
  41. data: {
  42. total_fee: 1,//1分
  43. openid: openid,
  44. },
  45. header: {
  46. 'content-type': 'application/json'
  47. },
  48.  
  49. success: function (res) {
  50.  
  51. var pay = res.data
  52. //发起支付
  53.  
  54. var timeStamp = pay.timeStamp;
  55. var packages = pay.package;
  56. var paySign = pay.paySign;
  57. var nonceStr = pay.nonceStr;
  58. var param = { "timeStamp": timeStamp, "package": packages, "paySign": paySign, "signType": "MD5", "nonceStr": nonceStr };
  59.  
  60. that.pay(param)
  61. },
  62. })
  63. },
  64.  
  65. /* 支付 */
  66. pay: function (param) {
  67.  
  68. wx.requestPayment({
  69. timeStamp: param.timeStamp,
  70. nonceStr: param.nonceStr,
  71. package: param.package,
  72. signType: param.signType,
  73. paySign: param.paySign,
  74. success: function (res) {
  75. // success
  76.  
  77. wx.navigateBack({
  78. delta: 1, // 回退前 delta(默认为1) 页面
  79. success: function (res1) {
  80. wx.showToast({
  81. title: '支付成功',
  82. icon: 'success',
  83. duration: 2000
  84. });
  85.  
  86. },
  87. fail: function () {
  88. // fail
  89.  
  90. },
  91. complete: function () {
  92.  
  93. }
  94. })
  95. },
  96. fail: function (res) {
  97. // fail
  98. },
  99. complete: function () {
  100. // complete
  101. }
  102. })
  103. },

信小程序支付(C#后台+前台)的更多相关文章

  1. 【原创】微信小程序支付java后台案例(公众号支付同适用)(签名错误问题)

    前言 1.微信小程序支付官方接口文档:[点击查看微信开放平台api开发文档]2.遇到的坑:预支付统一下单签名结果返回[签名错误]失败,建议用官方[签名验证工具]检查签名是否存在问题.3.遇到的坑:签名 ...

  2. 微信小程序支付c#后台实现

    今天为大家带来比较简单的支付后台处理 首先下载官方的c#模板(WxPayAPI),将模板(WxPayAPI)添加到服务器上,然后在WxPayAPI项目目录中添加两个“一般处理程序” (改名为GetOp ...

  3. 微信小程序支付接口之Django后台

    本文链接:https://blog.csdn.net/qq_41860162/article/details/89098694Python3-django-微信小程序支付接口调用工具类生成一系列微信官 ...

  4. 微信小程序+微信管理后台+微信用户前台

    代码地址如下:http://www.demodashi.com/demo/15043.html #### 微信小程序+微信管理后台+微信用户前台 #### 产品介绍 基础功能开发:景区微信地图导游.天 ...

  5. .Net后台实现微信小程序支付

    最近一直再研究微信支付和支付宝支付,官方支付文档中一直在讲与第三方支付打交道的原理,却没有介绍我们自己项目中的APP与后台该怎么交互(哈哈,人家也没必要介绍这一块).拜读了官方文档和前辈们的佳作,自己 ...

  6. 微信小程序支付源码,后台服务端代码

    作者:尹华南,来自原文地址 微信小程序支付绕坑指南 步骤 A:小程序向服务端发送商品详情.金额.openid B:服务端向微信统一下单 C:服务器收到返回信息二次签名发回给小程序 D:小程序发起支付 ...

  7. SpringBoot2.0小程序支付功能实现weixin-java-pay

    SpringBoot2.0小程序支付功能实现weixin-java-pay WxJava - 微信开发 Java SDK(开发工具包); 支持包括微信支付.开放平台.公众号.企业微信/企业号.小程序等 ...

  8. 微信小程序支付(JSAPI支付)

    开发环境:.NET MVC+ ORM框架(EF) 一.参考文档: 1.微信JSAPI支付官方文档:https://pay.weixin.qq.com/wiki/doc/api/wxa/wxa_api. ...

  9. Asp.net Core 微信小程序支付

    最近要做一个微信小程序支付的功能 在网上找了一下 .net Core做微信支付的博客 和 demo 几乎没有 自己研究了好几天 参考了 很多 大牛的博客 勉强做出来了  因为参数都没有 比如 opid ...

随机推荐

  1. [RxJS] Hot Observable, by .share()

    .share() is an alias for .publish().refCount(). So if the source is not yet completed, no matter how ...

  2. crx 【 集合 】

    Vimium dbepggeogbaibhgnhhndojpepiihcmeb-1.64-Crx4Chrome.com.crx https://www.crx4chrome.com/down/731/ ...

  3. 【35.02%】【codeforces 734A】Vladik and flights

    time limit per test2 seconds memory limit per test256 megabytes inputstandard input outputstandard o ...

  4. 【TP SRM 703 div2 250】AlternatingString

    Problem Statement A string of zeros and ones is called an alternating string if no two adjacent char ...

  5. 数学分析告诉偶们什么(vamei)

    1]人生的痛苦在于追求错误的东西.所谓追求错误的东西,就是你在无限趋近于它的时候,才猛然发现,你和它是不连续的. 2]人和人就像数轴上的有理数点,彼此能够靠得非常近非常近,但你们之间始终存在隔阂. 3 ...

  6. [Recompose] Transform Props using Recompose --mapProps

    Learn how to use the 'mapProps' higher-order component to modify an existing component’s API (its pr ...

  7. Linux中LVM2原理及制作LVM2

    Linux中LVM2原理及制作LVM2 一.LVM原理 [MD]:Multi Device 多设备 Mdadm是一个用户空间工具,是RAID的管理工具,与真正的RAID工作没有太大关系.真正的RAID ...

  8. poj2151之概率DP

    Check the difficulty of problems Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 4403   ...

  9. [Grid Layout] Describe a grid layout using grid-template-areas

    We can describe the nature of a grid in an ‘ASCII-art’ way with grid-template-areas. Let’s see how t ...

  10. [Angular Form] ngModel and ngModelChange

    When using Radio button for Tamplate driven form, we want to change to the value change and preform ...