在 ASP.NET Web 应用中解析 JSON 数据实例

ASP.NET Web 应用中解析 JSON 数据有多种方法,取决于你使用的是传统的 Web Forms、MVC 还是现代的 Web API。以下是几种常见的解析方法:

1. 使用 Newtonsoft.Json (Json.NET)

这是最常用的 JSON 处理库,需要先安装 NuGet 包:

bash 复制代码
Install-Package Newtonsoft.Json

反序列化 JSON 到对象

cs 复制代码
using Newtonsoft.Json;

// JSON 字符串
string json = @"{
    'Name': 'John Doe',
    'Age': 30,
    'Email': 'john@example.com'
}";

// 定义对应的类
public class Person
{
    public string Name { get; set; }
    public int Age { get; set; }
    public string Email { get; set; }
}

// 反序列化
Person person = JsonConvert.DeserializeObject<Person>(json);

序列化对象到 JSON

cs 复制代码
Person person = new Person
{
    Name = "Jane Smith",
    Age = 28,
    Email = "jane@example.com"
};

string json = JsonConvert.SerializeObject(person);

2. 使用 .NET 内置的 System.Text.Json (适用于 .NET Core 3.0+)

cs 复制代码
using System.Text.Json;

// 反序列化
Person person = JsonSerializer.Deserialize<Person>(json);

// 序列化
string json = JsonSerializer.Serialize(person);

3. 在 ASP.NET Web API 中自动处理 JSON

在 Web API 控制器中,框架会自动处理 JSON 的序列化和反序列化:

cs 复制代码
public class UsersController : ApiController
{
    // POST api/users
    public IHttpActionResult PostUser(Person person)
    {
        // person 参数会自动从请求的 JSON 体反序列化
        // 处理逻辑...
        return Ok();
    }
    
    // GET api/users/1
    public IHttpActionResult GetUser(int id)
    {
        Person person = GetPersonFromDatabase(id);
        return Ok(person); // 自动序列化为 JSON
    }
}

4. 在 ASP.NET MVC 中处理 JSON

接收 JSON 数据

cs 复制代码
[HttpPost]
public ActionResult ProcessJson()
{
    using (var reader = new StreamReader(Request.InputStream))
    {
        string json = reader.ReadToEnd();
        var person = JsonConvert.DeserializeObject<Person>(json);
        // 处理逻辑...
    }
    return Json(new { success = true });
}

返回 JSON 结果

cs 复制代码
public ActionResult GetUser(int id)
{
    Person person = GetPersonFromDatabase(id);
    return Json(person, JsonRequestBehavior.AllowGet);
}

5. 在客户端使用 JavaScript 处理

javascript 复制代码
// 发送 JSON 数据到服务器
$.ajax({
    url: '/api/users',
    type: 'POST',
    contentType: 'application/json',
    data: JSON.stringify({ Name: "John", Age: 30 }),
    success: function(response) {
        console.log(response);
    }
});

// 接收服务器返回的 JSON
$.getJSON('/api/users/1', function(data) {
    console.log(data.Name);
});

注意事项

  1. 确保请求和响应的 Content-Type 设置为 application/json

  2. 对于大型 JSON 数据,考虑使用流式处理而不是一次性加载到内存

  3. 处理 JSON 时要考虑安全性,防范 JSON 注入攻击

  4. 对于复杂的 JSON 结构,确保你的模型类与之匹配

以上方法适用于不同版本的 ASP.NET,选择哪种取决于你的项目类型和 .NET 版本。

相关推荐
葫芦和十三18 小时前
图解 MongoDB 26|片键设计:决定集群命运的一个决定
后端·mongodb·agent
Avan_菜菜19 小时前
使用 Docker + rclone 自建 WebDAV
后端·agent·claude
阳光是sunny21 小时前
别再被 worktree 绕晕了!AI 编程时代你必须掌握的 Git 隔离神器
前端·人工智能·后端
万少1 天前
万少的博客 - 技术分享与解决方案
前端·javascript·后端
咖啡八杯1 天前
GoF设计模式——备忘录模式
java·后端·spring·设计模式
苍何1 天前
腾讯再放大招,企微 Agent 大圆开启内测
后端
ethantan1 天前
一篇讲解AI Agent 组成:像人一样思考的智能体
人工智能·后端·程序员
Cosolar1 天前
vLLM 生产级部署完全指南
人工智能·后端·架构
IT_陈寒1 天前
垃圾回收器选错了,我的Java服务内存炸了
前端·人工智能·后端
用户8356290780511 天前
使用 Python 在 PDF 中创建与管理书签
后端·python