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

相关推荐
天天摸鱼的java工程师9 分钟前
🔧 MySQL 索引的设计原则有哪些?【原理 + 业务场景实战】
java·后端·面试
snakeshe101013 分钟前
Maven核心功能与IDEA高效调试技巧全解析
后端
*愿风载尘*1 小时前
ksql连接数据库免输入密码交互
数据库·后端
溟洵1 小时前
Qt 窗口 工具栏QToolBar、状态栏StatusBar
开发语言·前端·数据库·c++·后端·qt
ppo921 小时前
MCP简单应用:使用SpringAI + Cline + DeepSeek实现AI创建文件并写入内容
人工智能·后端
创码小奇客1 小时前
Talos 使用全攻略:从基础到高阶,常见问题一网打尽
java·后端·架构
Re2751 小时前
ThreadLocal 入门:搞懂线程私有变量
后端
midsummer_woo2 小时前
基于spring boot的纺织品企业财务管理系统(源码+论文)
java·spring boot·后端
zc-code2 小时前
Spring Boot + @RefreshScope:动态刷新配置的终极指南
java·spring boot·后端
何中应2 小时前
EasyExcel使用(二:写出)
java·后端·maven·excel