前言

依据 Restful 的方式, 修改 resource 要用 PUT, 然后把完整的 resource 发出去, resource 的所有信息都将被更新.

但很多时候我们希望只做局部更新, 而且希望只提供局部的 resource info.

比如有个 person resource

class Person {
name: string;
age: number;
}

如果只想修改 age 的话, 那 body 就是 { age : 11 }, 够了.

JSON Path & JSON Merge Path

这种情况下, Restful 对应的方式就是使用 JSON Patch 和 JSON Merge Path

JSON Patch 的 method 是 PATCH, content-type 是 application/json-patch+json

JSON Merge Path 的 method 是 PATCH, content-type 是 application/merge-patch+json

它们比较大的区别在 body

JSON Merge Path 和我们上面期望的比较类似, 就只发想要修改的内容, 其余的就省略掉.

但有一点要留意的是 { age: null }, 这个表达的意思是, delete 掉 age 这个 property, 而不是把 age set value to null.

要把 age set to null, 就一定要用 PUT 或者 JSON Patch

JSON Patch 的 body 是一堆修改的表达格式.

大概长这样:

[
{
"op" : "replace" ,
"path" : "/users/0/email" ,
"value" : "alice@wonderland.org"
},
{
"op" : "add" ,
"path" : "/users/-" ,
"value" : {
"name" : "Christine",
"email" : "christine@example.org"
}
}
]

op 是 operation, 有 add, remove, replace, move, copy

path 就是定位那个 property 要修改

value 就 new value 咯.

所以 JSON Patch 能做的比 JSON Merge Patch 多, 但是也相对复杂一些.

主要参考:

JSON Patch and JSON Merge Patch

如何在ASP.NET Core中使用JSON Patch

JsonPatch in ASP.NET Core web API

JSON Patch With ASP.NET Core

JSON Merge Patch in .NET Core

JSON Merge Patch in ASP.NET Core

Should I use it?

JSON Patch 其实对前端来说是比较麻烦的, JSON Merge Patch 的 null 概念也容易被坑.

所以我个人觉得 Restful 的东西, 大多时候听听就好, 不要死死跟它.

也可以看看 WEB开发中,使用JSON-RPC好,还是RESTful API好?大宽宽的回答

JSON Patch in ASP.NET Core

首先 ASP.NET Core 没有 build-in JSON Merge Patch.

它目前只有 build-in JSON Patch 但还需要配合 NewtonsoftJson. Issue: JsonPatchDocument should use System.Text.Json in ASP.NET vNext

step by step 看这篇就可以了: JsonPatch in ASP.NET Core web API

前端就是传 operation

后端就是接收, 然后 apply to resource

具体 resource 是一个 DTO, 还是一个 entity, 自由发挥, 后续的 validation 什么的也自由发挥, 它就只是封装了把 operation apply to resource, 让 resource 变化而已.

所以有些人的做法是,

从数据库拿资料放入 DTO

在把 JSON Patch apply to DTO (覆盖原本的值)

这样 DTO 就完整了, 然后可以拿去做验证什么的

再然后把 DTO to Entity 更新数据.

到底这个做法对不对,好不好, 完全是看你要怎么管理.

抽象来看, JSON Patch 的主要职责就是表达如何修改资源, 它就是一个表达而已, 理解的人要做什么那个是理解的人要去实现的部分. 不要被套死死.

另外, 表达只是一种手法, 我们完全可以用其它的表达方式, 也不一定非要用 JSON Patch. 用它只是因为它有个规范, 有搭配一些便利的工具 (比如上面这个 apply to 的功能)

如果我们的场景比较特殊, 我们完全可以自己搞一套自己的规则 (要知道所有规则都是一点点 build 起来的, 法律也有 cover 不到的场景, 每年也都要修订, 没有绝对的)

