赞
踩
在MVC项目中,经常需要在控制器中向客户端返回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串。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。