博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Json.Net系列教程 1.Json.Net介绍及实例
阅读量:6596 次
发布时间:2019-06-24

本文共 5109 字,大约阅读时间需要 17 分钟。

本系列教程假设读者已经对Json有一定的了解,关于Json在这里不多说.本系列教程希望能对读者开发涉及到Json的.Net项目有一定的帮助.本系列教程是根据官方文档资料和自己项目应用汇总而成.如果觉得本系列对你有用,望多多关注.本人还只是个未毕业的学生,水平有限,尽请指正.

一.Json.Net有什么用?

  Json.Net是一个读写Json效率比较高的.Net框架.Json.Net 使得在.Net环境下使用Json更加简单。通过Linq To JSON可以快速的读写Json,通过JsonSerializer可以序列化你的.Net对象。让你轻松实现.Net中所有类型(对象,基本数据类型等)和Json的转换.

  Json.Net目前的版本是4.5 

二.为什么要用Json.Net?

  我们知道在.Net中内置了读写Json的对象(DataContractJsonSerializer,JavaScriptSerializer),为什么我们还要用Json.Net呢?

  功能对比: 

特性 Json.Net DataContractJsonSerializer JavaScriptSerializer
Json 支持 支持 支持
Bson 支持 不支持 不支持
Json Schema 支持 不支持 不支持
.Net 2.0 支持 不支持 不支持
.Net 3.5 支持 支持 支持
.Net 4.0 支持 支持 支持
Silverlight 支持 支持 不支持
Windows Phone 支持 支持 不支持
Windows 8 Metro 支持 支持 不支持
Linq to Json 支持 不支持 不支持
Indented Json(有换行格式的Json) 支持 不支持 不支持
Json和XML转换 支持 不支持 不支持
序列化DataTable和DataSet 支持 不支持 不支持
序列化Entity Framework 支持 不支持 不支持

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

  性能对比:

三.实例

下面通过一个实例来展示它在项目的应用.下面的例子是通过Ajax和Json显示所有用户的列表信息.

准备: 创建一个Web项目,本应用程序是通过VS2010创建的.并添加引用Newtonsoft.Json.dll

1.首先创建一个Person对象

///     /// 包含用户的基本信息    ///     public class Person    {        ///         /// 获取或设置用户名        ///         public string Name { get; set; }        ///         /// 获取或设置用户年龄        ///         public int Age { get; set; }        ///         /// 获取或设置用户性别        ///         public string Gender { get; set; }        ///         /// 获取或设置用户国籍        ///         public string Country { get; set; }        ///         /// 获取或设置用户电子邮箱        ///         public string Email { get; set; }    }

2.创建用户操作类PersonRepository,用来对Person的操作,本例中仅仅用来获取Person对象列表

///     /// 用户操作类    ///     public class PersonRepository    {        ///         /// 获取用户列表        ///         /// 
所有用户信息
public static List
GetPersons() { List
ps = new List
(); Person p1 = new Person { Name = "Tom", Age = 32, Country = "US", Gender = "Male", Email = "tom@gmail.com" }; Person p2 = new Person { Name = "Jack", Age = 23, Country = "UK", Gender = "Male", Email = "jack@gmail.com" }; Person p3 = new Person { Name = "Eden", Age = 25, Country = "Canada", Gender = "Female", Email = "eden@gmail.com" }; Person p4 = new Person { Name = "Li Hua", Age = 29, Country = "China", Gender = "Male", Email = "lihui@163.com" }; Person p5 = new Person { Name = "Lvo", Age = 40, Country = "US", Gender = "Male", Email = "lvo@gmail.com" }; ps.Add(p1); ps.Add(p2); ps.Add(p3); ps.Add(p4); ps.Add(p5); return ps; } }

3.添加一个一般处理程序,我将其命名为PersonHandler.ashx,引入命名空间"using Newtonsoft.Json",修改ProcessRequest函数中的代码如下:

///     /// 处理用户类的请求    ///     public class PersonHandler : IHttpHandler    {        public void ProcessRequest(HttpContext context)        {            List
persons = PersonRepository.GetPersons(); string json = JsonConvert.SerializeObject(persons); context.Response.Write(json); } public bool IsReusable { get { return false; } } }

通过Json.Net来序列化对象,可以通过

string json = JsonConvert.SerializeObject(Object obj);

 

还可以通过JsonSerializer来实现

JsonSerializer serializer = new JsonSerializer();            StringBuilder sb = new StringBuilder();            StringWriter sw = new StringWriter(sb);            JsonWriter writer = new JsonTextWriter(sw);            serializer.Serialize(writer, persons);            string json = sb.ToString();

这两种方式有什么联系和区别呢?

实际上,JsonConvert.SerializerObject内部就是通过JsonSerializer来实现的.

public static string SerializeObject(object value, Formatting formatting, JsonSerializerSettings settings){    JsonSerializer jsonSerializer = JsonSerializer.Create(settings);    StringBuilder sb = new StringBuilder(0x100);    StringWriter sw = new StringWriter(sb, CultureInfo.InvariantCulture);    using (JsonTextWriter jsonWriter = new JsonTextWriter(sw))    {        jsonWriter.Formatting = formatting;        jsonSerializer.Serialize(jsonWriter, value);    }    return sw.ToString();}

区别在于JsonSerializer序列化时,你可以选择用JsonWriter也可以选择TextWriter.而JsonConvert只是默认使用JsonTextWriter. 

4.添加一个Html网页,网页的内容仅仅用来显示用户的基本信息

用户名 年龄 性别 国籍 电子邮箱

5.添加javascript代码,实现Ajax请求.首先要在头文件中引入JQuery

    

$.getJSON可以进行异步Ajax请求,并可以直接返回JSON对象

  jQuery.getJSON(url,data,success(data,status,xhr))   

 

参数说明

参数 描述
url 必需。规定将请求发送的哪个 URL。
data 可选。规定连同请求发送到服务器的数据。
success(data,status,xhr)

可选。规定当请求成功时运行的函数。

额外的参数:

  • response - 包含来自请求的结果数据
  • status - 包含请求的状态
  • xhr - 包含 XMLHttpRequest 对象

 

 

 

 

 

 

 

 

 

运行效果:

 

转载于:https://www.cnblogs.com/usharei/archive/2012/04/18/2454967.html

你可能感兴趣的文章
win7图片目录位置
查看>>
Maven
查看>>
FastDFS之集群部署
查看>>
Centos6.3系统语言设置
查看>>
我的友情链接
查看>>
javascript不可用的问题探究
查看>>
[置顶] jQuery乱谈(五)
查看>>
have sth done/doing的区别
查看>>
paste用法
查看>>
《java开发实战经典》读书笔记——第3章 Java基础程序设计之数据类型划分20151026...
查看>>
C. Tanya and Toys_模拟
查看>>
Swift 表达式
查看>>
JS实例(一)百度前端技术学院任务(十三)
查看>>
DEBUG(2)--函数的输入参数要做适当的检查
查看>>
js适配器模式
查看>>
xocde7下导入libsqlite3.tbd编译报错的解决办法
查看>>
100c之39:年龄问题
查看>>
吴忠军人民微博主页
查看>>
java 浅复制 深复制
查看>>
day09 函数
查看>>