ASP.NET Core – Web API JSON Patch的更多相关文章

  1. 在Mac下创建ASP.NET Core Web API

    在Mac下创建ASP.NET Core Web API 这系列文章是参考了.NET Core文档和源码,可能有人要问,直接看官方的英文文档不就可以了吗,为什么还要写这些文章呢? 原因如下: 官方文档涉 ...

  2. ASP.NET Core Web API 开发-RESTful API实现

    ASP.NET Core Web API 开发-RESTful API实现 REST 介绍: 符合REST设计风格的Web API称为RESTful API. 具象状态传输(英文:Representa ...

  3. 如何在ASP.NET Core中使用JSON Patch

    原文: JSON Patch With ASP.NET Core 作者:.NET Core Tutorials 译文:如何在ASP.NET Core中使用JSON Patch 地址:https://w ...

  4. ASP.NET Core Web API 最佳实践指南

    原文地址: ASP.NET-Core-Web-API-Best-Practices-Guide 介绍 当我们编写一个项目的时候,我们的主要目标是使它能如期运行,并尽可能地满足所有用户需求. 但是,你难 ...

  5. 使用 Swagger 自动生成 ASP.NET Core Web API 的文档、在线帮助测试文档(ASP.NET Core Web API 自动生成文档)

    对于开发人员来说,构建一个消费应用程序时去了解各种各样的 API 是一个巨大的挑战.在你的 Web API 项目中使用 Swagger 的 .NET Core 封装 Swashbuckle 可以帮助你 ...

  6. 在ASP.NET Core Web API上使用Swagger提供API文档

    我在开发自己的博客系统(http://daxnet.me)时,给自己的RESTful服务增加了基于Swagger的API文档功能.当设置IISExpress的默认启动路由到Swagger的API文档页 ...

  7. 在docker中运行ASP.NET Core Web API应用程序

    本文是一篇指导快速演练的文章,将介绍在docker中运行一个ASP.NET Core Web API应用程序的基本步骤,在介绍的过程中,也会对docker的使用进行一些简单的描述.对于.NET Cor ...

  8. docker中运行ASP.NET Core Web API

    在docker中运行ASP.NET Core Web API应用程序 本文是一篇指导快速演练的文章,将介绍在docker中运行一个ASP.NET Core Web API应用程序的基本步骤,在介绍的过 ...

  9. 在ASP.NET Core Web API中为RESTful服务增加对HAL的支持

    HAL(Hypertext Application Language,超文本应用语言)是一种RESTful API的数据格式风格,为RESTful API的设计提供了接口规范,同时也降低了客户端与服务 ...

  10. 如何在ASP.NET Core Web API测试中使用Postman

    使用Postman进行手动测试 如果您是开发人员,测试人员或管理人员,则在构建和使用应用程序时,有时了解各种API方法可能是一个挑战. 使用带有.NET Core的Postman为您的Web API生 ...

随机推荐

  1. JuiceFS 直连 NFS 新功能介绍,赋能 NAS 进行 AI 训练

    NAS 通过提供多用户网络数据存取服务,极大地简化了数据共享和管理.而 NFS 作为实现这种共享的一种主流协议,尽管广泛应用,但在处理复杂的 AI 训练场景时常常受限于其性能和一致性问题. Juice ...

  2. 开源!开源一个flutter实现的古诗拼图游戏

    去年(2023年)年底我初学flutter,看了一些文档和教程,想找个东西*练练手. 小时候看过一个关于历史名人儿时事迹的短片,有一集是讲*总理的,有一个细节我记得很清楚:幼年***经常要做一个游戏- ...

  3. 对比python学julia(第四章:人工智能)--(第三节)目标检测

    1.1.  项目简介 目标检测(Object Detection)的任务是在图像中找出检测对象的位置和犬小,是计算机视觉领域的核心问题之一,在自动驾驶.机器人和无人机等许多领域极具研究价值. 随着深度 ...

  4. 【Java】Jsoup 解析HTML报告

    一.需求背景 有好几种报告文件,目前是人肉找报告信息填到Excel上生成统计信息 跟用户交流了下需求和提供的几个文件,发现都是html文件 其实所谓的报告的文件,就是一些本地可打开的静态资源,里面也有 ...

  5. 【Java】【常用类】Comparable 可比较接口 Comparator 比较器接口

    我们需要对对象进行排序,但是对象不是像基本类型的那样,是具体的数值 如果要对对象比较,需要实现两个接口的任意一个即可 Comparable 可比较接口 Comparator 比较器接口 String包 ...

  6. 【HbuilderX】解决苹果手机不能连接Win10问题

    从微软商店上下载Itunes 只要这个Itunes能识别Iphone,HbuilderX也可以识别Iphone 如果之前已经装了其他来源下载的Iphone,先卸载掉,然后重启系统安装 另外: 还有一种 ...

  7. 【Hibernate】01 概述

    什么是Hibernate? - Hibernate是我们JavaEE开发中的DAO层框架 - DAO[Data Access Object] 数据访问对象层 - 在DAO层,访问数据库,进行CRUD操 ...

  8. 【Tomcat】IDEA工程没有EE规范的jar包?

    发现了一个问题,我安装了2种版本的Tomcat 一个是8版本,另一个是10版本 我在已经使用8版本的工程中,更换成使用10版本,当然一开始部署运行正常 但是关闭了工程之后,再次打开就发现,这些EE规范 ...

  9. 【Git】上传代码到码云

    教程来自于这个上面: https://www.jianshu.com/p/3e0b213ab03d 第一步:创建码云仓库 具体怎么点选这里不再演示了 第二步:创建本地文件夹 [这个目录用来做本地仓库, ...

  10. 【Lodop】02 C-Lodop手册阅读上手

    版本:4.0.6.2 一.概述 C-Lodop云打印是一款精巧快捷的云打印服务产品,以Lodop功能语句为基础,JS语句实现远程打印 移动设备+Wifi+普通打印机+集中打印 C-Lodop对客户端浏 ...