From 6739e98662c16571da7aec0e9b52fab0afd3833b Mon Sep 17 00:00:00 2001 From: sunpengfei <i@angelzzz.com> Date: 星期五, 13 六月 2025 14:07:28 +0800 Subject: [PATCH] fix:修订支付回调和供应商回调并发问题 --- LifePayment/LifePayment.HttpApi/LifePay/ACOOLYNotifyController.cs | 34 ++++++++++++++++++++++------------ 1 files changed, 22 insertions(+), 12 deletions(-) diff --git a/LifePayment/LifePayment.HttpApi/LifePay/ACOOLYNotifyController.cs b/LifePayment/LifePayment.HttpApi/LifePay/ACOOLYNotifyController.cs index bd6e839..d44e90d 100644 --- a/LifePayment/LifePayment.HttpApi/LifePay/ACOOLYNotifyController.cs +++ b/LifePayment/LifePayment.HttpApi/LifePay/ACOOLYNotifyController.cs @@ -7,9 +7,11 @@ using System; using System.IO; using System.Text; +using System.Threading; using System.Threading.Tasks; using Volo.Abp; using Volo.Abp.AspNetCore.Mvc; +using Volo.Abp.DistributedLocking; using Volo.Abp.Uow; namespace LifePayment.HttpApi @@ -20,14 +22,17 @@ public class ACOOLYNotifyController : AbpController { private readonly ILifePayService _lifePayService; + private readonly IAbpDistributedLock distributedLock; private readonly ILogger<ACOOLYNotifyController> _logger; public ACOOLYNotifyController( ILogger<ACOOLYNotifyController> logger, - ILifePayService lifePayService) + ILifePayService lifePayService, + IAbpDistributedLock distributedLock) { _logger = logger; _lifePayService = lifePayService; + this.distributedLock = distributedLock; } /// <summary> @@ -35,11 +40,11 @@ /// </summary> /// <returns></returns> [HttpPost] - [UnitOfWork] [AllowAnonymous] public async Task ACOOLYNotify() { _logger.LogError("ACOOLY鍥炶皟閫氱煡寮�濮嬭繘鍏�"); + Thread.Sleep(200); var body = string.Empty; using (var reader = new StreamReader(Request.Body, Encoding.UTF8)) { @@ -56,6 +61,8 @@ ACOOLYStatusEnum acoolyStatus = ACOOLYStatusEnum.鍏呭�煎け璐�; var acoolyOrderNo = string.Empty; decimal payAmount = 0; + decimal parValue = 0; + decimal actualParValue = 0; string refundApplyRemark = string.Empty; _logger.LogError("ACOOLY鍥炶皟閫氬鐞嗙被鍨嬶細" + baseInfo.Service); _logger.LogError("ACOOLY鍥炶皟鍐呭锛�" + body); @@ -66,6 +73,8 @@ orderNo = confirmElectricOrderResponse.ElectricChargeOrder.OutOrderNo; acoolyOrderNo = confirmElectricOrderResponse.ElectricChargeOrder.BusiOrderNo; payAmount = confirmElectricOrderResponse.ElectricChargeOrder.PayAmount; + actualParValue = confirmElectricOrderResponse.ElectricChargeOrder.ActualParValue; + parValue = confirmElectricOrderResponse.ElectricChargeOrder.ParValue; _logger.LogError("ACOOLY鍥炶皟閫氬鐞嗙粨鏋滅姸鎬侊細" + confirmElectricOrderResponse.ElectricChargeOrder.Status); if (!confirmElectricOrderResponse.Success @@ -96,13 +105,13 @@ else if (confirmElectricOrderResponse.ElectricChargeOrder.Status == ACOOLYConstant.Status.閫�娆句腑) { - status = LifePayOrderStatusEnum.宸插畬鎴�; - acoolyStatus = ACOOLYStatusEnum.宸查��娆�; + status = LifePayOrderStatusEnum.閫�娆句腑; + acoolyStatus = ACOOLYStatusEnum.閫�娆句腑; } else if (confirmElectricOrderResponse.ElectricChargeOrder.Status == ACOOLYConstant.Status.閫�娆惧畬鎴�) { - status = LifePayOrderStatusEnum.宸插畬鎴�; + status = LifePayOrderStatusEnum.寰呴��娆�; acoolyStatus = ACOOLYStatusEnum.宸查��娆�; } else @@ -116,6 +125,7 @@ { status = LifePayOrderStatusEnum.寰呴��娆�; acoolyStatus = ACOOLYStatusEnum.閮ㄥ垎鍏呭�兼垚鍔�; + refundApplyRemark = confirmElectricOrderResponse.ElectricChargeOrder.ResponseMessage; } break; case ACOOLYConstant.Sevice.ConfirmPhoneOrder: @@ -153,13 +163,13 @@ else if (confirmPhoneOrderResponse.PhoneChargeOrder.Status == ACOOLYConstant.Status.閫�娆句腑) { - status = LifePayOrderStatusEnum.宸插畬鎴�; - acoolyStatus = ACOOLYStatusEnum.宸查��娆�; + status = LifePayOrderStatusEnum.閫�娆句腑; + acoolyStatus = ACOOLYStatusEnum.閫�娆句腑; } else if (confirmPhoneOrderResponse.PhoneChargeOrder.Status == ACOOLYConstant.Status.閫�娆惧畬鎴�) { - status = LifePayOrderStatusEnum.宸插畬鎴�; + status = LifePayOrderStatusEnum.寰呴��娆�; acoolyStatus = ACOOLYStatusEnum.宸查��娆�; } else @@ -210,13 +220,13 @@ else if (confirmGasOrderResponse.GasChargeOrder.Status == ACOOLYConstant.Status.閫�娆句腑) { - status = LifePayOrderStatusEnum.宸插畬鎴�; - acoolyStatus = ACOOLYStatusEnum.宸查��娆�; + status = LifePayOrderStatusEnum.閫�娆句腑; + acoolyStatus = ACOOLYStatusEnum.閫�娆句腑; } else if (confirmGasOrderResponse.GasChargeOrder.Status == ACOOLYConstant.Status.閫�娆惧畬鎴�) { - status = LifePayOrderStatusEnum.宸插畬鎴�; + status = LifePayOrderStatusEnum.寰呴��娆�; acoolyStatus = ACOOLYStatusEnum.宸查��娆�; } else @@ -236,7 +246,7 @@ throw new UserFriendlyException("ACOOLY鍥炶皟閫氬鐞嗙被鍨嬩笉瀛樺湪"); } - await _lifePayService.ACOOLYOrderNotifyHandler(orderNo, acoolyOrderNo, status, acoolyStatus, payAmount, refundApplyRemark); + await _lifePayService.ACOOLYOrderNotifyHandler(orderNo, acoolyOrderNo, status, acoolyStatus, payAmount, refundApplyRemark, parValue, actualParValue); } } } \ No newline at end of file -- Gitblit v1.9.1