From 15be9cdba09e832452983ad3badf7e6cbefae57d Mon Sep 17 00:00:00 2001
From: xxyy <cathay_xy@163.com>
Date: 星期五, 07 三月 2025 15:08:29 +0800
Subject: [PATCH] 增强业务扩展能力和错误处理逻辑

---
 Code Management/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Filter/ThrottleFilter.cs |   48 ++++++++++++++++++++++++++++++++++++++++++++++--
 1 files changed, 46 insertions(+), 2 deletions(-)

diff --git a/Code Management/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Filter/ThrottleFilter.cs b/Code Management/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Filter/ThrottleFilter.cs
index a4b3dee..9d1ab3b 100644
--- a/Code Management/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Filter/ThrottleFilter.cs
+++ b/Code Management/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/Filter/ThrottleFilter.cs
@@ -1,5 +1,6 @@
 锘縰sing Microsoft.AspNetCore.Mvc.Filters;
 using System.Collections.Concurrent;
+using System.Text.Json;
 
 public class ThrottleFilter : IAsyncActionFilter
 {
@@ -14,7 +15,11 @@
     public async Task OnActionExecutionAsync(ActionExecutingContext context, ActionExecutionDelegate next)
     {
         var actionName = context.ActionDescriptor.DisplayName;
-        if (_lastExecutionTimes.TryGetValue(actionName, out var lastExecutionTime))
+
+        var parameterString = GenerateParameterString(context.ActionArguments);
+        var key = $"{actionName}_{parameterString}";
+
+        if (_lastExecutionTimes.TryGetValue(key, out var lastExecutionTime))
         {
             var elapsedTime = DateTime.Now - lastExecutionTime;
             if (elapsedTime.TotalSeconds < _intervalInSeconds)
@@ -24,7 +29,46 @@
             }
         }
 
-        _lastExecutionTimes[actionName] = DateTime.Now;
+        _lastExecutionTimes[key] = DateTime.Now;
         await next();
     }
+
+    private string GenerateParameterString(IDictionary<string, object> arguments)
+    {
+        if (arguments == null || arguments.Count == 0)
+        {
+            return "";
+        }
+
+        var paramStrings = new List<string>();
+        foreach (var argument in arguments)
+        {
+            var key = argument.Key;
+            var value = argument.Value;
+            string valueString;
+
+            if (value == null)
+            {
+                valueString = "null";
+            }
+            else if (IsSimpleType(value.GetType()))
+            {
+                valueString = value.ToString();
+            }
+            else
+            {
+                valueString = JsonSerializer.Serialize(value);
+            }
+
+            paramStrings.Add($"{key}={valueString}");
+        }
+
+        return string.Join("&", paramStrings);
+    }
+
+    // 鍒ゆ柇绫诲瀷鏄惁涓虹畝鍗曠被鍨�
+    private bool IsSimpleType(Type type)
+    {
+        return type.IsPrimitive || type == typeof(string) || type == typeof(decimal);
+    }
 }
\ No newline at end of file

--
Gitblit v1.9.3