response.Content.ReadAsStringAsync().Result 返回的Json字串中文字变成\u8d44\u4ea7这种字符

ivanl 2020-08-27 04:20:47
private void HttpSendRequest(string HTTPMethods,string RequestURL, string epicorLogin, string XAPIKey, string jsonStr, ref string ResponseStatusCode, ref string ResponseBody, ref string IsSuccessStatusCode, ref string ErrorMessage, ref string ExceptionMsg)
{
try
{
//Ignore SSL certificates
var handler = new WebRequestHandler();
handler.ServerCertificateValidationCallback = delegate { return true; };

using (HttpClient client = new HttpClient(handler))
{
client.DefaultRequestHeaders.Authorization = new AuthenticationHeaderValue("Basic", Convert.ToBase64String(ASCIIEncoding.ASCII.GetBytes(epicorLogin)));
// Add an Accept header for JSON format.
client.DefaultRequestHeaders.Accept.Add(new MediaTypeWithQualityHeaderValue("application/json"));
client.DefaultRequestHeaders.Add("X-API-Key", XAPIKey);
string TokenCreateURL = RequestURL;
var request = new HttpRequestMessage();
HttpResponseMessage response = null;

if (HTTPMethods == "POST")
{
request.RequestUri = new Uri(TokenCreateURL);
request.Method = HttpMethod.Post;

//send user credential
request.Content = new StringContent(jsonStr, Encoding.UTF8, "application/json");

response = client.SendAsync(request).Result;



ResponseStatusCode = Convert.ToString((int)response.StatusCode);
}

if (HTTPMethods == "DELETE")
{
response = client.DeleteAsync(TokenCreateURL).Result;
ResponseStatusCode = Convert.ToString((int)response.StatusCode);
}

if (HTTPMethods == "GET")
{
response = client.GetAsync(TokenCreateURL).Result;
ResponseStatusCode = Convert.ToString((int)response.StatusCode);
}

//Get response


if (response.IsSuccessStatusCode)
{
IsSuccessStatusCode = "Yes";
}
else
{
IsSuccessStatusCode = "No";
}

ResponseBody = response.Content.ReadAsStringAsync().Result;

//Deserialize ResponseBody and catch "ErrorMessage"
if (ResponseBody.IndexOf("\"ErrorMessage\"") > 0)
{
dynamic dyn = Newtonsoft.Json.JsonConvert.DeserializeObject(ResponseBody);

foreach (var obj in dyn)
{
if (obj.Name == "ErrorMessage")
{
ErrorMessage = Convert.ToString(obj.Value);
break;
}
}
}
}
}
catch (AggregateException ex)
{
ExceptionMsg = ex.ToString();
}
}
...全文
1323 2 打赏 收藏 转发到动态 举报
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
木v知 2022-03-07
  • 打赏
  • 举报
回复

楼主解决了么

木v知 2022-03-08
  • 举报
回复
@木v知 发现只是因为接口做了Unicode编码,解码之后就可以了
内容概要:本文围绕基于Basisformer模型的时间序列锂离子电池SOC(State of Charge,荷电状态)预测展开研究,利用PyTorch框架实现深度学习模型的构建与训练。通过将历史充放电数据作为输入,Basisformer能够有效捕捉电池状态的动态变化特征,提升SOC预测精度。文详细介绍了模型结构设计、数据预处理流程、训练策略及实验结果分析,并与传统方法进行对比,验证了该方法在复杂工况下的优越性与鲁棒性。该研究不仅展示了Basisformer在时序建模的潜力,也为电池管理系统提供了高精度的状态估计解决方案。; 适合人群:具备一定Python编程基础和深度学习理论知识,熟悉PyTorch框架,从事电池管理系统、新能源汽车或智能预测方向研究的研究生、科研人员及工程技术人员。; 使用场景及目标:①应用于电动汽车、储能系统等领域的电池SOC高精度实时估算;②为电池健康管理(BMS)提供可靠的状态输入;③推动深度学习在时间序列预测的实际落地,提升现有预测模型的泛化能力与稳定性; 阅读建议:建议读者结合标题为【锂电池SOC估计】【PyTorch】基于Basisformer时间序列锂离子电池SOC预测研究(python代码实现)的资源,重点研读所提供的Python代码,深入理解数据处理方式与模型网络结构的设计思路,尝试调整超参数以观察对预测性能的影响,从而全面掌握Basisformer在时序建模的优势、适用边界及工程化实现路径。

28,404

社区成员

发帖
与我相关
我的任务
社区描述
ASP即Active Server Pages,是Microsoft公司开发的服务器端脚本环境。
社区管理员
  • ASP
  • 无·法
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