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

相关推荐
MegaDataFlowers18 分钟前
快速上手Spring
java·后端·spring
小江的记录本18 分钟前
【MyBatis-Plus】Spring Boot + MyBatis-Plus 进行各种数据库操作(附完整 CRUD 项目代码示例)
java·前端·数据库·spring boot·后端·sql·mybatis
大傻^25 分钟前
Spring AI Alibaba Function Calling:外部工具集成与业务函数注册
java·人工智能·后端·spring·springai·springaialibaba
码界奇点32 分钟前
基于Spring Boot的医院药品管理系统设计与实现
java·spring boot·后端·车载系统·毕业设计·源代码管理
小旭952736 分钟前
Spring MVC :从入门到精通(下)
java·后端·spring·mvc
SimonKing2 小时前
全网爆火的OpenClaw保姆级教程Linux版,它来了。
java·后端·程序员
青柠代码录2 小时前
【Linux】常用命令:sort
后端
小江的记录本3 小时前
【MyBatis-Plus】MyBatis-Plus的核心特性、条件构造器、分页插件、乐观锁插件
java·前端·spring boot·后端·sql·tomcat·mybatis
驕傲的兎孒3 小时前
基于 SpringBoot + Vue3 + AI 打造企业级售后服务支持平台 | 实战方案分享
人工智能·spring boot·后端
大傻^3 小时前
Spring AI Alibaba 可观测性实践:AI应用监控与链路追踪
java·人工智能·后端·spring·springaialibaba