繁体   English   中英

解析JSON数据ASP.NET C#和Razor

[英]Parsing JSON data ASP.NET C# and Razor

嗨,我正在使用ASP.NET和razor在VS中工作,试图用db表中的值填充表,但我必须将Json解码或解析为简单文本。 我真的很感谢您的帮助。 这就是我得到的。 在此处输入图片说明

  [HttpGet] public ActionResult GetData() { string stdb = "Data Source=DMX87025;Initial Catalog=DB_PCC;Integrated Security=True"; SqlConnection conn = new SqlConnection(stdb); string sql = "SELECT *FROM[DB_PCC].[dbo].[Departments]"; SqlCommand cmd = new SqlCommand(sql, conn); conn.Open(); SqlDataReader rd = cmd.ExecuteReader(); var st = "kyo please help me uu"; return Json(new { success = true, message = rd }, JsonRequestBehavior.AllowGet); } 
这是我的AJAX ...

 <div id="result"></div> <input type="button" name="name" value="try" onclick="DepListQuery()" /> <script> function DepListQuery() { $.ajax({ type: 'GET', url: '@Url.Action("GetData","Home")', contentType: "application/json; charset=utf-8", dataType: "json", success: function (response) { $('#result').text(response.message); }, failure: function (response) { alert("something get wrong uu"); } }); } </script> 

您需要解决的第一件事是如何从SqlDataReader读取数据。 这是有关此操作的教程: http : //csharp-station.com/Tutorial/AdoDotNet/Lesson04

但更好的方法是将数据直接读入对象。 有关创建此类扩展方法的详细信息,请参见此答案: 将数据读取器中的行转换为键入的结果

样本扩展方法:

public static List<T> ReadList<T>(this IDataReader reader, 
                                  Func<IDataRecord, T> generator) {
     var list = new List<T>();
     while (reader.Read())
         list.Add(generator(reader));
     return list;
}

在您的SqlDataReader rd = cmd.ExecuteReader(); 行,您将需要以下内容:

var departmentList = reader.ReadList(x => new Department {
                                           DeptID = x.GetInt32(0),
                                           DeptName = x.GetString(1)
                                    });

然后,一旦有了这样的对象列表,就可以将它们返回到前端视图ajax:

如何在ajax返回上解析字符串的JSON列表?

Json字符串的对象列表

我还想指出,您应该using块包围SqlConnectionSqlCommandSqlDataReader等。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM