asp.net提取多层嵌套json数据的方法

雨,落在校园里!我撑着伞,慢慢地在雨中漫步。那嫣红的风凰叶,在雨中,轻轻地飘落下来,似乎有一段离别哀愁的情感啊!

本文实例讲述了asp.net提取多层嵌套json数据的方法。分享给大家供大家参考,具体如下:

在.net 2.0中提取这样的json:

{"name":"lily","age":23,"addr":{"city":guangzhou,"province":guangdong}}

引用命名空间:

using Newtonsoft.Json;
using Newtonsoft.Json.Linq;

可以把上面的JSON看成一个对象.你只要写对应的类即可

public class UserInfo
{
public string name;
public int age;
public address addr;
}
public class address
{
public string city;
public string province;
}

然后在解析的地方这样写:

string jsonData="{\"name\":\"lily\",\"age\":23,\"addr\":{\"city\":guangzhou,\"province\":guangdong}}";
UserInfo user=(UserInfo)JsonConvert.DeserializeObject(jsonData, typeof(UserInfo));

得到City的值只要:user.addr.City;

这样实现也行

JObject jsonObj = JObject.Parse(jsonData);
string name=jsonObj ["name"].ToString();
string age=jsonObj ["age"].ToString();
string city=((JObject )jsonObj ["addr"])["city"].ToString();
string province=((JObject )jsonObj ["addr"])["province"].ToString();

如何这个json是动态的呢?譬如让你输入一个json,如

{"name":"lily","age":23,"addr":{"city":guangzhou,"province":guangdong}};

然后让你输入一个对象,如city,然后系统会输出guangzhou这个值,那这样的话,json就是动态生成的了,我想了解有没有读取这样的json的方法。(注意,json是多级嵌套的。)

就用遍历

public string GetJsonValue(JEnumerable<JToken> jToken,string key)
{
IEnumerator enumerator = jToken.GetEnumerator();
while (enumerator.MoveNext())
{
JToken jc = (JToken)enumerator.Current;
if (jc is JObject||((JProperty)jc).Value is JObject)
{
return GetJsonValue(jc.Children(), key);
}
else
{
if (((JProperty)jc).Name == key)
{
return ((JProperty)jc).Value.ToString();
}
}
}
return null;
}

在调用的时候:

string jsonData = "{\"name\":\"lily\",\"age\":23,\"addr\":{\"city\":\"guangzhou\",\"province\":\"guangdong\"}}";
JObject jsonObj = JObject.Parse(jsonData);
Response.Write(GetJsonValue(jsonObj.Children(), "province"));

如果有多层嵌套的数组

string jsonData = "{\"addr\":[{\"city\":\"guangzhou\",\"province\":\"guangdong\"},{\"city\":\"guiyang\",\"province\":\"guizhou\"}]}";
JObject jsonObj = JObject.Parse(jsonData);
JArray jar = JArray.Parse(jsonObj["addr"].ToString());
JObject j = JObject.Parse(jar[0].ToString());
Response.Write(j["city"]);

JSON转XML:

string xmlstr=((XmlDocument)JsonConvert.DeserializeXmlNode(jsonData)).InnerXml.ToString();

PS:关于json格式数据操作小编这里推荐几款本站的在线工具供大家免费使用,相信在以后的开发中可以派上用场:

在线JSON代码检验、检验、美化、格式化工具:
http://tools.haodaima.com/code/json

在线XML/JSON互相转换工具:
http://tools.haodaima.com/code/xmljson

C语言风格/HTML/CSS/json代码格式化美化工具:
http://tools.haodaima.com/code/ccode_html_css_json

json代码在线格式化/美化/压缩/编辑/转换工具:
http://tools.haodaima.com/code/jsoncodeformat

希望本文所述对大家asp.net程序设计有所帮助。

到此这篇关于asp.net提取多层嵌套json数据的方法就介绍到这了。如同未曾开始的故事,就被作者手中的笔生生刻下了结局。早安!更多相关asp.net提取多层嵌套json数据的方法内容请查看相关栏目,小编编辑不易,再次感谢大家的支持!

您可能有感兴趣的文章
ASP.NET轻量级MVC框架Nancy的基本用法

使用grpcui测试ASP.NET core的gRPC服务

ASP.NET Core中的对象池介绍

asp.net中MVC的处理流程详解

ASP.NET Core的日志系统介绍