using AngleSharp.Dom; using Newtonsoft.Json; using System; using System.Collections.Generic; using System.Linq; using System.Net.Http.Headers; using System.Reflection.Metadata; using System.Security.Policy; using System.Text; using System.Threading.Tasks; using WIDESEAWCS_Core.LogHelper; namespace WIDESEAWCS_Core.Helper { public class HttpHelper { public static async Task GetAsync(string serviceAddress, Dictionary parameters, string contentType = "application/json", Dictionary? headers = null) { try { string result = string.Empty; using HttpClient httpClient = new HttpClient(); httpClient.Timeout = new TimeSpan(0, 0, 60); // 将参数拼接到URL中 string queryString = string.Join("&", parameters.Select(x => $"{x.Key}={x.Value}")); serviceAddress += "?" + queryString; if (headers != null) { foreach (var header in headers) httpClient.DefaultRequestHeaders.Add(header.Key, header.Value); } result = await httpClient.GetAsync(serviceAddress).Result.Content.ReadAsStringAsync(); return result; } catch (Exception e) { Console.WriteLine(e.Message); } return null; } // 用于追踪每个请求的调用次数和最后请求时间。 private static readonly Dictionary requestTracker = new(); public static async Task PostAsync(string serviceAddress, string requestJson = null, string contentType = "application/json", Dictionary? headers = null) { try { //if (serviceAddress.Contains("http://c24-cellmi3:12020")) //{ // // 将 JSON 字符串转换为字典 // var parameters = JsonConvert.DeserializeObject>(requestJson); // // 创建一个新的字典,排除 RequestTime 和 SessionId // var filteredParameters = parameters.Where(p => p.Key != "RequestTime" && p.Key != "SessionId").ToDictionary(p => p.Key, p => p.Value); // string requestKey = $"{serviceAddress}:{JsonConvert.SerializeObject(filteredParameters)}"; // // 检查请求次数和时间限制 // if (requestTracker.TryGetValue(requestKey, out var requestInfo)) // { // if (requestInfo.Count >= 5 && DateTime.Now < requestInfo.LastRequestTime.AddMinutes(3)) // { // // 如果请求次数超过限制且未超过10分钟,抛出异常 // throw new InvalidOperationException("请求次数已达到限制,请稍后再试。"); // } // } // // 更新请求跟踪信息 // if (requestTracker.ContainsKey(requestKey)) // { // requestTracker[requestKey] = (requestInfo.Count + 1, DateTime.Now); // } // else // { // requestTracker[requestKey] = (1, DateTime.Now); // } //} LogRequestParameters(requestJson, serviceAddress); string result = string.Empty; using (HttpContent httpContent = new StringContent(requestJson)) { httpContent.Headers.ContentType = new MediaTypeHeaderValue("application/json"); using HttpClient httpClient = new HttpClient(); httpClient.Timeout = new TimeSpan(0, 0, 60); if (headers != null) { foreach (var header in headers) httpClient.DefaultRequestHeaders.Add(header.Key, header.Value); } result = await httpClient.PostAsync(serviceAddress, httpContent).Result.Content.ReadAsStringAsync(); } LogResponseParameters(result, serviceAddress); return result; } catch (Exception ex) { LogErrorParameters(ex.StackTrace, ex.Message, serviceAddress); Console.WriteLine(ex.Message); } return null; } public static string Get(string serviceAddress, string contentType = "application/json", Dictionary? headers = null) { try { string result = string.Empty; using HttpClient httpClient = new HttpClient(); httpClient.Timeout = new TimeSpan(0, 0, 60); foreach (var header in headers) httpClient.DefaultRequestHeaders.Add(header.Key, header.Value); result = httpClient.GetStringAsync(serviceAddress).Result; return result; } catch (Exception e) { Console.WriteLine(e.Message); } return null; } public static string Post(string serviceAddress, string requestJson = null, string contentType = "application/json", Dictionary? headers = null) { try { string result = string.Empty; using (HttpContent httpContent = new StringContent(requestJson)) { httpContent.Headers.ContentType = new MediaTypeHeaderValue("application/json"); using HttpClient httpClient = new HttpClient(); httpClient.Timeout = new TimeSpan(0, 0, 60); foreach (var header in headers) httpClient.DefaultRequestHeaders.Add(header.Key, header.Value); result = httpClient.PostAsync(serviceAddress, httpContent).Result.Content.ReadAsStringAsync().Result; } return result; } catch (Exception e) { Console.WriteLine(e.Message); } return null; } private static void LogErrorParameters(string errordetail, string error, string url = "") { StringBuilder builder = new StringBuilder(); builder.Append(Environment.NewLine); builder.Append("---------------------------------------------"); builder.Append(Environment.NewLine); builder.Append("url:" + url + "异常详细信息: " + JsonConvert.SerializeObject(error)); builder.Append("url:" + url + "异常信息: " + JsonConvert.SerializeObject(error)); LogAPI.WriteInfo($"API接口", $"{builder}"); } private static void LogRequestParameters(string parameters, string url = "") { StringBuilder builder = new StringBuilder(); builder.Append(Environment.NewLine); builder.Append("---------------------------------------------"); builder.Append(Environment.NewLine); builder.Append("url:" + url + "请求参数: " + JsonConvert.SerializeObject(parameters)); LogAPI.WriteInfo($"API接口", $"{builder}"); } private static void LogResponseParameters(string responseBody, string url = "") { StringBuilder builder = new StringBuilder(); builder.Append(Environment.NewLine); builder.Append("url:" + url + "响应参数: " + responseBody); builder.Append(Environment.NewLine); builder.Append("---------------------------------------------"); builder.Append(Environment.NewLine); LogAPI.WriteInfo($"API接口", $"{builder}"); } } }