| | |
| | | public static async Task<string> GetAsync(string url, Dictionary<string, object> parameters) |
| | | { |
| | | // 记录请求参数 |
| | | LogRequestParameters(parameters); |
| | | LogRequestParameters(parameters, url); |
| | | |
| | | // 将参数拼接到URL中 |
| | | string queryString = string.Join("&", parameters.Select(x => $"{x.Key}={x.Value}")); |
| | |
| | | string responseBody = await response.Content.ReadAsStringAsync(); |
| | | |
| | | // 记录响应参数 |
| | | LogResponseParameters(responseBody); |
| | | LogResponseParameters(responseBody, url); |
| | | |
| | | // 返回响应内容 |
| | | return responseBody; |
| | |
| | | public static async Task<string> PostAsync(string url, Dictionary<string, object> parameters) |
| | | { |
| | | // 记录请求参数 |
| | | LogRequestParameters(parameters); |
| | | LogRequestParameters(parameters, url); |
| | | |
| | | // 创建HttpClient实例 |
| | | using (HttpClient client = new HttpClient()) |
| | | { |
| | | // 将参数转换为FormUrlEncodedContent |
| | | string content = JsonConvert.SerializeObject(parameters); |
| | | |
| | | //client.Timeout = TimeSpan.from; |
| | | |
| | | var request = new HttpRequestMessage(HttpMethod.Post, url); |
| | | |
| | |
| | | string responseBody = await response.Content.ReadAsStringAsync(); |
| | | |
| | | // 记录响应参数 |
| | | LogResponseParameters(responseBody); |
| | | LogResponseParameters(responseBody, url); |
| | | |
| | | // 返回响应内容 |
| | | return responseBody; |
| | | } |
| | | } |
| | | |
| | | private static void LogRequestParameters(Dictionary<string, object> parameters) |
| | | private static void LogRequestParameters(Dictionary<string, object> parameters,string url = "") |
| | | { |
| | | LogFactory.GetLog("API接口").Info(true, "请求参数: " + JsonConvert.SerializeObject(parameters)); |
| | | StringBuilder builder = new StringBuilder(); |
| | | builder.Append(Environment.NewLine); |
| | | builder.Append("---------------------------------------------"); |
| | | builder.Append(Environment.NewLine); |
| | | builder.Append("url:" + url + "请求参数: " + JsonConvert.SerializeObject(parameters)); |
| | | LogFactory.GetLog("API接口").Info(true, builder); |
| | | } |
| | | |
| | | private static void LogResponseParameters(string responseBody) |
| | | private static void LogResponseParameters(string responseBody, string url = "") |
| | | { |
| | | LogFactory.GetLog("API接口").Info(true, "响应参数: " + responseBody); |
| | | StringBuilder builder = new StringBuilder(); |
| | | builder.Append(Environment.NewLine); |
| | | builder.Append("url:" + url + "响应参数: " + responseBody); |
| | | builder.Append(Environment.NewLine); |
| | | builder.Append("---------------------------------------------"); |
| | | builder.Append(Environment.NewLine); |
| | | LogFactory.GetLog("API接口").Info(true, builder); |
| | | } |
| | | |
| | | private static IEnumerable<KeyValuePair<string, string>> ConvertToKeyValuePairs(Dictionary<string, object> parameters) |