信小程序支付(C#后台+前台)
今天为大家带来比较简单的支付后台处理
首先下载官方的c#模板(WxPayAPI),将模板(WxPayAPI)添加到服务器上,然后在WxPayAPI项目目录中添加两个“一般处理程序” (改名为GetOpenid.ashx、pay.ashx)
之后打开business目录下的JsApiPay.cs,在JsApiPay.cs中修改如下两处
然后在GetOpenid.ashx中加入代码如下:
- public class GetOpenid : IHttpHandler
- {
- public string openid { get; set; }
- public void ProcessRequest(HttpContext context)
- {
- string code = HttpContext.Current.Request.QueryString["code"];
- WxPayData data = new WxPayData();
- data.SetValue("appid", WxPayConfig.APPID);
- data.SetValue("secret", WxPayConfig.APPSECRET);
- data.SetValue("code", code);
- data.SetValue("grant_type", "authorization_code");
- string url = "https://api.weixin.qq.com/sns/oauth2/access_token?" + data.ToUrl();
- //请求url以获取数据
- string result = HttpService.Get(url);
- Log.Debug(this.GetType().ToString(), "GetOpenidAndAccessTokenFromCode response : " + result);
- //保存access_token,用于收货地址获取
- JsonData jd = JsonMapper.ToObject(result);
- //access_token = (string)jd["access_token"];
- //获取用户openid
- openid = (string)jd["openid"];
- context.Response.Write(openid);//获取H5调起JS API参数
- }
在pay.ashx中加入代码如下:
- public class pay : IHttpHandler
- {
- public void ProcessRequest(HttpContext context)
- {
- context.Response.ContentType = "text/plain";
- string openid = HttpContext.Current.Request.QueryString["openid"];
- string total_fee = HttpContext.Current.Request.QueryString["total_fee"];
- JsApiPay jsApiPay = new JsApiPay(context);
- jsApiPay.openid = openid;
- jsApiPay.total_fee = int.Parse(total_fee);
- WxPayData unifiedOrderResult = jsApiPay.GetUnifiedOrderResult();
- context.Response.Write(jsApiPay.GetJsApiParameters());//获取H5调起JS API参数
- }
然后发布就可以了(记得将相关的信息appid等填好)
微信小程序的代码如下:
- wxpay: function () {
- var that = this
- //登陆获取code
- wx.login({
- success: function (res) {
- console.log(res.code)
- //获取openid
- that.getOpenId(res.code)
- }
- });
- },
- getOpenId: function (code) {
- //获取openID
- var that = this;
- wx.request({
- url: 'http://*******/WxPayAPI/GetOpenid.ashx?code='+ code , //改为自己的域名
- data: {},
- // method: 'GET',
- success: function (res) {
- var a12=res.data
- that.generateOrder(a12)
- //console.log(a12)
- },
- fail: function () {
- // fail
- },
- complete: function () {
- // complete
- }
- })
- },
- /**生成商户订单 */
- generateOrder: function (openid) {
- var that = this;
- //console.log(openid)
- //统一支付
- wx.request({
- url: 'http://*******/WxPayAPI/pay.ashx', //改为自己的域名
- //method: 'GET',
- data: {
- total_fee: 1,//1分
- openid: openid,
- },
- header: {
- 'content-type': 'application/json'
- },
- success: function (res) {
- var pay = res.data
- //发起支付
- var timeStamp = pay.timeStamp;
- var packages = pay.package;
- var paySign = pay.paySign;
- var nonceStr = pay.nonceStr;
- var param = { "timeStamp": timeStamp, "package": packages, "paySign": paySign, "signType": "MD5", "nonceStr": nonceStr };
- that.pay(param)
- },
- })
- },
- /* 支付 */
- pay: function (param) {
- wx.requestPayment({
- timeStamp: param.timeStamp,
- nonceStr: param.nonceStr,
- package: param.package,
- signType: param.signType,
- paySign: param.paySign,
- success: function (res) {
- // success
- wx.navigateBack({
- delta: 1, // 回退前 delta(默认为1) 页面
- success: function (res1) {
- wx.showToast({
- title: '支付成功',
- icon: 'success',
- duration: 2000
- });
- },
- fail: function () {
- // fail
- },
- complete: function () {
- }
- })
- },
- fail: function (res) {
- // fail
- },
- complete: function () {
- // complete
- }
- })
- },
信小程序支付(C#后台+前台)的更多相关文章
- 【原创】微信小程序支付java后台案例(公众号支付同适用)(签名错误问题)
前言 1.微信小程序支付官方接口文档:[点击查看微信开放平台api开发文档]2.遇到的坑:预支付统一下单签名结果返回[签名错误]失败,建议用官方[签名验证工具]检查签名是否存在问题.3.遇到的坑:签名 ...
- 微信小程序支付c#后台实现
今天为大家带来比较简单的支付后台处理 首先下载官方的c#模板(WxPayAPI),将模板(WxPayAPI)添加到服务器上,然后在WxPayAPI项目目录中添加两个“一般处理程序” (改名为GetOp ...
- 微信小程序支付接口之Django后台
本文链接:https://blog.csdn.net/qq_41860162/article/details/89098694Python3-django-微信小程序支付接口调用工具类生成一系列微信官 ...
- 微信小程序+微信管理后台+微信用户前台
代码地址如下:http://www.demodashi.com/demo/15043.html #### 微信小程序+微信管理后台+微信用户前台 #### 产品介绍 基础功能开发:景区微信地图导游.天 ...
- .Net后台实现微信小程序支付
最近一直再研究微信支付和支付宝支付,官方支付文档中一直在讲与第三方支付打交道的原理,却没有介绍我们自己项目中的APP与后台该怎么交互(哈哈,人家也没必要介绍这一块).拜读了官方文档和前辈们的佳作,自己 ...
- 微信小程序支付源码,后台服务端代码
作者:尹华南,来自原文地址 微信小程序支付绕坑指南 步骤 A:小程序向服务端发送商品详情.金额.openid B:服务端向微信统一下单 C:服务器收到返回信息二次签名发回给小程序 D:小程序发起支付 ...
- SpringBoot2.0小程序支付功能实现weixin-java-pay
SpringBoot2.0小程序支付功能实现weixin-java-pay WxJava - 微信开发 Java SDK(开发工具包); 支持包括微信支付.开放平台.公众号.企业微信/企业号.小程序等 ...
- 微信小程序支付(JSAPI支付)
开发环境:.NET MVC+ ORM框架(EF) 一.参考文档: 1.微信JSAPI支付官方文档:https://pay.weixin.qq.com/wiki/doc/api/wxa/wxa_api. ...
- Asp.net Core 微信小程序支付
最近要做一个微信小程序支付的功能 在网上找了一下 .net Core做微信支付的博客 和 demo 几乎没有 自己研究了好几天 参考了 很多 大牛的博客 勉强做出来了 因为参数都没有 比如 opid ...
随机推荐
- [RxJS] Hot Observable, by .share()
.share() is an alias for .publish().refCount(). So if the source is not yet completed, no matter how ...
- crx 【 集合 】
Vimium dbepggeogbaibhgnhhndojpepiihcmeb-1.64-Crx4Chrome.com.crx https://www.crx4chrome.com/down/731/ ...
- 【35.02%】【codeforces 734A】Vladik and flights
time limit per test2 seconds memory limit per test256 megabytes inputstandard input outputstandard o ...
- 【TP SRM 703 div2 250】AlternatingString
Problem Statement A string of zeros and ones is called an alternating string if no two adjacent char ...
- 数学分析告诉偶们什么(vamei)
1]人生的痛苦在于追求错误的东西.所谓追求错误的东西,就是你在无限趋近于它的时候,才猛然发现,你和它是不连续的. 2]人和人就像数轴上的有理数点,彼此能够靠得非常近非常近,但你们之间始终存在隔阂. 3 ...
- [Recompose] Transform Props using Recompose --mapProps
Learn how to use the 'mapProps' higher-order component to modify an existing component’s API (its pr ...
- Linux中LVM2原理及制作LVM2
Linux中LVM2原理及制作LVM2 一.LVM原理 [MD]:Multi Device 多设备 Mdadm是一个用户空间工具,是RAID的管理工具,与真正的RAID工作没有太大关系.真正的RAID ...
- poj2151之概率DP
Check the difficulty of problems Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 4403 ...
- [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 ...
- [Angular Form] ngModel and ngModelChange
When using Radio button for Tamplate driven form, we want to change to the value change and preform ...