python - .NET 中使用的 Python Hug REST API,JSON 看起来很奇怪
问题描述
从 .net JSON 使用 Hug REST 端点时,会嵌入字符。下面发布了一个完整的失败示例。非常感谢任何帮助。
Python
@hug.post('/test')
def test(response, body=None):
input = body.get('input')
print('INSIDE TEST ' + input)
if input:
dict = {"lastname":"Jordan"}
dict["firstname"] = input
return json.dumps(dict, sort_keys=True, default=str)
.NET(只能使用 .net 3.5)
private static object GetParsedData(string data)
{
var posturl = "http://localhost:8000/test";
try
{
using (var client = new WebClient())
{
// upload values is the POST verb
var values = new NameValueCollection()
{
{ "input", data },
};
var response = client.UploadValues(posturl, values);
var responseString = Encoding.UTF8.GetString(response);
var settings = new JsonSerializerSettings
{
NullValueHandling = NullValueHandling.Ignore,
MissingMemberHandling = MissingMemberHandling.Ignore
};
JObject rss = JObject.Parse(responseString);
Console.WriteLine((string)rss["lastname"]);
}
}
catch (WebException ex)
{
if (ex.Response is HttpWebResponse)
{
var code = ((HttpWebResponse)ex.Response).StatusCode;
var desc = ((HttpWebResponse)ex.Response).StatusDescription;
}
//_logger.Error(ex.Message);
}
return false;
}
responseString 看起来像这样:
"\"{\\\"firstname\\\": \\\"Mike\\\", \\\"lastname\\\": \\\"Jordan\\\"}\""
JObject.Parse 抛出错误:
Newtonsoft.Json.JsonReaderException:
'Error reading JObject from JsonReader. Current JsonReader item is not an object: String. Path '', line 1, position 53.
解决方法 - 如果我对 responseString JObject 正确解析做这样可怕的事情:
str = str.Replace("\\", "");
str = str.Substring(1, len - 2);
这是怎么回事?
解决方案
默认的拥抱输出格式为json;不需要调用json.dumps
返回值,Hub 会自动执行此操作。
推荐阅读
- selenium - 在 selenium 中使用记住的用户模拟网站
- apache-kafka-streams - kafka 流没有从平面地图值向 dlq 主题生成消息
- python - pd.Series - “文件名” KeyError
- android - Android 防止在剪贴板中写入
- json - json中具体节点的全文搜索
- java - Hackerrank 错误答案
- asp.net - 将现有 Dnn 应用程序转换为 .Net 核心
- pagespeed-insights - 按国家/地区划分的 Crux Page 特定数据?
- android - 当我使用 LiveData 观察 dataList 时,通过服务 RecyclerView 调用 API 时出现故障
- sql - 从离散日期创建间隔