在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。

asp.net MVC控制器返回json问题总结_json


测试时,返回如下结果,说明正常返回了json串。

asp.net MVC控制器返回json问题总结_json_03