.NET MVC第九章、Web Api Json序列化与反序列化

简介: .NET MVC第九章、Web Api Json序列化与反序列化

json数据格式

JSON(JavaScript Object Notation, JS对象简谱)是一种轻量级的数据交换格式。它基于 ECMAScript(European Computer Manufacturers Association, 欧洲计算机协会制定的js规范)的一个子集,采用完全独立于编程语言的文本格式来存储和表示数据。简洁和清晰的层次结构使得 JSON 成为理想的数据交换语言。 易于人阅读和编写,同时也易于机器解析和生成,并有效地提升网络传输效率。


JSON 语法

JSON是一个标记符的序列。这套标记符包含六个构造字符、字符串、数字和三个字面名。


JSON是一个序列化的对象或数组。

{"state":true,"message":"成功访问","result":["苏洵","苏轼","苏辙","苏秦","苏代","苏厉"]}

image.png


这里写了个通用的格式,key:value类型。可以直接使用,我们为了练习,强行二次json序列化一下。


返回对象

public class SUCCESS
{
    public SUCCESS(string message,object result) {
        this.state = true;
        this.message = message;
        this.result = result;
    }
    public Boolean state { get; set; }
    public string message { get; set; }
    public object result { get; set; }
}

Json序列化

using Newtonsoft.Json;
[HttpGet]
public Object GetInfo()
{
    List<string> list = new List<string>() { "苏洵", "苏轼", "苏辙", "苏秦", "苏代", "苏厉" };
    return JsonConvert.SerializeObject(new SUCCESS("操作成功", list));
}

下面是返回结果


"{\"state\":true,\"message\":\"成功访问\",\"result\":[\"苏洵\",\"苏轼\",\"苏辙\",\"苏秦\",\"苏代\",\"苏厉\"]}"


image.png

反序列化:

使用JsonConvert.DeserializeObject(string)进行反序列化


public object GetInfoApi() {
    HttpClient http = new HttpClient();
    Task<string> task = http.GetStringAsync("http://localhost:1246/api/Test/GetInfo");
    string result = task.Result;
    return JsonConvert.DeserializeObject(result);
}

如果未反序列化直接输出则是:


image.png


反序列化后:


image.png


可以看到对应的效果,不过我们不能使用这种带/的json数据,这类是无法正常解析的。


稍微大型一些json格式数据:


