Beispiel #1
0
        protected void Page_Load(object sender, EventArgs e)
        {
            mcode = this.Request.QueryString["mcode"];
            if (!string.IsNullOrEmpty(mcode))
            {
                mcode = EncryptHelper.XorEncryptStr(mcode);
                message = mcode;
                return;
            }
            //创建ResponseHandler实例
            ResponseHandler resHandler = new ResponseHandler(Context);
            resHandler.setKey(PayConfig.AppKey);
            //判断签名
            try
            {
                string error = "";
                if (resHandler.isWXsign(out error))
                {
                    #region 协议参数=====================================
                    //--------------协议参数--------------------------------------------------------
                    string return_code = resHandler.getParameter("return_code");
                    string return_msg = resHandler.getParameter("return_msg");
                    string appid = resHandler.getParameter("appid");
                    //以下字段在 return_code 为 SUCCESS 的时候有返回--------------------------------
                    string mch_id = resHandler.getParameter("mch_id");
                    string device_info = resHandler.getParameter("device_info");
                    string nonce_str = resHandler.getParameter("nonce_str");
                    string result_code = resHandler.getParameter("result_code");
                    string err_code = resHandler.getParameter("err_code");
                    string err_code_des = resHandler.getParameter("err_code_des");

                    //以下字段在 return_code 和 result_code 都为 SUCCESS 的时候有返回---------------
                    string openid = resHandler.getParameter("openid");
                    string is_subscribe = resHandler.getParameter("is_subscribe");
                    string trade_type = resHandler.getParameter("trade_type");
                    string bank_type = resHandler.getParameter("bank_type");
                    string total_fee = resHandler.getParameter("total_fee");
                    string fee_type = resHandler.getParameter("fee_type");
                    string transaction_id = resHandler.getParameter("transaction_id");
                    string out_trade_no = resHandler.getParameter("out_trade_no");
                    string attach = resHandler.getParameter("attach");
                    string time_end = resHandler.getParameter("time_end");
                    #endregion
                    //支付成功
                    if (!out_trade_no.Equals("") && return_code.Equals("SUCCESS") && result_code.Equals("SUCCESS"))
                    {
                        /**
                         *  这里输入用户逻辑操作,比如更新订单的支付状态
                         *  这里可以发给用户信息操作
                         * **/
                        LogUtil.WriteLog("============ 支付成功 ===============");
                        //Response.Write("success");
                        var packageReqHandler = new RequestHandler(Context);
                        packageReqHandler.init();
                        packageReqHandler.setParameter("return_code", "SUCCESS");
                        packageReqHandler.setParameter("return_msg", "OK");
                        string data = packageReqHandler.parseXML();
                        LogUtil.WriteLog("Notify 页面  package(XML):" + data);
                        Response.Write(data);
                    }
                    else
                    {
                        message = err_code + err_code_des;
                        LogUtil.WriteLog("Notify  支付失败 " + err_code + ":" + err_code_des);
                    }
                }
                else
                {
                    //这里为我们自己调用显示的内容
                    LogUtil.WriteLog("Notify 页面  isWXsign= false ,显示自定义消息:" + mcode);

                }
            }
            catch (Exception ee)
            {
                LogUtil.WriteLog("Notify 页面  发送异常错误:" + ee.Message);
            }
        }
        protected void Page_Load(object sender, EventArgs e)
        {
            //创建ResponseHandler实例
            ResponseHandler resHandler = new ResponseHandler(Context);
            resHandler.setKey(PayConfig.AppKey);
           
            //判断签名
            try
            {
                string error = "";
                if (resHandler.isWXsign(out error))
                {
                    #region 协议参数=====================================
                    //--------------协议参数--------------------------------------------------------
                    //SUCCESS/FAIL此字段是通信标识,非交易标识,交易是否成功需要查
                    string return_code = resHandler.getParameter("return_code");
                    //返回信息,如非空,为错误原因签名失败参数格式校验错误
                    string return_msg = resHandler.getParameter("return_msg");
                    //微信分配的公众账号 ID
                    string appid = resHandler.getParameter("appid");

                    //以下字段在 return_code 为 SUCCESS 的时候有返回--------------------------------
                    //微信支付分配的商户号
                    string mch_id = resHandler.getParameter("mch_id");
                    //微信支付分配的终端设备号
                    string device_info = resHandler.getParameter("device_info");
                    //微信分配的公众账号 ID
                    string nonce_str = resHandler.getParameter("nonce_str");
                    //业务结果 SUCCESS/FAIL
                    string result_code = resHandler.getParameter("result_code");
                    //错误代码 
                    string err_code = resHandler.getParameter("err_code");
                    //结果信息描述
                    string err_code_des = resHandler.getParameter("err_code_des");

                    //以下字段在 return_code 和 result_code 都为 SUCCESS 的时候有返回---------------
                    //-------------业务参数---------------------------------------------------------
                    //用户在商户 appid 下的唯一标识
                    string openid = resHandler.getParameter("openid");
                    //用户是否关注公众账号,Y-关注,N-未关注,仅在公众账号类型支付有效
                    string is_subscribe = resHandler.getParameter("is_subscribe");
                    //JSAPI、NATIVE、MICROPAY、APP
                    string trade_type = resHandler.getParameter("trade_type");
                    //银行类型,采用字符串类型的银行标识
                    string bank_type = resHandler.getParameter("bank_type");
                    //订单总金额,单位为分
                    string total_fee = resHandler.getParameter("total_fee");
                    //货币类型,符合 ISO 4217 标准的三位字母代码,默认人民币:CNY
                    string fee_type = resHandler.getParameter("fee_type");
                    //微信支付订单号
                    string transaction_id = resHandler.getParameter("transaction_id");
                    //商户系统的订单号,与请求一致。
                    string out_trade_no = resHandler.getParameter("out_trade_no");
                    //商家数据包,原样返回
                    string attach = resHandler.getParameter("attach");
                    //支 付 完 成 时 间 , 格 式 为yyyyMMddhhmmss,如 2009 年12 月27日 9点 10分 10 秒表示为 20091227091010。时区为 GMT+8 beijing。该时间取自微信支付服务器
                    string time_end = resHandler.getParameter("time_end");

                    #endregion
                    //支付成功
                    if (!out_trade_no.Equals("") && return_code.Equals("SUCCESS") && result_code.Equals("SUCCESS"))
                    {
                        LogUtil.WriteLog("Notify 页面  支付成功,支付信息:商家订单号:" + out_trade_no + "、支付金额(分):" + total_fee + "、自定义参数:" + attach);
                       
                        /**
                         *  这里输入用户逻辑操作,比如更新订单的支付状态
                         * 
                         * **/

                        LogUtil.WriteLog("============ 单次支付结束 ===============");
                        Response.Write("success");
                        return;
                    }
                    else
                    {
                        LogUtil.WriteLog("Notify 页面  支付失败,支付信息   total_fee= " + total_fee + "、err_code_des=" + err_code_des + "、result_code=" + result_code);
                    }
                }
                else
                {
                    LogUtil.WriteLog("Notify 页面  isWXsign= false ,错误信息:" + error);
                }

           
            }
            catch (Exception ee)
            {
                LogUtil.WriteLog("Notify 页面  发送异常错误:" + ee.Message);
            }

            Response.End();
        }