From 06e0e3b7d61e95902a6129de2490461cd0693e1d Mon Sep 17 00:00:00 2001
From: huangxiaoqiang <huangxiaoqiang@hnkhzn.com>
Date: 星期三, 15 十月 2025 15:06:40 +0800
Subject: [PATCH] 新增异步方法并优化服务调用逻辑在多个数据库文件中进行了二进制文件的修改、删除和新增操作,可能涉及数据库内容的更新或重建。在 HttpsClient.cs文件中新增了 PostNotLimitAsync方法,用于发送支持 JSON 格式的异步 HTTP POST 请求,并记录请求和响应参数。在 AgingInOrOutInputService.cs文件中,将 HttpsClient.PostAsync替换为PostNotLimitAsync,以利用新方法的功能特性。同时删除了不再需要的注释代码。
---
 Code Management/WMS/WIDESEA_WMSServer/WIDESEA_StorageTaskServices/AspNetCoreSchedule.cs |   51 +++++++++++++++++++++++++++++++--------------------
 1 files changed, 31 insertions(+), 20 deletions(-)
diff --git a/Code Management/WMS/WIDESEA_WMSServer/WIDESEA_StorageTaskServices/AspNetCoreSchedule.cs b/Code Management/WMS/WIDESEA_WMSServer/WIDESEA_StorageTaskServices/AspNetCoreSchedule.cs
index eaeb458..3e818e6 100644
--- a/Code Management/WMS/WIDESEA_WMSServer/WIDESEA_StorageTaskServices/AspNetCoreSchedule.cs
+++ b/Code Management/WMS/WIDESEA_WMSServer/WIDESEA_StorageTaskServices/AspNetCoreSchedule.cs
@@ -1,17 +1,11 @@
 锘縰sing Masuit.Tools;
 using Microsoft.Extensions.Hosting;
 using Microsoft.Extensions.Logging;
-using System;
-using System.Collections.Generic;
-using System.Linq;
-using System.Text;
-using System.Threading.Tasks;
+using WIDESEA_Cache;
 using WIDESEA_Core.Const;
 using WIDESEA_DTO.WMS;
 using WIDESEA_IServices;
-using WIDESEA_Repository;
 using WIDESEAWCS_BasicInfoRepository;