{
    "code": 200,
    "message": "查询成功",
    "result": [
        {
            "id": "1D19A58448C144CDA867B3BCE7265D07",
            "createDate": "2021-06-12T14:38:50.547",
            "nickName": "苏泽开",
            "introduce": "帅气的王润松同桌"
        },
        {
            "id": "2CC74D39758641EB99AB0A6DCC59F5E5",
            "createDate": "2021-06-11T15:15:25.583",
            "nickName": "张宇婷",
            "introduce": "国士无双"
        },
        {
            "id": "30F890AB477D4425ADE95773F95985F0",
            "createDate": "2021-06-11T15:16:51.4",
            "nickName": "张舒",
            "introduce": "迪士尼在逃公主,仙女啥样她啥样。"
        },
        {
            "id": "5f42022a8bd347609defc4efd122aa5d",
            "createDate": "2021-09-28T14:19:18.71",
            "nickName": "曲弘扬",
            "introduce": "黑帮教父"
        },
        {
            "id": "6A8746DCB76547BD9BB66597E7E06EF3",
            "createDate": "2021-06-11T15:12:39.32",
            "nickName": "王佳敏",
            "introduce": "当真是喜从天降,一生之中,从未听见过有四个字是这般好听的。"
        },
        {
            "id": "86A3F5AAEBBA49768E6BE55E631B9A21",
            "createDate": "2021-06-11T15:16:22.947",
            "nickName": "张紫璇",
            "introduce": "峨眉绝世不可寻,能使花羞在上林。"
        },
        {
            "id": "955D402234224263A91C28BFD93A24A4",
            "createDate": "2021-06-11T15:10:53.753",
            "nickName": "常子怡",
            "introduce": "北方有美人绝世而独立。一顾倾人城,再顾倾人国。"
        },
        {
            "id": "9855E757E7664F7A81D10159FA4AA4B4",
            "createDate": "2021-06-11T15:08:44.89",
            "nickName": "黄珊",
            "introduce": "箫长琴短衣流黄"
        },
        {
            "id": "9B924F52D9984ED89F0B503D884C86BE",
            "createDate": "2021-06-11T15:06:05.217",
            "nickName": "王浩博",
            "introduce": "人见人爱,花见花开,车见车载。"
        },
        {
            "id": "d0dff2b742054077a4cf94907a25d168",
            "createDate": "2021-09-15T09:26:49.317",
            "nickName": "龙珠",
            "introduce": "笑若桃花三月开,清风徐徐醉颜来。"
        },
        {
            "id": "D8936E94D3AE4313A7C4B2F469B417E5",
            "createDate": "2021-06-11T15:13:38",
            "nickName": "付伟佳",
            "introduce": "芙蓉不足佳人妆,水殿风来珠翠香。"
        },
        {
            "id": "E2DE7B3B5BA943F6BEC0A9E32F6C4941",
            "createDate": "2021-06-11T15:10:01.75",
            "nickName": "纪茜茜",
            "introduce": "云想衣裳花想容,春风拂槛露华浓,若非群玉山头见,会向瑶台月下逢。"
        }
    ]
}
相关文章
|
2月前
|
存储 JSON 安全
如何使用 JSON Web Tokens 进行身份验证?
总的来说,JWT 是一种强大而灵活的身份验证方式,通过正确使用和管理,可以为应用提供可靠的身份验证机制,同时提高系统的可扩展性和安全性。在实际应用中,需要根据具体的需求和场景,合理设计和实施 JWT 身份验证方案。
123 63
|
2月前
|
开发框架 .NET 程序员
驾驭Autofac,ASP.NET WebApi实现依赖注入详细步骤总结
Autofac 是一个轻量级的依赖注入框架,专门为 .NET 应用程序量身定做,它就像是你代码中的 "魔法师",用它来管理对象的生命周期,让你的代码更加模块化、易于测试和维护
驾驭Autofac,ASP.NET WebApi实现依赖注入详细步骤总结
|
23天前
|
JSON API 数据格式
淘系等商品评论Json数据格式参考,API接口测试
通过以上示例和说明,你可以了解淘系商品评论的JSON数据结构和如何使用相关API接口获取评论数据。在实际操作中,你需要参考具体的API接口文档和开放平台的相关说明进行配置和调用。
|
2月前
|
JSON API 数据安全/隐私保护
拍立淘按图搜索API接口返回数据的JSON格式示例
拍立淘按图搜索API接口允许用户通过上传图片来搜索相似的商品,该接口返回的通常是一个JSON格式的响应,其中包含了与上传图片相似的商品信息。以下是一个基于淘宝平台的拍立淘按图搜索API接口返回数据的JSON格式示例,同时提供对其关键字段的解释
|
2月前
|
JSON API 数据格式
Amazon商品详情API,json数据格式示例参考
亚马逊商品详情API接口返回的JSON数据格式通常包含丰富的商品信息,以下是一个简化的JSON数据格式示例参考
|
2月前
|
JSON API 数据格式
店铺所有商品列表接口json数据格式示例(API接口)
当然,以下是一个示例的JSON数据格式,用于表示一个店铺所有商品列表的API接口响应
|
3月前
|
JSON API 数据安全/隐私保护
拍立淘按图搜索json数据格式示例(API接口)
拍立淘按图搜索API接口为电商平台和购物应用提供了强大的图像搜索功能,能够显著提升用户的购物体验和搜索效率。开发者可以根据自己的需求调用此接口,并处理返回的JSON格式数据来展示推荐商品
|
3月前
|
开发框架 .NET API
Windows Forms应用程序中集成一个ASP.NET API服务
Windows Forms应用程序中集成一个ASP.NET API服务
113 9
|
3月前
|
JSON API 数据格式
低代码实现鸿蒙API返回JSON转TS及快速生成ArkUI代码
低代码实现鸿蒙API返回JSON转TS及快速生成ArkUI代码
65 0
低代码实现鸿蒙API返回JSON转TS及快速生成ArkUI代码
|
3月前
|
JSON API 数据格式
商品详情数据JSON格式示例参考(api接口)
JSON数据格式的商品详情数据通常包含商品的多个层级信息,以下是一个综合多个来源信息的JSON数据格式的商品详情数据示例参考: