asp.net MVC控制器返回json问题总结
2016-04-03 11:39
681 查看
在MVC项目中,经常需要在控制器中向客户端返回json数据,常见的返回方法如下:
1、如果服务器端完全采用微软的类,则要序列号的集合类通常使用List<T>,返回时直接使用Json(list);则会自动将列表中的内容进行序列号,生成json字符串。
2、如果服务器端使用DataTable,则DataTable微软自己不能序列号,很奇怪!要使用Json(table)返回,是不能直接序列号的。还需要将行定义成对象,如:
这样比较啰嗦。
3、直接使用Newtonsoft.json对table进行序列化,得到json字符串。
此时不能使用Json(str)的形式返回,这样返回的话,客户端不会识别为json。
可以直接返回Content(str)即可。
4、如果采用字符串拼接的形式,同方法3.
在浏览器中测试时,返回如下内容,说明有问题,在客户不会被自动解析成json。
测试时,返回如下结果,说明正常返回了json串。
1、如果服务器端完全采用微软的类,则要序列号的集合类通常使用List<T>,返回时直接使用Json(list);则会自动将列表中的内容进行序列号,生成json字符串。
2、如果服务器端使用DataTable,则DataTable微软自己不能序列号,很奇怪!要使用Json(table)返回,是不能直接序列号的。还需要将行定义成对象,如:
class Person { public string username { get; set; } public string truename { get; set; } public int age { get; set; } }----------------------------------
List<Person> list = new List<Person>(); DataTable dt = new DataTable(); try { sqlcnn.Open(); SqlDataReader reader = sqlcmm.ExecuteReader(); while (reader.Read()) list.Add(new Person { username = reader.GetString(0), truename = reader.GetString(1), age = reader.GetInt32(2) }); //读取数据 sqlcnn.Close(); } catch { } return Json(list, JsonRequestBehavior.AllowGet);
这样比较啰嗦。
3、直接使用Newtonsoft.json对table进行序列化,得到json字符串。
此时不能使用Json(str)的形式返回,这样返回的话,客户端不会识别为json。
可以直接返回Content(str)即可。
4、如果采用字符串拼接的形式,同方法3.
在浏览器中测试时,返回如下内容,说明有问题,在客户不会被自动解析成json。
测试时,返回如下结果,说明正常返回了json串。
相关文章推荐
- 分享微信开发Html5轻游戏中的几个坑
- XML 与 JSON 优劣对比
- VBA将excel数据表生成JSON文件
- newtonsoft.json解析天气数据出错解决方法
- vbs 解析json jsonp的方法
- Extjs4如何处理后台json数据中日期和时间
- C#实现将类的内容写成JSON格式字符串的方法
- JQuery ajax返回JSON时的处理方式 (三种方式)
- jquery JSON的解析方式示例介绍
- c#版json数据解析示例分享
- ASP JSON类文件的使用方法
- C#实现对Json字符串处理实例
- C#实现Json转Unicode的方法
- Zend的MVC机制使用分析(二)
- php解析json数据实例
- PHP中JSON的应用技巧
- PHP6 先修班 JSON实例代码
- 关于JSON以及JSON在PHP中的应用技巧
- .Net中的json操作类用法分析
- C#操作 JSON方法汇总