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")); }