예제 #1
0
        public async Task <ActionResult> PayNotifyJob([FromBody] YaeherConsultationAdd yaeherConsultationAdd)
        {
            if (!Commons.CheckSecret(yaeherConsultationAdd.Secret))
            {
                this.ObjectResultModule.StatusCode = 422;
                this.ObjectResultModule.Message    = "Wrong Secret";
                this.ObjectResultModule.Object     = "";
                Logger.Info("secret 错误!");
                return(Content("", "text/xml"));
            }
            string       xml = "";
            TencentWXPay OrdertencentWXPay  = new TencentWXPay();
            TencentWXPay RefundtencentWXPay = new TencentWXPay();

            string message         = "";
            string WXPayBillno     = "";
            string WXTransactionId = "";
            string WXOrderQuery    = "";

            WXPayBillno = yaeherConsultationAdd.sp_billno;
            var secret = await CreateSecret();

            //患者端咨询单
            var consul = await _consultationService.YaeherConsultationByNumber(yaeherConsultationAdd.ConsultNumber);

            //if (consul.ConsultState != "unpaid"&&consul.ConsultState != "created") { return Content(xml, "text/xml"); }
            //新增处理中条件判断
            if (consul.ConsultState != "unpaid" && consul.ConsultState != "processing")
            {
                return(Content(xml, "text/xml"));
            }
            //配置文件查询
            var Content1      = "{\"SystemType\":\"TencentWechar\",\"secret\":\"" + secret + "\"}";
            var tencentmparam = await this.PostResponseAsync(Commons.AdminIp + "api/SystemConfigsList/", Content1);

            var tencentmparamlist = JsonHelper.FromJson <APIResult <ResultModule <List <SystemConfigs> > > >(tencentmparam);

            if (tencentmparamlist == null || tencentmparamlist.result.item == null)
            {
                return(Content("", "text/xml"));
            }
            var tencentparam = tencentmparamlist.result.item.FirstOrDefault();

            //医生端医生信息查询
            Content1 = "{\"Id\":" + consul.DoctorID + ",\"secret\":\"" + secret + "\"}";
            var doctoruser = await this.PostResponseAsync(Commons.AdminIp + "api/DoctorInformation", Content1);

            var doctorUserResult = JsonHelper.FromJson <APIResult <ResultModule <YaeherDoctorInfo> > >(doctoruser);

            if (doctorUserResult == null || doctorUserResult.result.item == null)
            {
                return(Content("", "text/xml"));
            }
            var ServiceResult = doctorUserResult.result.item.ServiceMoneyLists.Find(t => t.Id == consul.ServiceMoneyListId);
            var queryresult   = await OrdertencentWXPay.OrderQueryAsync(WXPayBillno, tencentparam);

            if (ServiceResult == null || ServiceResult.Id < 1 || ServiceResult.ServiceState == false)
            {
                message = "医生该服务已下线,资金会原路返回您的账户,请稍后!";
            }
            if (queryresult.trade_state != "SUCCESS")
            {
                return(Content(queryresult.trade_state, "text/xml"));
            }
            #region 重复支付处理
            //if (consul.ConsultState == "created")
            //{
            //    var ordertradeold = await _orderTradeRecordService.OrderTradeRecordByConsultNumber(consul.ConsultNumber);
            //    if (ordertradeold != null && ordertradeold.WXPayBillno != WXPayBillno)
            //    {
            //        message = "您的支付已经收到,请不要重复支付,程序正在处理,请稍后!";
            //    }
            //}
            #endregion
            var YaeherUserPaymentResult = doctorUserResult.result.item.YaeherUserPayment.Find(t => t.IsDefault);
            if (YaeherUserPaymentResult == null)
            {
                YaeherUserPaymentResult = doctorUserResult.result.item.YaeherUserPayment.Find(t => t.PayMethod == "wxpay");
            }

            if (string.IsNullOrEmpty(message))
            {
                //患者端满单查询
                OrderTradeRecordIn refundManageIn = new OrderTradeRecordIn();
                var StartTime = Convert.ToDateTime(DateTime.Now.ToString("yyyy-MM-dd"));
                refundManageIn.DoctorId  = consul.DoctorID;
                refundManageIn.ServiceID = consul.ServiceMoneyListId;
                refundManageIn.AndAlso(t => t.IsDelete == false);
                refundManageIn.AndAlso(t => t.PayMoney > 0);
                refundManageIn.AndAlso(t => t.CreatedOn >= StartTime);
                refundManageIn.AndAlso(t => t.CreatedOn < StartTime.AddDays(1));

                var ordertradelist = await _orderTradeRecordService.PatientOrderTradeRecordList(refundManageIn);

                var allconsultation = ordertradelist.Count();
                if (ServiceResult.ServiceFrequency <= allconsultation)
                {
                    message = "医生该服务已满单,资金会原路返回您的账户,请稍后!";
                }

                if (!string.IsNullOrEmpty(yaeherConsultationAdd.sp_billno))
                {
                    if (queryresult.result_code != "SUCCESS")
                    {
                        return(Content("查询支付信息失败,请重新提交!", "text/xml"));
                    }

                    if (int.Parse(queryresult.total_fee) != (int)(ServiceResult.ServiceExpense * 100))
                    {
                        message = "医生该服务已修改价格,资金会原路返回您的账户,请稍后!";
                    }
                }
            }
            if (!string.IsNullOrEmpty(message))
            {
                string outTradeNo      = WXPayBillno;
                string outRefundNo     = consul.ConsultNumber + "-" + DateTime.Now.ToString("yyyMMddhhmmss");
                var    totalFee        = int.Parse(queryresult.total_fee);//单位:分
                int    refundFee       = totalFee;
                var    refundpayresult = await RefundtencentWXPay.RefundAsync(outTradeNo, outRefundNo, totalFee, refundFee, tencentparam, message);

                consul.ConsultState = "unpaid";
                await _consultationService.UpdateYaeherConsultation(consul);

                if (refundpayresult.code != "SUCCESS")
                {
                    Logger.Info("outTradeNo:" + outTradeNo + "outRefundNo:" + outRefundNo + "totalFee:" + totalFee + "refundFee:" + refundFee + "message:" + message + "+refundpayresult:" + JsonHelper.ToJson(refundpayresult));

                    HangfireScheduleJob job         = new HangfireScheduleJob();
                    RefundModel         refundModel = new RefundModel();
                    refundModel.Secret = await CreateSecret();

                    refundModel.outTradeNo  = outTradeNo;
                    refundModel.outRefundNo = outRefundNo;
                    refundModel.totalFee    = totalFee;
                    refundModel.refundFee   = refundFee;
                    refundModel.msg         = message;
                    JobModel model = new JobModel();
                    model.CallbackUrl     = Commons.AdminIp + "api/RefundAsync";
                    model.CallbackContent = JsonHelper.ToJson(refundModel);

                    job.Enqueue(model);

                    return(Content("退款支付失败,请联系管理员!", "text/xml"));
                    //return new ObjectResultModule("", 400, "退款支付失败,请联系管理员");
                }
                return(Content(message, "text/xml"));
            }

            WXTransactionId = queryresult.transaction_id;
            WXOrderQuery    = JsonHelper.ToJson(queryresult);

            Content1 = "{\"SystemCode\":\"SystemOverTime\",\"secret\":\"" + secret + "\"}";
            var replymparam = await this.PostResponseAsync(Commons.AdminIp + "api/YaeherMobileParameterList/", Content1);

            var replylistparam = JsonHelper.FromJson <APIResult <ResultModule <List <SystemParameter> > > >(replymparam);
            if (replylistparam == null || replylistparam.result.item == null)
            {
                return(Content("", "text/xml"));
            }

            Consultation consultation         = new Consultation();
            Publishs     Consultationpublishs = new Publishs();
            using (var unitOfWork = _unitOfWorkManager.Begin())
            {
                consul.ConsultState = "created";
                consul.Overtime     = DateTime.Now.AddDays(double.Parse(replylistparam.result.item[0].ItemValue));
                var result = await _consultationService.UpdateYaeherConsultation(consul);

                var OrderManage = new OrderManage();
                OrderManage.SequenceNo        = DateTime.Now.ToString("yyyyMMddHHmmss") + new RandomCode().GenerateCheckCodeNum(6);
                OrderManage.OrderNumber       = "ON-" + DateTime.Now.ToString("yyyyMMddhhmm") + new RandomCode().RamdomRecode(4);
                OrderManage.ConsultNumber     = result.ConsultNumber;
                OrderManage.ConsultID         = result.Id;
                OrderManage.ConsultType       = ServiceResult.ServiceType;
                OrderManage.ConsultantID      = consul.CreatedBy;
                OrderManage.ConsultantName    = result.ConsultantName;
                OrderManage.PatientID         = result.PatientID;
                OrderManage.PatientName       = result.PatientName;
                OrderManage.DoctorID          = consul.DoctorID;
                OrderManage.DoctorName        = doctorUserResult.result.item.DoctorInfo.DoctorName;
                OrderManage.OrderCurrency     = "rmb";
                OrderManage.OrderMoney        = Convert.ToDecimal(ServiceResult.ServiceExpense);
                OrderManage.ReceivablesType   = YaeherUserPaymentResult.PayMethod;                      //医生收款类型
                OrderManage.ReceivablesNumber = YaeherUserPaymentResult.PaymentAccout;                  //医生收款账号
                OrderManage.ServiceID         = ServiceResult.Id;                                       //产品ID
                OrderManage.ServiceName       = ServiceResult.DoctorName + ServiceResult.ServiceType;   //产品名称
                OrderManage.SellerMoneyID     = doctorUserResult.result.item.WxPayBusinessId.ItemValue; //微信支付分配的商户号
                OrderManage.TradeType         = ServiceResult.ServiceType;                              //交易类型
                OrderManage.CreatedBy         = consul.CreatedBy;
                OrderManage.CreatedOn         = DateTime.Now;
                var result1 = await _orderManageService.CreateOrderManage(OrderManage);

                var record = new OrderTradeRecord()
                {
                    SequenceNo        = DateTime.Now.ToString("yyyyMMddHHmmss") + new RandomCode().GenerateCheckCodeNum(6),
                    OrderID           = result1.Id,
                    OrderNumber       = result1.OrderNumber,
                    PayType           = "wxpay",
                    OrderCurrency     = "rmb",
                    TenpayNumber      = "", //支付账号
                    VoucherNumber     = "", //代金券编号
                    VoucherJSON       = "", //代金券Json
                    PayMoney          = Convert.ToDecimal(ServiceResult.ServiceExpense),
                    PaymentState      = "paid",
                    PaymentSourceCode = "order",
                    PaymentSource     = "订单",
                    WXPayBillno       = WXPayBillno,
                    WXTransactionId   = WXTransactionId,
                    WXOrderQuery      = WXOrderQuery,
                    CreatedBy         = consul.CreatedBy,
                    CreatedOn         = DateTime.Now
                };
                var result2 = await _orderTradeRecordService.CreateOrderTradeRecord(record);

                #region  发布咨询 消息接受者为医生  DoctorNotice AddConsultation
                // 发布咨询
                consultation.yaeherConsultation    = result;                    // 咨询主表
                consultation.orderManage           = result1;                   // 订单管理表
                consultation.orderTradeRecords     = result2;                   // 交易记录表
                Consultationpublishs.TemplateCode  = "DoctorNotice";
                Consultationpublishs.OperationType = "AddConsultation";         // 新增咨询
                Consultationpublishs.MessageRemark = result.IIInessDescription; // 发起咨询
                Consultationpublishs.Publisher     = "Patient";
                Consultationpublishs.PublishUrl    = "Patient";
                Consultationpublishs.EventName     = "发布 新增咨询";
                Consultationpublishs.EventCode     = "Consultation";
                Consultationpublishs.BusinessID    = result.Id.ToString();
                Consultationpublishs.BusinessCode  = result.ConsultNumber;
                Consultationpublishs.BusinessJSON  = JsonHelper.ToJson(consultation);
                Consultationpublishs.PublishedTime = result.CreatedOn;
                Consultationpublishs.PublishStatus = true;
                Consultationpublishs.CreatedBy     = consul.CreatedBy;
                Consultationpublishs.CreatedOn     = DateTime.Now;
                Consultationpublishs.Secret        = secret;

                Consultationpublishs.ServerClient = "Client";
                try
                {
                    var ConsultationResult = await _publishsService.CreatePublishs(Consultationpublishs);
                }
                catch (Exception ex)
                {
                    YaeherOperList yaeherOperList = new YaeherOperList();
                    yaeherOperList.CreatedOn   = DateTime.Now;
                    yaeherOperList.OperExplain = "Message:" + ex.Message.ToString();
                    yaeherOperList.OperContent = "StackTrace:" + ex.StackTrace.ToString();
                    yaeherOperList.OperType    = "支付回调";
                    await _YaeherOperListrepository.PatientYaeherOperList(yaeherOperList);

                    throw ex;
                }
                #endregion
                unitOfWork.Complete();
            }
            var ConsultationParma = await this.PostResponseAsync(Commons.DoctorIp + "api/ConsultationManage/", JsonHelper.ToJson(Consultationpublishs));

            // var ConsultationJson = JsonHelper.FromJson<APIResult<ResultModule<Publishs>>>(ConsultationParma);

            return(Content("success", "text/xml"));
        }
        public async Task <WecharSendMessage> CreateWecharSendMessage(SendMessageInfo sendMessageInfo)
        {
            var YaeherConsultationInfo = await _YaeherConsultationrepository.FirstOrDefaultAsync(a => a.ConsultNumber == sendMessageInfo.ConsultNumber);

            // 咨询人
            var ConsultantUserInfo = await _YaeherUserrepository.FirstOrDefaultAsync(a => a.Id == YaeherConsultationInfo.ConsultantID);

            var DoctorInfo = await _YaeherDoctorrepository.FirstOrDefaultAsync(a => a.Id == YaeherConsultationInfo.DoctorID);

            // 医生
            var DoctorUserInfo = await _YaeherUserrepository.FirstOrDefaultAsync(a => a.Id == DoctorInfo.UserID);

            // 查询微信模板ID
            WecharSendMessage wecharSendMessage = new WecharSendMessage();
            // 查询当前模板ID
            var YaeherMessageInfo = await _YaeherMessageTemplaterepository.FirstOrDefaultAsync(a => a.TemplateCode == sendMessageInfo.TemplateCode);

            wecharSendMessage.TemplateId = YaeherMessageInfo.TemplateId;
            // 是否自动发送
            bool SendState = bool.Parse(_SystemParameterrepository.GetAll().Where(a => a.SystemCode == "WecharSendState").FirstOrDefault().Code);
            // 查询消息模板内容
            var SendMessageList = _SendMessagerepository.GetAll().Where(a => a.TemplateCode == sendMessageInfo.TemplateCode && a.OperationType == sendMessageInfo.OperationType);

            try
            {
                if (SendMessageList.Count() > 0)
                {
                    SendWechaMessage         sendWechaMessage      = new SendWechaMessage();
                    SendMsmHelper            sendMsmHelper         = new SendMsmHelper();
                    List <WecharSendMessage> WecharSendMessageList = new List <WecharSendMessage>();
                    using (var unitOfWork = _unitOfWorkManager.Begin())
                    {
                        var    IsDoctor    = false;
                        string MessageType = string.Empty;
                        foreach (var SendMessageInfo in SendMessageList)
                        {
                            WecharSendMessage wecharMessage = new WecharSendMessage();
                            wecharMessage.ConsultNumber  = sendMessageInfo.ConsultNumber;
                            wecharMessage.TemplateCode   = sendMessageInfo.TemplateCode;
                            wecharMessage.OperationType  = sendMessageInfo.OperationType;
                            wecharMessage.ConsultantName = YaeherConsultationInfo.PatientName;      // 修改为患者用户名
                            wecharMessage.DoctorName     = YaeherConsultationInfo.DoctorName;
                            wecharMessage.ConsultJson    = JsonHelper.ToJson(YaeherConsultationInfo);
                            wecharMessage.BackUrl        = SendMessageInfo.BackUrl;
                            wecharMessage.FirstMessage   = SendMessageInfo.FirstMessage;  // 查询标语
                            wecharMessage.Keyword1       = SendMessageInfo.Keyword1;      // 称呼人
                            wecharMessage.Keyword2       = SendMessageInfo.Keyword2;      // 时间
                            wecharMessage.Keyword3       = SendMessageInfo.Keyword3;      // 内容
                            wecharMessage.MessageRemark  = SendMessageInfo.MessageRemark; // 备注
                            wecharMessage.TemplateId     = YaeherMessageInfo.TemplateId;
                            // 将对应信息转为发送模板
                            SendTemplate WecharTemplate = new SendTemplate();
                            switch (SendMessageInfo.Recipient)
                            {
                            case "Patient":                                                                                               // 接受人为咨询者
                                wecharMessage.ToUser = ConsultantUserInfo.WecharOpenID;
                                WecharTemplate       = sendWechaMessage.ConsultantWecharTemplate(wecharMessage, sendMessageInfo.Inquiry); // 赋值咨询者信息
                                break;

                            case "Doctor":      //  接受人为医生
                                wecharMessage.ToUser = DoctorUserInfo.WecharOpenID;
                                IsDoctor             = true;
                                WecharTemplate       = sendWechaMessage.DoctorWecharTemplate(wecharMessage, sendMessageInfo.EvaluateLevel, sendMessageInfo.WarningTime); // 赋值医生信息
                                MessageType          = WecharTemplate.MessageType;
                                break;
                            }
                            // 将对应信息转为发送实际内容
                            wecharMessage.WecharData = sendWechaMessage.WecharContent(WecharTemplate);
                            #region
                            // 执行微信消息发送
                            TemplateModel templateModel = new TemplateModel();
                            if (SendState)  // 是否实时发送
                            {
                                var TokenInfo = _systemTokenService.SystemTokenList("Wechar").Result;
                                templateModel = sendWechaMessage.SendWecharMessage(wecharMessage.WecharData, TokenInfo.access_token).Result;
                            }
                            if (templateModel.errcode == "error" || !SendState)
                            {
                                #region 增加重试机制
                                HangFireJob WecharhangFireJob = new HangFireJob();
                                WecharhangFireJob.JobName      = "微信定时服务";
                                WecharhangFireJob.JobCode      = "WechaMessageSend";
                                WecharhangFireJob.BusinessID   = Commons.GetCurrentTimeStepNumber(); //int.Parse(new RandomCode().GenerateCheckCodeNum(5));
                                WecharhangFireJob.BusinessCode = sendMessageInfo.ConsultNumber;
                                Random rd      = new Random();
                                int    Seconds = rd.Next(1, 5);
                                WecharhangFireJob.JobRunTime   = DateTime.Now.AddSeconds(Seconds); // 随机时间
                                WecharhangFireJob.JobSates     = "Open";
                                WecharhangFireJob.CallbackUrl  = Commons.AdminIp + "api/SendWechar/";
                                WecharhangFireJob.JobParameter = wecharMessage.WecharData;  // 将需要发送的内容整理好

                                HangfireScheduleJob job   = new HangfireScheduleJob();
                                JobModel            model = new JobModel();
                                model.CallbackUrl     = WecharhangFireJob.CallbackUrl;        //回调URL
                                model.queues          = "adminqueue";
                                model.CallbackContent = JsonHelper.ToJson(WecharhangFireJob); //回调参数
                                model.Timespan        = WecharhangFireJob.JobRunTime;         //运行时间
                                var returnjobid = job.Schedule(model);
                                if (returnjobid.IndexOf("error") < 0)
                                {
                                    WecharhangFireJob.JobRunID = returnjobid;
                                }
                                WecharhangFireJob = await _HangFireJobrepository.InsertAsync(WecharhangFireJob);

                                templateModel.msgid  = WecharhangFireJob.BusinessID.ToString();
                                templateModel.errmsg = "Undo";
                                #endregion

                                if (templateModel.errcode == "error")
                                {
                                    #region 将错误日志存起来
                                    YaeherOperList yaeherOperList = new YaeherOperList();
                                    yaeherOperList.CreatedOn   = DateTime.Now;
                                    yaeherOperList.OperExplain = JsonHelper.ToJson(sendMessageInfo);
                                    yaeherOperList.OperContent = "error:" + templateModel.errmsg;
                                    yaeherOperList.OperType    = "发送消息异常测试备用:" + sendMessageInfo.OperationType;
                                    await _YaeherOperListrepository.InsertAsync(yaeherOperList);

                                    #endregion
                                }
                            }
                            wecharMessage.MsgID   = templateModel.msgid;
                            wecharMessage.Status  = templateModel.errmsg;
                            wecharMessage.MsgType = wecharMessage.MsgType;
                            WecharSendMessageList.Add(wecharMessage);
                            #endregion
                        }
                        #region 发送短信
                        if (IsDoctor)
                        {
                            YaeherSendMsm yaeherSendMsm = new YaeherSendMsm();
                            yaeherSendMsm.PhoneNumbers  = DoctorUserInfo.PhoneNumber == null? DoctorInfo.PhoneNumber : DoctorUserInfo.PhoneNumber; // 医生电话
                            yaeherSendMsm.MessageType   = MessageType;                                                                             // 短信类型
                            yaeherSendMsm.TemplateParam = "{\"remark\":\"" + sendMessageInfo.ConsultNumber + "\"}";                                // 提示短信内容
                            // 发送短信 并存储记录
                            if (yaeherSendMsm.PhoneNumbers != null && yaeherSendMsm.MessageType != null)
                            {
                                var SendMessage = sendMsmHelper.SendMsm(yaeherSendMsm);  // 发送短信
                                YaeherMessageRemind MessageRemind = new YaeherMessageRemind();
                                MessageRemind.UserID           = 0;
                                MessageRemind.UserName         = "******";
                                MessageRemind.PhoneNumber      = yaeherSendMsm.PhoneNumbers;
                                MessageRemind.MessageType      = yaeherSendMsm.MessageType;
                                MessageRemind.Message          = SendMessage.ToString(); //将发送短信消息存起来
                                MessageRemind.VerificationCode = "";
                                MessageRemind.Message          = yaeherSendMsm.TemplateParam;
                                MessageRemind.CreatedBy        = 0;
                                MessageRemind.CreatedOn        = DateTime.Now;
                                MessageRemind.EffectiveLength  = 0;
                                MessageRemind.EffectiveTime    = DateTime.Now;
                                await _MessageRemindrepository.InsertAsync(MessageRemind);
                            }
                        }
                        #endregion
                        #region 将发微信的消息记录
                        if (WecharSendMessageList.Count > 0)
                        {
                            foreach (var wecharMessage in WecharSendMessageList)
                            {
                                await _repository.InsertAsync(wecharMessage);
                            }
                        }
                        #endregion
                        #region 增加有效用户访问记录 暂时关掉获取有效访问量
                        //YaeherOperList yaeherOperList = new YaeherOperList();
                        //yaeherOperList.CreatedOn = DateTime.Now;
                        //yaeherOperList.OperExplain = "ConsultNumber:"+ sendMessageInfo.ConsultNumber;
                        //yaeherOperList.OperContent = JsonHelper.ToJson(ConsultantUserInfo);
                        //yaeherOperList.OperType = "发送消息成功";
                        //await _YaeherOperListrepository.InsertAsync(yaeherOperList);
                        #endregion
                        unitOfWork.Complete();
                    }
                }
            }
            catch (Exception ex)
            {
                #region 增加有效用户访问记录
                YaeherOperList yaeherOperList = new YaeherOperList();
                yaeherOperList.CreatedOn   = DateTime.Now;
                yaeherOperList.OperExplain = JsonHelper.ToJson(sendMessageInfo);
                yaeherOperList.OperContent = "error:" + ex.ToString();
                yaeherOperList.OperType    = "发送消息异常:" + sendMessageInfo.OperationType;
                await _YaeherOperListrepository.InsertAsync(yaeherOperList);

                #endregion
            }
            return(wecharSendMessage);
        }
