zoukankan      html  css  js  c++  java
  • 【分享·微信支付】 C# MVC 微信支付教程系列之公众号支付

    微信支付教程系列之公众号支付
     
            今天,我们接着讲微信支付的系列教程,前面,我们讲了这个微信红包和扫码支付。现在,我们讲讲这个公众号支付。公众号支付的应用环境常见的用户通过公众号,然后再通过公众号里面的菜单链接,进入公众号的商城,然后在里面完成购买和支付功能,我们可以看看官方对这个公众号支付的场景的解释,链接:https://pay.weixin.qq.com/wiki/doc/api/jsapi.php?chapter=7_1,通过这个官方的解释,那我们大概清楚这个公众号的用途了,下面,我就说说,做这个公众号支付的准备工作有哪些了。
            1、下载微信web开发者工具,工具的使用方式,也看链接,地址:https://mp.weixin.qq.com/wiki?t=resource/res_main&id=mp1455784140&token=&lang=zh_CN
            2、配置“微信支付”环境,如下图:
            3、授权获取用户信息,如下图:
     
     
            下面开始,一步一步往下走。
            一、我们先开发程序,首先,新建一个MVC工程(asp.net的话,官方给的demo就是asp.net的,可以下载来参考:https://pay.weixin.qq.com/wiki/doc/api/jsapi.php?chapter=11_1),名为:微信支付之公众号支付,如下图:
     
     
            然后右键项目,我们修改一下属性,如下图:
     
     
    然后我们再把程序自动生成的HomeController.cs和View里面的删掉,再新建一个HomeController.cs和添加View,代码如下:
     
    复制代码
    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Web;
    using System.Web.Mvc;
    
    namespace Web.Controllers
    {
        public class HomeController : Controller
        {
            // GET: Home
            public ActionResult Index()
            {
                return View();
            }
        }
    } 
    复制代码
     
    View代码:
    复制代码
    @{
        Layout = null;
    }
    
    <!DOCTYPE html>
    
    <html>
    <head>
        <meta name="viewport" content="width=device-width" />
        <title>Index</title>
    </head>
    <body>
        <div> 
        </div>
    </body>
    </html>
    复制代码
     
            嗯,没错,目前还是空的,现在我们开始写前台,代码如下(我先贴上代码,后续再解释为啥这么做,因为如果一步步的写下去,按照前面两个的篇幅来,我觉得都可以开课了,所以,我先上代码,然后再一步步解释。): 
    复制代码
    @{
        Layout = null;
    }
    
    <!DOCTYPE html>
    
    <html>
    <head>
        <meta name="viewport" content="width=device-width" />
        <title>电表充值服务</title>
        <link href="~/Scripts/jquery-easyui-1.4.5/themes/bootstrap/easyui.css" rel="stylesheet" />
        <link href="~/Scripts/jquery-easyui-1.4.5/themes/mobile.css" rel="stylesheet" />
        <link href="~/Scripts/jquery-easyui-1.4.5/themes/icon.css" rel="stylesheet" />
        <style type="text/css">
            body{
                margin:0;
                padding:0;
            }
            .logo {
                 100%;
                height: 70px;
                background: url(/Images/EleLogo.png) 0 0 no-repeat;
                background-size: 100% 100%;
                padding: 0;
                margin: 0;
            }
    
            .line {
                 100%;
                float: left;
                height: auto;
                text-align: center;
                margin-top: 10px;
            }
    
            .lineText {
                 100%;
                float: left;
                height: auto;
                text-indent: 5%;
                text-align: left;
                font-size: x-large;
                margin: 0;
            }
    
            .function {
                height: 60pt;
                line-height: 60pt;
                 45%;
                float: left;
                border-radius: 10px;
                background-color: #990000;
                margin-left: 8pt;
            }
    
            .title {
                font-family: "微软雅黑";
                font-size: x-large;
                color: white;
            }
    
            a {
                text-decoration: none;
                color: white;
            }
    
            input {
                vertical-align: central;
            }
    
            label {
                vertical-align: central;
            }
    
            .lbBlock {
                border: 1px solid #808080;
                background-color: grey;
                 90%;
                margin-left: 5%;
                font-size: x-large;
                border-radius: 10px;
                text-align: left;
                text-indent: 10pt;
                height: 30pt;
                padding-top: 5pt;
            }
    
            .btn {
                 90%;
                height: 35pt;
                font-size: x-large;
                background-color: #990000;
                color: white;
                background: url(/Images/red.png) 0 0 repeat;
                border: none;
                border-radius: 10px;
                margin: 10px 0 0 0;
            }
    
            .input {
                height: 30pt;
                 90%;
                font-size: x-large;
                border-radius: 10px;
                margin: 0;
                padding: 0;
            }
        </style>
    
    </head>
    <body>
        <div class="logo">
        </div>
        <form id="ChargeForm">        
            <div class="line">
                <div class="lineText">
                    充值金额:
                </div>
            </div>
            <div class="line">
                <input type="number" id="ChargeVal" name="ChargeVal" class="input" placeholder="单位:元" />
            </div>       
        </form>
        <div class="line">
            <input type="button" class="btn" value="立即充值" onclick="fCharge()" style="margin-top: 20px;" />
        </div>
        <div class="line">
            <input type="button" id="btnHome" class="btn" value="返回主页" onclick="fBackHome()" />
        </div>
        <script src="~/Scripts/jquery-easyui-1.4.5/jquery.min.js"></script>
        <script src="~/Scripts/jquery-easyui-1.4.5/jquery.easyui.min.js"></script>
        <script src="~/Scripts/jquery-easyui-1.4.5/jquery.easyui.mobile.js"></script>
        <script src="~/Scripts/jquery-easyui-1.4.5/easyloader.js"></script>
        <script type="text/javascript">
            $(function () {
                var vCode = getQueryString("code");
                if (vCode != "" && vCode != null) {
                    //alert(vCode);
                    $.ajax({
                        type: 'post',
                        data: {
                            code: vCode
                        },
                        url: '/Home/getWxInfo',
                        success: function (sjson) {
                            //alert(sjson);
                            //var vData = JSON.stringify(sjson);
                            //alert(vData);
                            $.messager.show({
                                title: '提示',
                                msg: '欢迎您来到微信端充值中心。'
                            });
                        }
                    })
                }
                else {
                    $.ajax({
                        type: 'post',
                        url: '/Home/getCode',
                        success: function (sjson) {
                            //alert(sjson);
                            location.href = sjson;
                        }
                    })
                }
            })
            //获取url的参数
            function getQueryString(name) {
                var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)", "i");
                var r = window.location.search.substr(1).match(reg);
                if (r != null) return unescape(r[2]); return null;
            }
    
    
    
    
    
            //初始化微信支付环境
            function fCharge() {
                if (typeof WeixinJSBridge == "undefined") {
                    if (document.addEventListener) {
                        document.addEventListener('WeixinJSBridgeReady', onBridgeReady, false);
                    } else if (document.attachEvent) {
                        document.attachEvent('WeixinJSBridgeReady', onBridgeReady);
                        document.attachEvent('onWeixinJSBridgeReady', onBridgeReady);
                    }
                } else {
                    fPostCharge();
                }
            }
            //提交充值数据
            function fPostCharge() {
                var vChargeVal = $("#ChargeVal").val();
                vChargeVal = parseFloat(vChargeVal);
                if (vChargeVal > 0) {
                    $.messager.progress({
                        title: "",
                        msg: "正在调用微信支付接口,请稍后..."
                    });
                    $.ajax({
                        type: "post",
                        data: "totalfee=" + vChargeVal,
                        url: "/Home/MeterRecharge",
                        success: function (json) {
                            $.messager.progress('close');//记得关闭
                            //var json = eval("(" + msg + ")");//转换后的JSON对象
                            onBridgeReady(json);
                        },
                        error: function () {
                            $.messager.progress('close');//记得关闭
                            $.messager.alert("提示", '调用微信支付模块失败,请稍后再试。', 'info')
                        }
                    })
                }
                else {
                    alert("房间名或者充值金额不可以为空或者为负数,请确认后再试.")
                }
            }
            //调用微信支付模块
            function onBridgeReady(json) {
                WeixinJSBridge.invoke(
               'getBrandWCPayRequest', {
                   "appId": json.appId,     //公众号名称,由商户传入
                   "timeStamp": json.timeStamp,         //时间戳,自1970年以来的秒数
                   "nonceStr": json.nonceStr, //随机串
                   "package": json.packageValue,
                   "signType": "MD5",         //微信签名方式:
                   "paySign": json.paySign //微信签名
               },
               function (res) {
                   if (res.err_msg == "get_brand_wcpay_request:ok") {
                       //alert("支付成功,请稍后查询余额,如有疑问,请联系管理员.");
                       fAlreadyPay();
                   }     // 使用以上方式判断前端返回,微信团队郑重提示:res.err_msg将在用户支付成功后返回    ok,但并不保证它绝对可靠。
               }
                );
            }
            function fBackHome() {
                location.href = "/";
            }
        </script>
    </body>
    </html>
    复制代码
     
    后台代码如下:
     
    复制代码
    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Web;
    using System.Web.Mvc;
    using Web.Models;
    using WxPayAPI;
    
    namespace Web.Controllers
    {
        public class HomeController : Controller
        {
            JsApiPay jsApiPay = new JsApiPay();
            // GET: Home
            public ActionResult Index()
            {
                if (Session["openid"] == null)
                {
                    try
                    {
                        //调用【网页授权获取用户信息】接口获取用户的openid和access_token
                        GetOpenidAndAccessToken();
    
                    }
                    catch (Exception ex)
                    {
                        //Response.Write(ex.ToString());
                        //throw;
                    }
                }
                return View();
            }
    
    
            /**
            * 
            * 网页授权获取用户基本信息的全部过程
            * 详情请参看网页授权获取用户基本信息:http://mp.weixin.qq.com/wiki/17/c0f37d5704f0b64713d5d2c37b468d75.html
            * 第一步:利用url跳转获取code
            * 第二步:利用code去获取openid和access_token
            * 
            */
            public void GetOpenidAndAccessToken()
            {
                if (Session["code"] != null)
                {
                    //获取code码,以获取openid和access_token
                    string code = Session["code"].ToString();
                    Log.Debug(this.GetType().ToString(), "Get code : " + code);
                    jsApiPay.GetOpenidAndAccessTokenFromCode(code);
                }
                else
                {
                    //构造网页授权获取code的URL
                    string host = Request.Url.Host;
                    string path = Request.Path;
                    string redirect_uri = HttpUtility.UrlEncode("http://" + host + path);
                    //string redirect_uri = HttpUtility.UrlEncode("http://gzh.lmx.ren");
                    WxPayData data = new WxPayData();
                    data.SetValue("appid", WxPayConfig.APPID);
                    data.SetValue("redirect_uri", redirect_uri);
                    data.SetValue("response_type", "code");
                    data.SetValue("scope", "snsapi_base");
                    data.SetValue("state", "STATE" + "#wechat_redirect");
                    string url = "https://open.weixin.qq.com/connect/oauth2/authorize?" + data.ToUrl();
                    Log.Debug(this.GetType().ToString(), "Will Redirect to URL : " + url);
                    Session["url"] = url;               
                }
            }
    
    
            /// <summary>
            /// 获取code
            /// </summary>
            /// <returns></returns>
            [HttpPost]
            public ActionResult getCode()
            {
                object objResult = "";
                if (Session["url"] != null)
                {
                    objResult = Session["url"].ToString();
                }
                else
                {
                    objResult = "url为空。";
                }
                return Json(objResult);
            }
    
            /// <summary>
            /// 通过code换取网页授权access_token和openid的返回数据
            /// </summary>
            /// <returns></returns>
            [HttpPost]
            public ActionResult getWxInfo()
            {
                object objResult = "";
                string strCode = Request.Form["code"];
                if (Session["access_token"] == null || Session["openid"] == null)
                {
                    jsApiPay.GetOpenidAndAccessTokenFromCode(strCode);
                }
                string strAccess_Token = Session["access_token"].ToString();
                string strOpenid = Session["openid"].ToString();
                objResult = new { openid = strOpenid, access_token = strAccess_Token };
                return Json(objResult);
            }
    
    
    
    
            /// <summary>
            /// 充值
            /// </summary>
            /// <returns></returns>
            [HttpPost]
            public ActionResult MeterRecharge()
            {
                object objResult = "";
                string strTotal_fee = Request.Form["totalfee"];
                string strFee = (double.Parse(strTotal_fee) * 100).ToString();
    
                //若传递了相关参数,则调统一下单接口,获得后续相关接口的入口参数
                jsApiPay.openid = Session["openid"].ToString();
                jsApiPay.total_fee = int.Parse(strFee);
    
                //JSAPI支付预处理
                try
                {
                    string strBody = "南宫萧尘微信支付";//商品描述
                    WxPayData unifiedOrderResult = jsApiPay.GetUnifiedOrderResult(strBody);
                    WxPayData wxJsApiParam = jsApiPay.GetJsApiParameters();//获取H5调起JS API参数,注意,这里引用了官方的demo的方法,由于原方法是返回string的,所以,要对原方法改为下面的代码,代码在下一段
    
                    ModelForOrder aOrder = new ModelForOrder()
                    {
                        appId = wxJsApiParam.GetValue("appId").ToString(),
                        nonceStr = wxJsApiParam.GetValue("nonceStr").ToString(),
                        packageValue = wxJsApiParam.GetValue("package").ToString(),
                        paySign = wxJsApiParam.GetValue("paySign").ToString(),
                        timeStamp = wxJsApiParam.GetValue("timeStamp").ToString(),
                        msg = "成功下单,正在接入微信支付."
                    };
                    objResult = aOrder;
                }
                catch (Exception ex)
                {
                    ModelForOrder aOrder = new ModelForOrder()
                    {
                        appId = "",
                        nonceStr = "",
                        packageValue = "",
                        paySign = "",
                        timeStamp = "",
                        msg = "下单失败,请重试,多次失败,请联系管理员."
                    };
                    objResult = aOrder;
                }
                return Json(objResult);
            }
    
    
        }
    } 
    复制代码

     这里就是上面修改了的代码,童鞋们请注意

    复制代码
            /**
            *  
            * 从统一下单成功返回的数据中获取微信浏览器调起jsapi支付所需的参数,
            * 微信浏览器调起JSAPI时的输入参数格式如下:
            * {
            *   "appId" : "wx2421b1c4370ec43b",     //公众号名称,由商户传入     
            *   "timeStamp":" 1395712654",         //时间戳,自1970年以来的秒数     
            *   "nonceStr" : "e61463f8efa94090b1f366cccfbbb444", //随机串     
            *   "package" : "prepay_id=u802345jgfjsdfgsdg888",     
            *   "signType" : "MD5",         //微信签名方式:    
            *   "paySign" : "70EA570631E4BB79628FBCA90534C63FF7FADD89" //微信签名 
            * }
            * @return string 微信浏览器调起JSAPI时的输入参数,json格式可以直接做参数用
            * 更详细的说明请参考网页端调起支付API:http://pay.weixin.qq.com/wiki/doc/api/jsapi.php?chapter=7_7
            * 
            */
            public WxPayData GetJsApiParameters()
            {
                Log.Debug(this.GetType().ToString(), "JsApiPay::GetJsApiParam is processing...");
    
                WxPayData jsApiParam = new WxPayData();
                jsApiParam.SetValue("appId", unifiedOrderResult.GetValue("appid"));
                jsApiParam.SetValue("timeStamp", WxPayApi.GenerateTimeStamp());
                jsApiParam.SetValue("nonceStr", WxPayApi.GenerateNonceStr());
                jsApiParam.SetValue("package", "prepay_id=" + unifiedOrderResult.GetValue("prepay_id"));
                jsApiParam.SetValue("signType", "MD5");
                jsApiParam.SetValue("paySign", jsApiParam.MakeSign());
    
                string parameters = jsApiParam.ToJson();
                Log.Debug(this.GetType().ToString(), "Get jsApiParam : " + parameters);
                return jsApiParam;
            }
    复制代码
     
     
     
    ModelForOrder类的代码:
     
    复制代码
    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Web;
    
    namespace Web.Models
    {
        public class ModelForOrder
        {
            public string appId { get; set; }
            public string timeStamp { get; set; }
            public string nonceStr { get; set; }
            public string packageValue { get; set; }
            public string paySign { get; set; }
    
            public string msg { get; set; }
        }
    }  
    复制代码
     
    还有一个地方需要注意,修改一下的就是这里WxLib/business/JsApiPay.cs,如下图:
     
    最后,把程序发布出来,这次咱们把Web发布在http://gzh.lmx.ren上 ,然后再把接口权限,改为这样的,如下图:
     
     
            注意,这里面的域名和上面我们发布的域名要一致。
     
            除此以外,我们还需要改这里:
            就是一定要授权这里,否则,支付的时候,会提示其他错误,具体,我就不测试了。
            
            另外,这里其实已经完成了这个公众号的支付的流程了,但是,我们页面上,会友善的提醒(其实不友善,提示是红色的,在头部,提示别输入密码什么),这是因为,我们还没把咱们这个http://gzh.lmx.ren域名设置为安全域名,设置之后,就不会在提示了。设置方法如下图:
     
    在这里面加入咱们的域名,就完美了。。。
     
            我的代码都尽量精简,多余的,我都会丢掉,就是为了避免混淆视听。如果代码里面,有写的不清楚的,可以私信问我,或群里来问我,群号在文章末端。
     
     
    现在,我开始一一解释我上面的做法。
            首先,在后端,页面加载的时候,他会先执行
            
    复制代码
    public ActionResult Index()
            {
                if (Session["openid"] == null)
                {
                    try
                    {
                        //调用【网页授权获取用户信息】接口获取用户的openid和access_token
                        GetOpenidAndAccessToken();
    
                    }
                    catch (Exception ex)
                    {
                        //Response.Write(ex.ToString());
                        //throw;
                    }
                }
                return View();
            } 
    复制代码
    这里面就是为了获取用户的Openid和Access_token,这个用途很大,还有就是,我们通过代码可以知道,我们通过这个方法,可以获取到微信的一些相关信息,获取完了之后,他会返回到我们的页面上来,url就存在一个session里面,如下:
    Session["url"] = url;        
     
    接着,在前端:
            当页面加载完毕之后,会执行以下JS方法,如下:
          
    复制代码
      $(function () {
                var vCode = getQueryString("code");
                if (vCode != "" && vCode != null) {
                    //alert(vCode);
                    $.ajax({
                        type: 'post',
                        data: {
                            code: vCode
                        },
                        url: '/Home/getWxInfo',
                        success: function (sjson) {
                            //alert(sjson);
                            //var vData = JSON.stringify(sjson);
                            //alert(vData);
                            $.messager.show({
                                title: '提示',
                                msg: '欢迎您来到微信端充值中心。'
                            });
                        }
                    })
                }
                else {
                    $.ajax({
                        type: 'post',
                        url: '/Home/getCode',
                        success: function (sjson) {
                            //alert(sjson);
                            location.href = sjson;
                        }
                    })
                }
            }) 
    复制代码
     
    他会先获取浏览器的url,然后获取code,就是一般url后面的xxx.com?code=xxx,这里面就是首先判断有无code,如果没有code,则,我们去后台请求这个code。为什么请求这个code呢?我们来看这个方法: getWxInfo,如下图:
           
    复制代码
     /// <summary>
            /// 获取code
            /// </summary>
            /// <returns></returns>
            [HttpPost]
            public ActionResult getCode()
            {
                object objResult = "";
                if (Session["url"] != null)
                {
                    objResult = Session["url"].ToString();
                }
                else
                {
                    objResult = "url为空。";
                }
                return Json(objResult);
            } 
    复制代码
     
    他就会返回url到前端,前端通过js去访问那个网址,那个网址就是微信端获取到我们的信息之后,给我们按照规则再返回一个url,这rul就是我们后面需要后去的code的url。这个code对我们至关重要,因为后面我们要做跟支付有关的工作,都用到的。有了code,我们才能拿到openid和access_token。具体看代码逻辑也可以明了。
            好,走到这一步,我们已经知道openid和access_token了,这个时候,我们就负责处理前端的东西。
            前端,我就一个金额输入框,然后一个提交,实际应用中,我们肯定还需要传入商品的参数,我这里面就不写那些多余的了,后续你们自己加进去就可以了。这里面在点击提交的时候,会调用微信的环境,看下面的代码:
          
    复制代码
      //初始化微信支付环境
            function fCharge() {
                if (typeof WeixinJSBridge == "undefined") {
                    if (document.addEventListener) {
                        document.addEventListener('WeixinJSBridgeReady', onBridgeReady, false);
                    } else if (document.attachEvent) {
                        document.attachEvent('WeixinJSBridgeReady', onBridgeReady);
                        document.attachEvent('onWeixinJSBridgeReady', onBridgeReady);
                    }
                } else {
                    fPostCharge();
                }
            } 
    复制代码
    他会初始化一下环境,如果初始化成功,代表,这个页面是在微信客户端里面运行的,那么我们就给他运行我们真正的充值代码提交,所以,就会执行:fPostCharge();
     
    提交之后,就会进入后台,后台需要组织我们前台需要用到的参数,其中包括如下:
            
     
    复制代码
    /// <summary>
            /// 充值
            /// </summary>
            /// <returns></returns>
            [HttpPost]
            public ActionResult MeterRecharge()
            {
                object objResult = "";
                string strTotal_fee = Request.Form["totalfee"];
                string strFee = (double.Parse(strTotal_fee) * 100).ToString();
    
                //若传递了相关参数,则调统一下单接口,获得后续相关接口的入口参数
                jsApiPay.openid = Session["openid"].ToString();
                jsApiPay.total_fee = int.Parse(strFee);
    
                //JSAPI支付预处理
                try
                {
                    string strBody = "南宫萧尘微信支付";//商品描述
                    WxPayData unifiedOrderResult = jsApiPay.GetUnifiedOrderResult(strBody);
                    WxPayData wxJsApiParam = jsApiPay.GetJsApiParameters();//获取H5调起JS API参数
    
                    ModelForOrder aOrder = new ModelForOrder()
                    {
                        appId = wxJsApiParam.GetValue("appId").ToString(),
                        nonceStr = wxJsApiParam.GetValue("nonceStr").ToString(),
                        packageValue = wxJsApiParam.GetValue("package").ToString(),
                        paySign = wxJsApiParam.GetValue("paySign").ToString(),
                        timeStamp = wxJsApiParam.GetValue("timeStamp").ToString(),
                        msg = "成功下单,正在接入微信支付."
                    };
                    objResult = aOrder;
                }
                catch (Exception ex)
                {
                    ModelForOrder aOrder = new ModelForOrder()
                    {
                        appId = "",
                        nonceStr = "",
                        packageValue = "",
                        paySign = "",
                        timeStamp = "",
                        msg = "下单失败,请重试,多次失败,请联系管理员."
                    };
                    objResult = aOrder;
                }
                return Json(objResult);
            }  
    复制代码
     
    我们主要需要提供的就是这个类ModelForOrder 里面的参数,然后再把这些参数返回给前台调用,如下:
           
    复制代码
     //调用微信支付模块
            function onBridgeReady(json) {
                WeixinJSBridge.invoke(
               'getBrandWCPayRequest', {
                   "appId": json.appId,     //公众号名称,由商户传入
                   "timeStamp": json.timeStamp,         //时间戳,自1970年以来的秒数
                   "nonceStr": json.nonceStr, //随机串
                   "package": json.packageValue,
                   "signType": "MD5",         //微信签名方式:
                   "paySign": json.paySign //微信签名
               },
               function (res) {
                   if (res.err_msg == "get_brand_wcpay_request:ok") {
                       //alert("支付成功,请稍后查询余额,如有疑问,请联系管理员.");
                       fAlreadyPay();
                   }     // 使用以上方式判断前端返回,微信团队郑重提示:res.err_msg将在用户支付成功后返回    ok,但并不保证它绝对可靠。
               }
                );
            } 
    复制代码
     
    这样,他就会弹出一个微信支付的窗口,如下:
    然后我们确认付款之后,是否付款成功,如果付款成功,我们在执行: fAlreadyPay();
     
    这个方法已经被我删掉了,用途是用于,我们收到用户的款之后,我们需要同步一些数据到我们的数据库里面去,所以,该怎么操作,自己自行修改了。
     
     
    到这里,就大功告成啦,接下来的东西,就由大家自己去展开拓展了,本次经验分享到此结束,写过博客的人都知道,好好写一个博客,需要自己从头重新走一遍代码,所以,各种辛苦,只有自己能体会。所以您如果觉得写得不错,或者对你有帮助,请点“好文要顶”或者“关注我”,顺带也可以评论一两句,大家互相交流交流,转载请保留原作者地址以及姓名
     
     

    需要实时测试的,可以关注公众号,测试相关功能(根据实际情况,可能会不定时更新程序,如果需要最新程序的,可以加群联系,QQ群号在上面):
     
     
     
     
     
     
     
     
    我新建一个QQ群,如果有问题,可以在群里提。如果合适,也会根据大家提的比较多的问题,来写篇博文,帮助更多的人,群号:275523437
    点击链接加入群【.Net,MVC,EasyUI,MUI,Html,JS】:http://jq.qq.com/?_wv=1027&k=2A0RbLd
     
     
    (如果有私活,或者一起合作的,也可以私信找我呀,嘿嘿);
     
     
    作者:南宫萧尘  
    E-mail:314791147@qq.com
    QQ:314791147
    日期:2016-05-30
     
    鉴于网页篇幅较小,有些代码,我修改过后,有可能会漏贴到博文上,所以,为了让错误减值最少,我把代码包上传到QQ群了。
    如果园友在开发过程中,又发现问题,可以到群里来下载相关的代码来校对,造成不便,请谅解。
     
     
    最新动态,我已把代码上传到GitHub,其中一些敏感参数,就是config.cs里面的参数已删去,如果需要直接运行测试,请根据自身公众号信息,自行补全。
    地址:https://github.com/Jeffrey9061/WeChat_PublicAccountPay
     
     
    转自 https://www.cnblogs.com/nangong/p/50ab3c60f0d1ae5b551373cf96cd060d.html
  • 相关阅读:
    Mybatis Cause: java.lang.ClassNotFoundException: Cannot find class:
    java常见面试题及部分答案
    页面css样式找不到问题
    深入分析Java I/O的工作机制 (二)
    深入分析Java I/O的工作机制 (一)
    LifecycleProcessor not initialized
    几个java小例子
    idea 过段时间java程序包不存在问题 ?
    使用HttpClient发送Get/Post请求 你get了吗?
    Convert PIL Image to byte array?
  • 原文地址:https://www.cnblogs.com/flish/p/9633825.html
Copyright © 2011-2022 走看看