asp.net微信jsapi支付

1.前台页面:

<!DOCTYPE html>

<html xmlns="http://www.w3.org/1999/xhtml"><head runat="server">    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />    <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" />    <title>微信扫码支付</title>    <style>        html { font-size:20px; }        .logo_g { width:8.5rem; }        .form-control { width:96%;height:2rem;font-size: 1.5rem;border-radius: 0.25rem;border: 1px solid #ccc; }        #btnSubmit { width: 96%; height: 2rem; border-radius: 0.25rem; background-color: #00CD00; border: 0px #FE6714 solid; cursor: pointer; color: white; font-size: 1.5rem;margin-top: 1rem; }    </style>    <script type="text/javascript">        window.onload=function(){            document.documentElement.style.fontSize=document.documentElement.clientWidth*20/320+‘px‘;            window.onsize=function(){                document.documentElement.style.fontSize=document.documentElement.clientWidth*20/320+‘px‘;            };        };

        //调用微信JS api 支付        function jsApiCall()        {            WeixinJSBridge.invoke(            ‘getBrandWCPayRequest‘,            <%=wxJsApiParam%>,//josn串                    function (res)                    {                        if (res.err_msg == "get_brand_wcpay_request:ok") {                            alert("微信支付成功!");                        } else if (res.err_msg == "get_brand_wcpay_request:cancel") {                            alert("用户取消支付!");                        } else {                            alert(res.err_msg);                            alert("支付失败!");                        }                    }                    );        }

        function callpay()        {            //WeixinJSBridge.invoke()            if (typeof WeixinJSBridge == "undefined")            {                if (document.addEventListener)                {                    document.addEventListener(‘WeixinJSBridgeReady‘, jsApiCall, false);                }                else if (document.attachEvent)                {                    document.attachEvent(‘WeixinJSBridgeReady‘, jsApiCall);                    document.attachEvent(‘onWeixinJSBridgeReady‘, jsApiCall);                }            }            else            {                jsApiCall();            }        }                   </script></head><body>    <form id="form1" runat="server" style="text-align:center;">        <img class="logo_g" src="../Templates/vshop/t7/images/logo.png" />        <asp:TextBox ID="txtMoney" CssClass="form-control" runat="server"  onkeypress="if (event.keyCode < 48 || event.keyCode >57) event.returnValue = false;" placeholder="请输入金额"  />        <asp:Button ID="btnSubmit" runat="server" Text="立即支付" OnClientClick="callpay()" />    </form></body></html>

2.后台代码

public class wx_ScanCodePay : Page    {        protected Button btnSubmit;        protected TextBox txtMoney;

        public static string wxEditAddrParam { get; set; }        public static string wxJsApiParam { get; set; } //H5调起JS API参数

        protected void Page_Load(object sender, EventArgs e)        {            this.btnSubmit.Click += new EventHandler(this.btnSubmit_Click);            if (!IsPostBack)            {                //JsApiPay jsApiPay = new JsApiPay(this);                //try                //{                //    //调用【网页授权获取用户信息】接口获取用户的openid和access_token                //    jsApiPay.GetOpenidAndAccessToken();

                //    //获取收货地址js函数入口参数                //    wxEditAddrParam = jsApiPay.GetEditAddressParameters();                //    ViewState["openid"] = jsApiPay.openid;                //}                //catch (Exception ex)                //{                //    Response.Write("<span style=‘color:#FF0000;font-size:20px‘>" + "页面加载出错,请重试" + "</span>");                //}            }        }

        private void btnSubmit_Click(object sender, EventArgs e)        {            string amount = this.txtMoney.Text;            int money;            if (ViewState["openid"] != null)            {                string openid = ViewState["openid"].ToString();

                //检测是否给当前页面传递了相关参数                if (string.IsNullOrEmpty(amount))                {                    Response.Write("<span style=‘color:#FF0000;font-size:20px‘>" + "请输入正确的金额,请返回重试" + "</span>");                    return;                }                if (!int.TryParse(amount, out money))                {                    Response.Write("<span style=‘color:#FF0000;font-size:20px‘>" + "请输入正确的金额,请返回重试" + "</span>");                    return;                }

                //若传递了相关参数,则调统一下单接口,获得后续相关接口的入口参数                JsApiPay jsApiPay = new JsApiPay(this);                jsApiPay.openid = openid;                jsApiPay.total_fee = (int)(money * 100M);

                //JSAPI支付预处理                try                {                    WxPayData unifiedOrderResult = jsApiPay.GetUnifiedOrderResult();                    wxJsApiParam = jsApiPay.GetJsApiParameters();//获取H5调起JS API参数                           }                catch (Exception ex)                {                    Response.Write("<span style=‘color:#FF0000;font-size:20px‘>" + "下单失败,请返回重试" + "</span>");

                }            }            else            {                Response.Write("<span style=‘color:#FF0000;font-size:20px‘>" + "页面缺少参数,请返回重试" + "</span>");                        }        }    }

3.JsApiPay.cs

namespace WxPayAPI
{
    public class JsApiPay
    {
        /// <summary>
        /// 保存页面对象,因为要在类的方法中使用Page的Request对象
        /// </summary>
        private Page page {get;set;}

        /// <summary>
        /// openid用于调用统一下单接口
        /// </summary>
        public string openid { get; set; }

        /// <summary>
        /// access_token用于获取收货地址js函数入口参数
        /// </summary>
        public string access_token { get; set; }

        /// <summary>
        /// 商品金额,用于统一下单
        /// </summary>
        public int total_fee { get; set; }

        /// <summary>
        /// 统一下单接口返回结果
        /// </summary>
        public WxPayData unifiedOrderResult { get; set; } 

        public JsApiPay(Page page)
        {
            this.page = page;
        }

        /**
        *
        * 网页授权获取用户基本信息的全部过程
        * 详情请参看网页授权获取用户基本信息:http://mp.weixin.qq.com/wiki/17/c0f37d5704f0b64713d5d2c37b468d75.html
        * 第一步:利用url跳转获取code
        * 第二步:利用code去获取openid和access_token
        *
        */

        public  SiteSettings masterSettings = SettingsManager.GetMasterSettings(false);

        public void GetOpenidAndAccessToken()
        {
            if (!string.IsNullOrEmpty(page.Request.QueryString["code"]))
            {
                //获取code码,以获取openid和access_token
                string code = page.Request.QueryString["code"];
               // Log.Debug(this.GetType().ToString(), "Get code : " + code);
                GetOpenidAndAccessTokenFromCode(code);
            }
            else
            {
                //构造网页授权获取code的URL
                string host = page.Request.Url.Host;
                string path = page.Request.Path;
                string redirect_uri = HttpUtility.UrlEncode("http://" + host + path);
                WxPayData data = new WxPayData();
                data.SetValue("appid", masterSettings.WeixinAppId);
                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);
                try
                {
                    //触发微信返回code码
                    page.Response.Redirect(url);//Redirect函数会抛出ThreadAbortException异常,不用处理这个异常
                }
                catch(System.Threading.ThreadAbortException ex)
                {
                }
            }
        }

        /**
        *
        * 通过code换取网页授权access_token和openid的返回数据,正确时返回的JSON数据包如下:
        * {
        *  "access_token":"ACCESS_TOKEN",
        *  "expires_in":7200,
        *  "refresh_token":"REFRESH_TOKEN",
        *  "openid":"OPENID",
        *  "scope":"SCOPE",
        *  "unionid": "o6_bmasdasdsad6_2sgVt7hMZOPfL"
        * }
        * 其中access_token可用于获取共享收货地址
        * openid是微信支付jsapi支付接口统一下单时必须的参数
        * 更详细的说明请参考网页授权获取用户基本信息:http://mp.weixin.qq.com/wiki/17/c0f37d5704f0b64713d5d2c37b468d75.html
        * @失败时抛异常WxPayException
        */
        public void GetOpenidAndAccessTokenFromCode(string code)
        {
            try
            {
                //构造获取openid及access_token的url
                WxPayData data = new WxPayData();
                data.SetValue("appid", masterSettings.WeixinAppId);
                data.SetValue("secret", masterSettings.WeixinAppSecret);
                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"];

              //  Log.Debug(this.GetType().ToString(), "Get openid : " + openid);
             //   Log.Debug(this.GetType().ToString(), "Get access_token : " + access_token);
            }
            catch (Exception ex)
            {
               // Log.Error(this.GetType().ToString(), ex.ToString());
                throw new WxPayException(ex.ToString());
            }
        }

        /**
         * 调用统一下单,获得下单结果
         * @return 统一下单结果
         * @失败时抛异常WxPayException
         */
        public WxPayData GetUnifiedOrderResult()
        {
            //统一下单
            WxPayData data = new WxPayData();
            data.SetValue("body", "test");//商品描述
            data.SetValue("attach", "test");//附加数据
            data.SetValue("out_trade_no", WxPayApi.GenerateOutTradeNo());
            data.SetValue("total_fee", total_fee);
            data.SetValue("time_start", DateTime.Now.ToString("yyyyMMddHHmmss"));
            data.SetValue("time_expire", DateTime.Now.AddMinutes(10).ToString("yyyyMMddHHmmss"));
            data.SetValue("goods_tag", "test");//商品标记(优惠券可能用到)
            data.SetValue("trade_type", "JSAPI");
            data.SetValue("openid", openid);

            WxPayData result = WxPayApi.UnifiedOrder(data);
            if (!result.IsSet("appid") || !result.IsSet("prepay_id") || result.GetValue("prepay_id").ToString() == "")
            {
            //    Log.Error(this.GetType().ToString(), "UnifiedOrder response error!");
                throw new WxPayException("UnifiedOrder response error!");
            }

            unifiedOrderResult = result;
            return result;
        }

        /**
        *
        * 从统一下单成功返回的数据中获取微信浏览器调起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 string 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 parameters;
        }

        /**
        *
        * 获取收货地址js函数入口参数,详情请参考收货地址共享接口:http://pay.weixin.qq.com/wiki/doc/api/jsapi.php?chapter=7_9
        * @return string 共享收货地址js函数需要的参数,json格式可以直接做参数使用
        */
        public string GetEditAddressParameters()
        {
            string parameter = "";
            try
            {
                string host = page.Request.Url.Host;
                string path = page.Request.Path;
                string queryString = page.Request.Url.Query;
                //这个地方要注意,参与签名的是网页授权获取用户信息时微信后台回传的完整url
                string url = "http://" + host + path + queryString;

                //构造需要用SHA1算法加密的数据
                WxPayData signData = new WxPayData();
                signData.SetValue("appid", masterSettings.WeixinAppId);
                signData.SetValue("url", url);
                signData.SetValue("timestamp",WxPayApi.GenerateTimeStamp());
                signData.SetValue("noncestr",WxPayApi.GenerateNonceStr());
                signData.SetValue("accesstoken",access_token);
                string param = signData.ToUrl();

              //  Log.Debug(this.GetType().ToString(), "SHA1 encrypt param : " + param);
                //SHA1加密
                string addrSign = FormsAuthentication.HashPasswordForStoringInConfigFile(param, "SHA1");
             //   Log.Debug(this.GetType().ToString(), "SHA1 encrypt result : " + addrSign);

                //获取收货地址js函数入口参数
                WxPayData afterData = new WxPayData();
                afterData.SetValue("appId", masterSettings.WeixinAppId);
                afterData.SetValue("scope","jsapi_address");
                afterData.SetValue("signType","sha1");
                afterData.SetValue("addrSign",addrSign);
                afterData.SetValue("timeStamp",signData.GetValue("timestamp"));
                afterData.SetValue("nonceStr",signData.GetValue("noncestr"));

                //转为json格式
                parameter = afterData.ToJson();
              //  Log.Debug(this.GetType().ToString(), "Get EditAddressParam : " + parameter);
            }
            catch (Exception ex)
            {
              //  Log.Error(this.GetType().ToString(), ex.ToString());
                throw new WxPayException(ex.ToString());
            }

            return parameter;
        }
    }
}
时间: 2024-10-09 23:20:03

asp.net微信jsapi支付的相关文章

微信JSAPI支付 统一下单 (.net后台)

交流QQ群  ASP.NET鹰组 460845632  我会倾囊相授 我们要做微信支付当配置好微信微信商户和支付配置之后我们首先应该看   https://pay.weixin.qq.com/wiki/doc/api/app/app.php?chapter=9_1# 这是微信统一下单的参数,我将这个参数做成了一个数据模型 当做好这个数据模型之后仔细看一下里面那些参数是必须的,支付金额要注意,微信是按分来计算的 接下来我们就要生成签名,我这写好了个类  生成签名后 返回提交的值.....先给大家看

微信JSAPI支付

最近在微信H5页面内集成微信JSAPI支付,遇到不少问题,现将集成步骤及遇到的问题记录如下: 1.官方下载SDK,下载地址:https://pay.weixin.qq.com/wiki/doc/api/download/WxpayAPI_php_v3.zip 2.下载之后,只保留存放证书的文件cert(从微信公众平台"API安全"中下载),库文件lib,日志文件logs,以及example里面的notify.php,jsapi.php文件 3.配置WxPay.Config.php文件(

微信JSApi支付~集成到MVC环境后的最后一个坑(网上没有这种解决方案)

大叔第一人 之前写了关于微信的坑<微信JSApi支付~坑和如何填坑>,今天将微信的jsapi支付封装到了MVC环境里,当然也出现了一些新的坑,如支付参数应该是Json对象而不是Json字符串,这样也会应付引起“get_brand_wcpay_request:fail_invalid appid”这个大家都知道的异常,呵呵,解决方案网上说是“授权目录“,事实上,还有一种原因,那就是你的WeixinJSBridge.invoke方法里的参数应该是Json对象而不是字符串,这才是最重要的. 代码我们

微信JSApi支付~订单号和微信交易号&lt;转&gt;

本文转载自:张占岭 原文链接:http://www.cnblogs.com/lori/p/5364213.html 谈谈transactionId和out_trade_no 前一篇微信JSApi支付~坑和如何填坑文章反映不错,所以又写了个后篇,呵呵. 每个第三方在线支付系统中都会有至少两类订单号,其一为支付系统的订单号,我们称为transactionId,其二为商户平台的订单号,我们通常称为out_trade_no,这两个号一般用来对账,在第三方支付平台你可以通过这两个订单号来查询订单的状态,而

微信JSAPI支付(比较详细) 关于getRrandWCPayRequest:fail_invalid appid 错误

原文:微信JSAPI支付(比较详细) 关于getRrandWCPayRequest:fail_invalid appid 错误 首先微信支付需注册  微信公从平台开发 和 微信支付商户平台 关于4个密钥,如何获得:有图 AppID(应用ID) :wx000000000 (来自微信公众平台->开发者中心->配置项->开发者ID->AppID(应用ID)) AppSecret(应用密钥) :62d0000000000000000000ae (来自微信公众平台->开发者中心->

微信内网页支付(微信 JSAPI 支付)的一点经验

微信 JSAPI 支付的流程是:服务端根据情况,向微信服务器发起"下单"请求.此处需要提供自己维护唯一的订单号,并要求签名加密.根据"下单"反馈的微信提供的预支付"订单号",用刚才下单请求参数同样的签名方式,对几个基本数据进行封包签名.将签名摘要,和这几个基本数据,传输给 JavaScript 端.JavaScript 通过微信内置对象的方法,唤起支付,并前端返回支付操作结果.微信服务端会异步通知服务端,支付结果:此处通知地址是之前"下

微信JSApi支付~坑和如何填坑&lt;转&gt;

本文转载自:张占岭 原文链接:http://www.cnblogs.com/lori/p/5355550.html 微信一直用着不爽,这几天研究它的jsapi支付,即在微信内打开H5页面,完成支付的过程,在这个过程中,你将会遇到各种各样的问题,而大叔将把这些问题的解决方法写一下,希望可以给你带来帮助! 一 网页授权的域名需要设置 注意:我们设置的域名为当前域名,而不是一级域名,如www.api.com,你不能设置为api.com,而要设置成www.api.com 二 授权目录需要设置 三 JsA

微信公众号JSAPI支付

微信公众号JSAPI支付 一:配置参数 申请成功后,获取接口文件, 将所有文件放入项目根目录weixin下,在WxPay.ub.config.php中填入配置账户信息; 二:设置授权 开发者中心->网页服务->网页授权获取用户基本信息->修改; “授权回调页面域名修改成你的域名地址即可,须保证网页授权已获得,不然会报redirect_uri 参数错误; 三:网页授权获取用户openid js_api_call.php 请求文件中改动(所有传给微信的参数都在入口文件中接收) $out_tr

微信支付开发 c# SDK JSAPI支付开发的流程和微信大坑

微信支付开发流程 1. 开通微信支付功能 省略 2. 下载微信的C#版的微信SDK 下载连接:https://pay.weixin.qq.com/wiki/doc/api/jsapi.php?chapter=11_1 各个版本的都有,可惜咱最熟悉C# 我的下载时间是2016-02-28日,所以所有的流程都是基于这个版本的SDK. 3. 配置各种参数 首先在微信支付的开发配置中配置发起支付的路径如下: 代码的solution中找到lib的config.cs文件,如下图,所有的参数都在这里,这里配置