예제 #3
0
        public async Task <ActionResult> PayNotify()
        {
            try
            {
                ResponseHandler resHandler  = new ResponseHandler(HttpContext);
                string          return_code = resHandler.GetParameter("return_code");
                string          return_msg  = resHandler.GetParameter("return_msg");

                string xml = string.Format(@"<xml>
                                                <return_code><![CDATA[{0}]]></return_code>
                                                <return_msg><![CDATA[{1}]]></return_msg>
                                                </xml>", return_code, return_msg);

                string res = null;
                resHandler.SetKey("8FrTmTM1S9i1t0WhIl17AXyEa8L7NUrm");//微信支付密室
                //验证请求是否从微信发过来(安全)
                if (resHandler.IsTenpaySign() && return_code.ToUpper() == "SUCCESS")
                {
                    res = "success"; //正确的订单处理
                                     //直到这里,才能认为交易真正成功了,可以进行数据库操作,但是别忘了返回规定格式的消息!
                }
                else
                {
                    res = "wrong";//错误的订单处理
                }
                /* 这里可以进行订单处理的逻辑 */
                try
                {
                    if (res == "success")
                    {
                        string out_trade_no = resHandler.GetParameter("out_trade_no");
                        YaeherConsultationAdd yaeherConsultationAdd = new YaeherConsultationAdd();
                        yaeherConsultationAdd.ConsultNumber = "CN-" + out_trade_no.Substring(0, out_trade_no.Length - 6);
                        yaeherConsultationAdd.sp_billno     = out_trade_no;
                        yaeherConsultationAdd.Secret        = await CreateSecret();

                        HangfireScheduleJob job = new HangfireScheduleJob();
                        var JobModel            = new JobModel();
                        JobModel.CallbackUrl     = Commons.PatientIp + "api/PayNotifyJob";
                        JobModel.CallbackContent = JsonHelper.ToJson(yaeherConsultationAdd);
                        job.NotifyEnqueue(JobModel);
                    }
                    //发送支付成功的模板消息
                    #region 消息模板
                    // string appId = TenPayV3_AppId;//与微信公众账号后台的AppId设置保持一致,区分大小写。
                    // string openId = resHandler.GetParameter("openid");
                    // var templateData = new WeixinTemplate_PaySuccess("https://weixin.senparc.com", "购买商品", "状态:" + return_code);

                    //  Senparc.Weixin.WeixinTrace.SendCustomLog("支付成功模板消息参数", appId + " , " + openId);

                    //  var result = AdvancedAPIs.TemplateApi.SendTemplateMessage(appId, openId, templateData);
                    #endregion
                }
                catch (Exception ex)
                {
                    YaeherOperList yaeherOperList = new YaeherOperList();
                    yaeherOperList.CreatedOn   = DateTime.Now;
                    yaeherOperList.OperExplain = "Message:" + ex.Message.ToString();
                    yaeherOperList.OperContent = "StackTrace:" + ex.StackTrace.ToString();
                    yaeherOperList.OperType    = "支付回调";
                    await _YaeherOperListrepository.PatientYaeherOperList(yaeherOperList);
                }

                return(Content(xml, "text/xml"));
            }
            catch (Exception ex)
            {
                YaeherOperList yaeherOperList = new YaeherOperList();
                yaeherOperList.CreatedOn   = DateTime.Now;
                yaeherOperList.OperExplain = "Message:" + ex.Message.ToString();
                yaeherOperList.OperContent = "StackTrace:" + ex.StackTrace.ToString();
                yaeherOperList.OperType    = "支付回调";
                await _YaeherOperListrepository.PatientYaeherOperList(yaeherOperList);

                throw;
            }
        }