299 lines
		
	
	
		
			15 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			299 lines
		
	
	
		
			15 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
using APT.BaseData.Domain.Entities.OP;
 | 
						|
using APT.BaseData.Domain.Enums.OP;
 | 
						|
using APT.CMS.Domain.Entities.SO;
 | 
						|
using APT.CMS.Domain.Enums.FC;
 | 
						|
using APT.CMS.Domain.Enums.SO;
 | 
						|
using APT.Infrastructure.Api;
 | 
						|
using APT.Infrastructure.Core;
 | 
						|
using Microsoft.AspNetCore.Http;
 | 
						|
using Microsoft.AspNetCore.Mvc;
 | 
						|
using System;
 | 
						|
using System.Collections.Generic;
 | 
						|
using System.Data;
 | 
						|
using System.IO;
 | 
						|
using System.Linq;
 | 
						|
using System.Security.Cryptography;
 | 
						|
using System.Text;
 | 
						|
using System.Threading.Tasks;
 | 
						|
using System.Xml;
 | 
						|
 | 
						|
namespace APT.OP.WebApi.Controllers.Api
 | 
						|
{
 | 
						|
    [Route("api/OP/WeiXin")]
 | 
						|
    public class WeiXinController : APTApiController<T_OP_CLIENT>
 | 
						|
    {
 | 
						|
        /// <summary>
 | 
						|
        /// 付款回调
 | 
						|
        /// </summary>
 | 
						|
        /// <returns></returns>
 | 
						|
        [HttpPost, Route("Notify")]
 | 
						|
        public async Task<IActionResult> Notify()
 | 
						|
        {
 | 
						|
            String xmlData = getPostStr();
 | 
						|
            //保存付款成功过来的数据
 | 
						|
            LoggerManager.GetLogger().Info("GXL", xmlData);
 | 
						|
            PayResult(xmlData);
 | 
						|
            return Content("<xml><return_code><![CDATA[SUCCESS]]></return_code></xml>", "text/xml");
 | 
						|
        }
 | 
						|
 | 
						|
 | 
						|
 | 
						|
        [HttpPost("CancelNotify")]
 | 
						|
        /// <summary>
 | 
						|
        /// 付款返回的数据
 | 
						|
        /// </summary>
 | 
						|
        /// <returns></returns>
 | 
						|
        public async Task<IActionResult> CancelNotify()
 | 
						|
        {
 | 
						|
            String xmlData = getPostStr();
 | 
						|
            //保存付款成功过来的数据
 | 
						|
            LoggerManager.GetLogger().Info("GXL", xmlData);
 | 
						|
            CancelResult(xmlData);
 | 
						|
            return Content("<xml><return_code><![CDATA[SUCCESS]]></return_code></xml>", "text/xml");
 | 
						|
        }
 | 
						|
 | 
						|
        //获得Post过来的数据  
 | 
						|
        public string getPostStr()
 | 
						|
        {
 | 
						|
            //Int32 intLen = Convert.ToInt32(System.Web.HttpContext.Current.Request.InputStream.Length);
 | 
						|
            //byte[] b = new byte[intLen];
 | 
						|
            //System.Web.HttpContext.Current.Request.InputStream.Read(b, 0, intLen);
 | 
						|
            Request.EnableBuffering();
 | 
						|
            using (Stream stream = Request.Body)
 | 
						|
            {
 | 
						|
                byte[] buffer = new byte[Request.ContentLength.Value];
 | 
						|
                stream.Read(buffer, 0, buffer.Length);
 | 
						|
                string content = Encoding.UTF8.GetString(buffer);
 | 
						|
                return content;
 | 
						|
            }
 | 
						|
        }
 | 
						|
        /// <summary>
 | 
						|
        /// 付款结果处理
 | 
						|
        /// </summary>
 | 
						|
        public void PayResult(string ResultMsg)
 | 
						|
        {
 | 
						|
            if (!string.IsNullOrEmpty(ResultMsg))
 | 
						|
            {
 | 
						|
                LoggerManager.GetLogger().Info("收到回调数据1:" + ResultMsg);
 | 
						|
                var xml = new XmlDocument();
 | 
						|
                xml.LoadXml(ResultMsg);
 | 
						|
                //处理返回的值
 | 
						|
                DataSet ds = new DataSet();
 | 
						|
                StringReader stram = new StringReader(ResultMsg);
 | 
						|
                XmlTextReader reader = new XmlTextReader(stram);
 | 
						|
                ds.ReadXml(reader);
 | 
						|
                string return_code = ds.Tables[0].Rows[0]["return_code"].ToString();
 | 
						|
                if (return_code.ToUpper() == "SUCCESS")
 | 
						|
                {
 | 
						|
                    //通信成功  
 | 
						|
                    string result_code = ds.Tables[0].Rows[0]["result_code"].ToString();//业务结果  
 | 
						|
                    if (result_code.ToUpper() == "SUCCESS")
 | 
						|
                    {
 | 
						|
                        string appid = ds.Tables[0].Rows[0]["appid"].ToString();
 | 
						|
                        //string attach = ds.Tables[0].Rows[0]["attach"].ToString();
 | 
						|
                        string mch_id = ds.Tables[0].Rows[0]["mch_id"].ToString();
 | 
						|
                        string openid = ds.Tables[0].Rows[0]["openid"].ToString();
 | 
						|
                        string orderid = ds.Tables[0].Rows[0]["out_trade_no"].ToString();
 | 
						|
                        Int32 total_fee = Convert.ToInt32(ds.Tables[0].Rows[0]["total_fee"].ToString());
 | 
						|
                        string transaction_id = ds.Tables[0].Rows[0]["transaction_id"].ToString();
 | 
						|
                        LoggerManager.GetLogger().Info("付款成功:小程序appID:" + appid + ",商户号:" + mch_id +
 | 
						|
                            ",支付人:" + openid + ",付款金额:" + total_fee + ",商户交易号:" + transaction_id);
 | 
						|
 | 
						|
                        //var gOrder = orderid.Substring(0, 8) + "-" + orderid.Substring(8, 4) + "-" + orderid.Substring(12, 4) + "-" + orderid.Substring(16, 4) + "-" + orderid.Substring(20);
 | 
						|
                        var orderAry = orderid.Split(new char[] { '_' }, StringSplitOptions.RemoveEmptyEntries);
 | 
						|
                        //var orderId = new Guid(gOrder);
 | 
						|
                        //var order = this.GetEntity<T_FM_SALE_ORDER>(i => i.CODE == orderAry[0], "Nav_ClinetOpen.NavClient",
 | 
						|
                        //    "Nav_Orders.Nav_Details.Nav_Stock.Nav_HotelRoomTypeDetail.Nav_HotelRoomType",
 | 
						|
                        //    "Nav_Orders.Nav_Details.Nav_Stock.Nav_HotelRoomTypeDetail.Nav_Hotel");                       
 | 
						|
                        if (orderAry[2] == "DK")//电卡订单
 | 
						|
                        {
 | 
						|
                            BaseFilter filter = new BaseFilter();
 | 
						|
                            filter.IgnoreOrgRule = true;
 | 
						|
                            filter.IsMultipleDb = true;
 | 
						|
                            var order = this.GetEntity<T_SO_RECHARGE_ORDER>(i => i.CODE == orderAry[0], filter, "Nav_RechargeCard");
 | 
						|
                            if (order == null)
 | 
						|
                                LoggerManager.GetLogger().Error("订单不存在:" + order);
 | 
						|
                            order.ORDER_STATUS = (int)OPRechargeOrderStatus.成功;
 | 
						|
                            if (order.Nav_RechargeCard != null)
 | 
						|
                            {
 | 
						|
                                var rechargeCard = order.Nav_RechargeCard;
 | 
						|
                                rechargeCard.BALANCE += order.AMOUNT;
 | 
						|
                                this.UpdateEntityByConn(order, order.DbConn,"ORDER_STATUS");
 | 
						|
                                this.UpdateEntityByConn(rechargeCard, order.DbConn, "BALANCE");
 | 
						|
                                LoggerManager.GetLogger().Info("充值成功" + order.CODE);
 | 
						|
                            }
 | 
						|
                            else
 | 
						|
                            {
 | 
						|
                                order.ORDER_STATUS = (int)OPRechargeOrderStatus.失败;
 | 
						|
                                this.UpdateEntityByConn(order, order.DbConn, "ORDER_STATUS");
 | 
						|
                                LoggerManager.GetLogger().Error("微信充值成功,电卡金额未更新:" + ResultMsg);
 | 
						|
                            }
 | 
						|
                        }
 | 
						|
                        else//微信直接支付
 | 
						|
                        {
 | 
						|
                            BaseFilter filter = new BaseFilter();
 | 
						|
                            filter.IgnoreOrgRule = true;
 | 
						|
                            filter.IsMultipleDb = true;
 | 
						|
                            var order = this.GetEntity<T_SO_CHARGING_ORDER>(x => x.CODE == orderAry[0], filter);//查询订单
 | 
						|
                            order.PAY_TYPE = (int)FCPayType.微信支付;
 | 
						|
                            order.ORDER_STATUS = (int)FCOrderStatus.已付款;
 | 
						|
                            this.UpdateEntityByConn(order, order.DbConn);//更新订单状态
 | 
						|
                        }
 | 
						|
                    }
 | 
						|
                    else
 | 
						|
                    {
 | 
						|
                        LoggerManager.GetLogger().Error("支付失败:" + ResultMsg);
 | 
						|
                    }
 | 
						|
                }
 | 
						|
                else
 | 
						|
                {
 | 
						|
                    LoggerManager.GetLogger().Error("支付失败:" + ResultMsg);
 | 
						|
                }
 | 
						|
            }
 | 
						|
        }
 | 
						|
 | 
						|
        /// <summary>
 | 
						|
        /// 付款结果处理
 | 
						|
        /// </summary>
 | 
						|
        public void CancelResult(string ResultMsg)
 | 
						|
        {
 | 
						|
            if (!string.IsNullOrEmpty(ResultMsg))
 | 
						|
            {
 | 
						|
                LoggerManager.GetLogger().Info("收到回调数据:" + ResultMsg);
 | 
						|
                var xml = new XmlDocument();
 | 
						|
                xml.LoadXml(ResultMsg);
 | 
						|
                //处理返回的值
 | 
						|
                DataSet ds = new DataSet();
 | 
						|
                StringReader stram = new StringReader(ResultMsg);
 | 
						|
                XmlTextReader reader = new XmlTextReader(stram);
 | 
						|
                ds.ReadXml(reader);
 | 
						|
                string return_code = ds.Tables[0].Rows[0]["return_code"].ToString();
 | 
						|
                if (return_code.ToUpper() == "SUCCESS")
 | 
						|
                {
 | 
						|
                    //通信成功  
 | 
						|
                    string appid = ds.Tables[0].Rows[0]["appid"].ToString();
 | 
						|
                    //string attach = ds.Tables[0].Rows[0]["attach"].ToString();
 | 
						|
                    string mch_id = ds.Tables[0].Rows[0]["mch_id"].ToString();
 | 
						|
                    string reqInfo = ds.Tables[0].Rows[0]["req_info"].ToString();
 | 
						|
                    //
 | 
						|
                    var tenant = this.GetEntity<T_OP_TENANT>(x => x.MCH_ID == mch_id);//查找运营商
 | 
						|
                    //解密reqInfo
 | 
						|
                    string dReqInfo = DecodeReqInfoByTenant(reqInfo, tenant.WXPAYKEY);
 | 
						|
                    if (dReqInfo == null)
 | 
						|
                    {
 | 
						|
                        LoggerManager.GetLogger().Error("解密失败");
 | 
						|
                        return;
 | 
						|
                    }
 | 
						|
                    LoggerManager.GetLogger().Info(reqInfo);
 | 
						|
                    DataSet dsReq = new DataSet();
 | 
						|
                    StringReader stramReq = new StringReader(dReqInfo);
 | 
						|
                    XmlTextReader readerReq = new XmlTextReader(stramReq);
 | 
						|
                    dsReq.ReadXml(readerReq);
 | 
						|
 | 
						|
                    string orderid = dsReq.Tables[0].Rows[0]["out_trade_no"].ToString();
 | 
						|
                    string refundCode = dsReq.Tables[0].Rows[0]["out_refund_no"].ToString();
 | 
						|
                    Int32 total_fee = Convert.ToInt32(dsReq.Tables[0].Rows[0]["total_fee"].ToString());
 | 
						|
                    Int32 refund_fee = Convert.ToInt32(dsReq.Tables[0].Rows[0]["refund_fee"].ToString());
 | 
						|
                    string transaction_id = dsReq.Tables[0].Rows[0]["transaction_id"].ToString();
 | 
						|
                    LoggerManager.GetLogger().Info("退款成功:小程序appID:" + appid + ",商户号:" + mch_id +
 | 
						|
                         ",订单金额:" + total_fee + ",退款金额:" + refund_fee + ",商户交易号:" + transaction_id);
 | 
						|
 | 
						|
                    var orderAry = orderid.Split(new char[] { '_' }, StringSplitOptions.RemoveEmptyEntries);
 | 
						|
                    var refundCodeAry = refundCode.Split(new char[] { '@' }, StringSplitOptions.RemoveEmptyEntries);
 | 
						|
                    if (orderAry[3] == "DK")//电卡订单
 | 
						|
                    {
 | 
						|
                        BaseFilter filter = new BaseFilter();
 | 
						|
                        filter.IgnoreOrgRule = true;
 | 
						|
                        filter.IsMultipleDb = true;
 | 
						|
                        var refundOrder = this.GetEntity<T_SO_REFUND_ORDER>(i => i.CODE == refundCodeAry[0], filter);
 | 
						|
                        if (refundOrder == null)
 | 
						|
                            LoggerManager.GetLogger().Error("订单不存在:" + refundOrder);
 | 
						|
                        refundOrder.REFUND_STATUS = (int)SORefundOrderStatus.退款成功;
 | 
						|
                        var order = this.GetEntity<T_SO_RECHARGE_ORDER>(i => i.CODE == orderAry[0], filter, "Nav_RechargeCard");
 | 
						|
                        if (order.Nav_RechargeCard != null)
 | 
						|
                        {
 | 
						|
                            var rechargeCard = order.Nav_RechargeCard;
 | 
						|
                            rechargeCard.BALANCE -= refundOrder.REFUND_AMOUNT;//扣除电卡金额
 | 
						|
                            this.UpdateEntityByConn(refundOrder, refundOrder.DbConn, "REFUND_STATUS");
 | 
						|
                            this.UpdateEntityByConn(rechargeCard, refundOrder.DbConn, "BALANCE");
 | 
						|
                            LoggerManager.GetLogger().Info("退款成功" + order.CODE);
 | 
						|
                        }
 | 
						|
                        else
 | 
						|
                        {
 | 
						|
                            refundOrder.REFUND_STATUS = (int)SORefundOrderStatus.退款失败;
 | 
						|
                            this.UpdateEntityByConn(refundOrder, refundOrder.DbConn, "REFUND_STATUS");
 | 
						|
                            LoggerManager.GetLogger().Error("微信退款成功,电卡金额未更新:" + ResultMsg);
 | 
						|
                        }
 | 
						|
                    }
 | 
						|
                    else//微信直接支付
 | 
						|
                    {
 | 
						|
                        BaseFilter filter = new BaseFilter();
 | 
						|
                        filter.IgnoreOrgRule = true;
 | 
						|
                        filter.IsMultipleDb = true;
 | 
						|
                        var refundOrder = this.GetEntity<T_SO_REFUND_ORDER>(i => i.CODE == refundCodeAry[0], filter);
 | 
						|
                        if (refundOrder == null)
 | 
						|
                            LoggerManager.GetLogger().Error("订单不存在:" + refundOrder);
 | 
						|
                        refundOrder.REFUND_STATUS = (int)SORefundOrderStatus.退款成功;                    
 | 
						|
                        this.UpdateEntityByConn(refundOrder, refundOrder.DbConn, "REFUND_STATUS");//更新订单状态
 | 
						|
                    }
 | 
						|
                }
 | 
						|
                else
 | 
						|
                {
 | 
						|
                    LoggerManager.GetLogger().Error("退款成功:" + ResultMsg);
 | 
						|
                }
 | 
						|
            }
 | 
						|
        }
 | 
						|
        public static string DecodeReqInfo(string s)
 | 
						|
        {
 | 
						|
            string r = null;
 | 
						|
            string key = GenerateMD5(LibUtils.ToString(ConfigurationManager.AppSettings["WxPayKey"])).ToLower();
 | 
						|
            r = DecodeAES256ECB(s, key);
 | 
						|
            return r;
 | 
						|
        }
 | 
						|
        public static string DecodeReqInfoByTenant(string s,string key)
 | 
						|
        {
 | 
						|
            string r = null;
 | 
						|
            //string key = GenerateMD5(LibUtils.ToString(ConfigurationManager.AppSettings["WxPayKey"])).ToLower();
 | 
						|
            r = DecodeAES256ECB(s, key);
 | 
						|
            return r;
 | 
						|
        }
 | 
						|
        public static string DecodeAES256ECB(string s, string key)
 | 
						|
        {
 | 
						|
            string r = null;
 | 
						|
            try
 | 
						|
            {
 | 
						|
                byte[] keyArray = UTF8Encoding.UTF8.GetBytes(key);
 | 
						|
                byte[] toEncryptArray = Convert.FromBase64String(s);
 | 
						|
                RijndaelManaged rDel = new RijndaelManaged();
 | 
						|
                rDel.Key = keyArray;
 | 
						|
                rDel.Mode = CipherMode.ECB;
 | 
						|
                rDel.Padding = PaddingMode.PKCS7;
 | 
						|
                ICryptoTransform cTransform = rDel.CreateDecryptor();
 | 
						|
                byte[] resultArray = cTransform.TransformFinalBlock(toEncryptArray, 0, toEncryptArray.Length);
 | 
						|
                r = UTF8Encoding.UTF8.GetString(resultArray);
 | 
						|
            }
 | 
						|
            catch (Exception e)
 | 
						|
            {
 | 
						|
                LoggerManager.GetLogger().Error("解密异常:" + e.Message);
 | 
						|
            }
 | 
						|
            return r;
 | 
						|
        }
 | 
						|
        public static string GenerateMD5(string txt)
 | 
						|
        {
 | 
						|
            using (MD5 mi = MD5.Create())
 | 
						|
            {
 | 
						|
                byte[] buffer = Encoding.Default.GetBytes(txt);
 | 
						|
                //开始加密
 | 
						|
                byte[] newBuffer = mi.ComputeHash(buffer);
 | 
						|
                StringBuilder sb = new StringBuilder();
 | 
						|
                for (int i = 0; i < newBuffer.Length; i++)
 | 
						|
                {
 | 
						|
                    sb.Append(newBuffer[i].ToString("x2"));
 | 
						|
                }
 | 
						|
                return sb.ToString();
 | 
						|
            }
 | 
						|
        }
 | 
						|
 | 
						|
    }
 | 
						|
}
 |