-using WIDESEA_Model;
 
 namespace WIDESEA_StorageTaskServices
 {
@@ -24,9 +18,11 @@
         private readonly IDt_StationManagerRepository _stationManagerRepository;
         private readonly ISys_ConfigService _configService;
         private readonly ILocationInfoRepository _locationRepository;
+        private readonly ISimpleCacheService _simpleCacheService;
 
         private Timer _timer;
-        public MyBackgroundService(ILogger<MyBackgroundService> logger, ILocationInfoRepository locationRepository, IStockInfoRepository stockInfoRepository, IDt_AreaInfoRepository areaInfoRepository, IDt_TaskRepository taskRepository, IDt_StationManagerRepository stationManagerRepository, ISys_ConfigService configService)
+
+        public MyBackgroundService(ILogger<MyBackgroundService> logger, ILocationInfoRepository locationRepository, IStockInfoRepository stockInfoRepository, IDt_AreaInfoRepository areaInfoRepository, IDt_TaskRepository taskRepository, IDt_StationManagerRepository stationManagerRepository, ISys_ConfigService configService, ISimpleCacheService simpleCacheService)
         {
             _logger = logger;
             _locationRepository = locationRepository;
@@ -35,30 +31,42 @@
             _taskRepository = taskRepository;
             _stationManagerRepository = stationManagerRepository;
             _configService = configService;
+            _simpleCacheService = simpleCacheService;
         }
+
         public Task StartAsync(CancellationToken cancellationToken)
         {
-            _timer = new Timer(DoWork, null, 0, 10000);
+            _timer = new Timer(DoWork, null, TimeSpan.Zero, TimeSpan.FromMinutes(5));
             return Task.CompletedTask;
         }
+
         private void DoWork(object state)
         {
             try
             {
                 var area = _areaInfoRepository.QueryFirst(x => x.AreaCode == "GWSC1");
 
+                if (area == null) { return; }
+
+                //IDictionary<string, DtStockInfo>? stockInfos = _simpleCacheService.HashGetAll<DtStockInfo>(WIDESEA_Cache.CacheConst.Cache_DtStockInfo);
+                //List<DtStockInfo> stockInfoList = stockInfos.Values.ToList();
+
+                //var stockInfo = stockInfoList.Where(x => x.AreaCode == area.AreaCode && x.OutboundTime < DateTime.Now && x.IsFull == true) // 杩囨护鏉′欢
+                //     .Where(x => x.LocationInfo != null && x.LocationInfo.LocationStatus == (int)LocationEnum.InStock && x.LocationInfo.AreaId == area.AreaID) // 杩囨护鏉′欢
+                //     .OrderBy(x => x.OutboundTime) // 鎺掑簭
+                //     .ToList(); // 鑾峰彇绗竴涓厓绱�
                 var stockInfo = _stockInfoRepository.Db.Queryable<DtStockInfo>()
-                     .Includes(x => x.LocationInfo) // 棰勫姞杞絃ocationInfo
-                     .Includes(x => x.StockInfoDetails) // 棰勫姞杞絊tockInfoDetails
-                     .Where(x => x.AreaCode == area.AreaCode && x.OutboundTime < DateTime.Now && x.IsFull == true) // 杩囨护鏉′欢
-                     .Where(x => x.LocationInfo.LocationStatus == (int)LocationEnum.InStock && x.LocationInfo.AreaId == area.AreaID) // 杩囨护鏉′欢
-                     .OrderBy(x => x.OutboundTime) // 鎺掑簭
-                     .ToList(); // 鑾峰彇绗竴涓厓绱�
+                    .Where(x => x.AreaCode == area.AreaCode && x.OutboundTime < DateTime.Now && x.IsFull == true)
+                    .Includes(x => x.LocationInfo)
+                    .Where(x => x.LocationInfo.LocationStatus == (int)LocationEnum.InStock && x.LocationInfo.AreaId == area.AreaID) // 杩囨护鏉′欢
+                    .Includes(x => x.StockInfoDetails)
+                    .OrderBy(x => x.OutboundTime) // 鎺掑簭
+                    .ToList(); // 鑾峰彇绗竴涓厓绱�
+
 
                 if (stockInfo.Count <= 0) return;
                 foreach (var item in stockInfo)
                 {
-
                     var hasTask = _taskRepository.QueryFirst(x => x.PalletCode == item.PalletCode);
                     if (hasTask != null)
                     {
@@ -77,7 +85,6 @@
                     // 鍒涘缓浠诲姟DTO
                     WMSTaskDTO taskDTO = CreateTaskDTO(task);
 
-
                     var configs = _configService.GetConfigsByCategory(CateGoryConst.CONFIG_SYS_IPAddress);
                     var wmsBase = configs.FirstOrDefault(x => x.ConfigKey == SysConfigConst.WCSIPAddress)?.ConfigValue;
                     var ipAddress = configs.FirstOrDefault(x => x.ConfigKey == SysConfigConst.ReceiveTask)?.ConfigValue;
@@ -94,10 +101,10 @@
                         _taskRepository.AddData(task);
                         // 鏇存柊搴撳瓨浣嶇疆鐘舵�佷负涓嶅彲鐢�
                         item.LocationInfo.LocationStatus = (int)LocationEnum.InStockDisable;
+                        //_simpleCacheService.HashDel<DtStockInfo>(WIDESEA_Cache.CacheConst.Cache_DtStockInfo, new string[] { taskDTO.PalletCode });
                         _locationRepository.UpdateData(item.LocationInfo);
                     }
                 }
-
             }
             catch (Exception ex)
             {
@@ -105,17 +112,18 @@
             }
             ConsoleHelper.WriteSuccessLine($"楂樻俯鍑哄簱璋冪敤锛�" + DateTime.Now.ToString());
         }
+
         public Task StopAsync(CancellationToken cancellationToken)
         {
             _logger.LogInformation("MyBackgroundService is stopping.");
             _timer?.Change(Timeout.Infinite, 0);
             return Task.CompletedTask;
         }
+
         public void Dispose()
         {
             _timer?.Dispose();
         }
-
 
         /// <summary>
         /// 鍒涘缓浠诲姟瀹炰緥
@@ -140,6 +148,8 @@
                 Creater = "System", // 淇鎷煎啓閿欒
                 CreateDate = DateTime.Now,
                 TaskId = 0,
+                ProductionLine = stockInfo.ProductionLine,
+                ProcessCode = stockInfo.ProcessCode,
             };
         }
 
@@ -159,7 +169,8 @@
                 TaskState = task.TaskState.Value,
                 Id = 0,
                 TaskType = task.TaskType,
+                ProductionLine = task.ProductionLine,
             };
         }
     }
-}
+}
\ No newline at end of file
--
Gitblit v1.9.3