首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

干货 | 携程基于 GraphQL 的前端 BFF 服务开发实践

而 data 字段的类型不带 !,即可能为空。这就带来一个问题,code 为 1 表达存在错误时,data 也可能不为空。从类型上,并不能保证,code 为 1 时,data 一定为空。...由于非空类型的字段不能为空,字段错误被传播到父字段中处理。如果父字段可能是null,那么它就会解析为null,否则,如果它是一个非null类型,字段错误会进一步传播到它的父字段。...当 Grandchild 的 value 结果为 null 时,查询结果如下: 通过空值冒泡,Grandchild 的空值,被冒泡到 parent 节点,令 parent 的结果也为空。...这也是符合我们编写的 GraphQL Schema 的类型约束的。如果只有 Grandchild 的 value 为 null,反而不符合类型,因为该节点是带 ! 的非空类型。...,而根因是依赖的 API 返回错误。

2.6K20

C# 8.0 可空引用类型中的各项警告错误的含义和示例代码

C# 8.0 引入了可为空引用类型和不可为空引用类型。当你需要给你或者团队更严格的要求时,可能需要定义这部分的警告和错误级别。...C# 8.0 如何在项目中开启可空引用类型的支持 - 吕毅 C# 可空引用类型 NullableReferenceTypes 更强制的约束:将警告改为错误 WarningsAsErrors - 吕毅 警告和错误...GetText() { return null; } CS8609 返回类型中引用类型的为 Null 性与重写成员不匹配。...比如你的基类中返回值不允许为 null,但是实现中返回值却允许为 null。...CS8616 接口中定义的成员中的 null 性与实现中成员的 null 型不匹配。 具体来说,你的接口中不允许为 null,但是实现中却允许为 null。

87020
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    如何优雅地扩展GraphQL系统能力

    作者 | 杜艮魁 编辑 | 蔡芳芳 1 背景 为什么要扩展 GraphQL 系统能力 GraphQL 可将 API 表示的数据通过解析函数映射到 GraphQL 的 schema 中,为 API...例如为 App 渲染数据时,低于指定版本的客户端不用请求某些字段,该条件判断无法通过请求变量只有客户端版本号的原生查询实现。...2 GraphQL 系统能力扩展实践 本文以 GraphQL Calculator 为例,介绍对 GraphQL 系统能力进行扩展的实践。...,保留断言表达式predicate 结果为 true 的元素,predicate参数为所注解数组元素的字段名称与字段值的映射 Map。...校验指令使用 通过QueryVisitor实现自定义指令的校验规则,以校验@filter参数表达式不可为空为例,其实现核心代码如下: public class BasicRule implements

    1.3K20

    GraphQL 基础实践

    如果感叹号跟在 field 的后面,则表示返回该 type 的数据时,此字段一定不为空。 通过上面的类型定义,可以看到 GraphQL 中的类型系统起到了很重要的角色。...在本例中,Schema 定义了 name 为 String类型,那么你就不能传 Int类型进去,此时会抛出类型不符的错误。...需要注意的是[Movie]!与 [Movie!]两种写法的含义是不同的:前者表示 movies字段始终返回不可为空但Movie元素可以为空。...后者表示movies中返回的 Movie 元素不能为空,但 movies字段的返回是可以为空的。 你可能在请求体中注意到,genre 参数的值没有被双引号括起来,也不是任何内置类型。...字段得到的是一组 id,不符合 Schema 的定义,此时 GraphQL 会抛出错误。

    12.8K20

    GraphQL 的入门指南

    给 GraphQL API 添加字段和类型而无需影响现有查询,老旧字段可以废弃,从工具中隐藏。...例如,如果你正在构建一个社交媒体应用程序,那么你的 API 应该具有诸如文章、用户、赞、组等类型。 类型具有字段,这些字段返回特定类型的数据。...类型字段可以是任何类型,并始终返回一种数据类型,如 Int,Float,String,Boolean,ID,对象类型列表或自定义对象类型。...但是,在每一行的结尾的 !呢? 感叹号表示字段不可为空,这意味着每个字段必须在每个查询中返回一些数据。 User 中唯一可以为空的字段是 age。...它不会返回 null,因为我们放入了 ! ,这意味着它是一个不可为空的查询, 它总会返回一些数据。 但我们也可以返回特定用户。 为此,创建一个名为 user 的新查询。

    2K30

    C# 可为空引用类型

    不过,遗憾的是,对于可为空引用类型,我们“失败了”,将精力放在了错误的事情上,而不是正确的事情上。“失败”操作是指未检查是否为空就调用了引用类型。...不过,如果我们能够将一切推到重来,还是希望引用类型默认不可为空,并通过添加“?”显式允许为空。 无法运行静态流分析,进而也就无法检查所有路径是否有空值(若为空,取消引用它)。...目前的实际情况是,字符串 text; 会生成 text 引用类型,它不仅允许文本为空,还要求文本应为空,实际上文本在许多情况下(如在字段或数组中)都默认为空。...例如,如果某方法声明返回不可为空引用类型(可能是尚未使用为空性修饰符进行更新的库)或错误返回空值(可能是警告被忽略),或抛出非致命异常且未执行预期分配,那么不可为空引用类型最终仍可能会分配有空值。...最重要的是,这意味着,现有 API(如 .NET API)能够使用可为空元数据进行更新,而不破坏 API。此外,这还意味着,不支持根据为空性修饰符进行重载。

    19120

    Go GraphQL 教程

    返回JSON 格式的响应、状态码、或者错误信息 前端或者客户端,根据具体的需求,调用接口,对接口返回的字段进行处理。...看到没,这类的接口设计: 需要维护多类接口,需求不断变更,维护的接口越来越多 字段的获取,前端或者客户端不能决定,而是一股脑的返回,再由相应开发人员处理 需要考虑接口版本 ......是否不包含该字段、@deprecate 是否废弃该字段 内联片段:接口类型或者联合类型中获取下层字段 元字段 类型定义、对象定义 内置的类型:ID、Int、Float、String、Boolean,...表示非空 接口:interface 联合类型: | 通过对象类型组合而成 输入类型: 为解决传递复杂参数的问题 讲了这么些,其实最好的方式还是亲自调用下接口,参照着官方文档,按个调用尝试下,熟悉这套语法规范...请求名称:viewer 响应对象:User 非空,即一定会返回一个 User 对象,User 对象由一系列字段、对象组成 1.

    4.4K20

    为什么数据库字段要使用NOT NULL?

    来自高性能Mysql中有这样一段话: 尽量避免NULL 很多表都包含可为NULL(空值)的列,即使应用程序并不需要保存NULL也是如此,这是因为可为NULL是列的默认属性。...而言,如果不主动设置为NOT NULL的话,那么插入数据的时候默认值就是NULL。...NULL和NOT NULL使用的空值代表的含义是不一样,NULL可以认为这一列的值是未知的,空值则可以认为我们知道这个值,只不过他是空的而已。...而对于大多数程序的情况而言,没有什么特殊需要非要字段要NULL的吧,NULL值反而会对程序造成比如空指针的问题。...值计算 聚合函数不准确 对于NULL值的列,使用聚合函数的时候会忽略NULL值。 现在我们有一张表,name字段默认是NULL,此时对name进行count得出的结果是1,这个是错误的。

    1.9K20

    C# 8.0 的可空引用类型,不止是加个问号哦!你还有很多种不同的可空玩法

    C# 8.0 引入了可空引用类型,你可以通过 ? 为字段、属性、方法参数、返回值等添加是否可为 null 的特性。...也许你可以理解为有什么特性 Attribute 标记了字段、属性、方法参数、返回值的可空特性,于是可空特性就被编译到程序集中了。...更灵活控制的可空特性 阻碍你将老项目迁移到可空类型的原因,可能还有你原来代码逻辑的问题。因为有些情况下你无法完完全全将类型迁移到可空。...例如: 有些时候你不得不为非空的类型赋值为 null 或者获取可空类型时你能确保此时一定不为 null(待会儿我会解释到底是什么情况); 一个方法,可能这种情况下返回的是 null 那种情况下返回的是非...text) { } 然而这个方法的语义是确保此字段初始化。于是可以传入 null 但不会返回 null 的。

    1.5K20

    GraphQL+Koa2实现服务端API结合Apollo+Vue

    它弥补了 RESTful API(字段冗余,扩展性差、无法聚合 api、无法定义数据 类型、网络请求次数多)等不足 注意:GraphQL 是 api 的查询语言,而不是数据库。...比如:字段冗余,扩展性差、无法聚合 api、无法 定义数据类型、网络请求次数多 GraphQL 的出现整好弥补了 RESTful APi 的不足 使用 GraphQL 的公司 目前已经有很多的公司在使用...然而 REST api 表 现得过于僵化,无法跟上访问它们的客户的快速变化的需求 RESTful API 不足 扩展性(多个终端需要返回不同的字段),单个 RESTful 接口返回数据越来越 臃肿。...前端对于真正用到的字段是没有直观映像的,仅仅通过 url 地址,无法预测也无 法回忆返回的字段数目和字段是否有效,接口返回 50 个字段,但却只用 5 个字段,造 成字段冗余,扩展性差,单个 RESTful...可以用于必须保证值不能为null的字段。

    5.2K42

    安全地将 Netflix 迁移到 GraphQL

    我们不希望传统的 Falcor API 永远存在,因此我们采用了 Federated GraphQL 来支持一个具有多个 GraphQL 服务器的单一 GraphQL API。...我们知道我们可以使用相同的查询和相同的输入进行测试,并始终期望得到相同的结果。 对于请求非幂等字段的 GraphQL 查询或变更,我们无法进行 Replay 测试。...优势 高级健康指标:AB 测试为我们的整体客户端 GraphQL 实现提供了所需的保证。这帮助我们在 6 个月内成功将移动首页画布上 100% 的流量迁移到 GraphQL。...具有 @override 指令的相同字段的存在告知 GraphQL 网关将此字段的解析路由到新的 Video Service,而不是旧的 Shim Service。...手动构建的查询只能测试开发人员记得测试的功能。由于遗忘,我们最终会有一些未经测试的字段。 正确性:正确性的概念也可能令人困惑。例如,对于一个数组来说,空数组更正确还是 null 更正确,或者只是噪音?

    17030

    来试试Graphql

    下面对比一下 RESTful api 和 GraphQL 的优缺点。 优点: 声明式的接口获取 RESTful api 返回的字段冗余, 当多个终端共用接口时,尤其明显。...GraphQL 可精准的返回所需的数据结果,减少数据传输大小。 嵌套复杂数据仅需一次调用 RESTful 对于嵌套的复杂数据需要多次调用,而 GraphQL 只需要一次。...有以下三种做法: 新开一个接口, 返回所需要的所有字段 请求增加一个 type ,用于区分场景,服务端根据不同 type 返回不同的字段 不管三七二十一, 在原有接口上增加多的字段。...(不可为 null) 可通过 Union types 或 implements 扩展上面的类型。...resolver 的解析规则是, 从外到内依次处理查询块,为每一个查询块执行对应的 resolver 函数,并传递外层调用返回的结果作为第一个参数,也就是下面代码中的 obj 。

    2K20

    GraphQL(二):GraphQL服务搭建

    在GraphQL(一):GraphQL介绍中讲到目前已经有很多平台完成了GraphQL实现,这里以Java平台为例,介绍GraphQL服务的搭建。...对象),同时为我们屏蔽了graphql-java的底层细节,它本身依赖graphql-java。...): type Query{ # 根据学校Id查询学校,schoolId不能为空,返回的School不能为空 school(schoolId:String!)...实际上针对type中的每个Field都需要有getField,使得Graphql能够获取到数据注入到返回的结果中,如果针对此Field已经实现了Resolver,那么会优先使用Resolver来注入数据...insertTeacher引入了一个新类型TeacherInput,将需要传递到服务端的数据封装起来,GraphQL的返回类型(Teacher)和输入类型(TeacherInput)是不能共用的,所以加上

    1.2K30

    为什么我使用 GraphQL 而放弃 REST API?

    在一个有经验的团队中,你可以避免这些问题,但是你难道不希望一些问题已经在软件方面得到解决吗?...没有静态类型意味着要注意类型验证 无论如何努力避免这种情况,你迟早会遇到 JSON 属性拼写错误、发送或接收的数据类型错误、字段丢失等问题。...如果你的客户端和 / 或服务器编程语言是静态类型的,并且你不能用错误的字段名或类型构造对象,那可能没问题。...类型的字段allTodos(limit: Int, offset: Int): TodoList!接受两个可选参数,而其本身的值是非可选的,这意味着它将始终返回一个不能为空的TodoList实例。...请注意,allTodos字段的offset参数是缺失的。作为可选项,它的缺失意味着它有null值。如果服务器提供这种模式,文档中可能会声明,null偏移量意味着默认情况下应该返回第一页。

    2.3K30

    GraphQL 从入门到实践

    age: Int } 这个 User 对象类型有两个字段,name 字段是一个为 String 的非空标量,age 字段为一个 Int 的可空标量。...它定义了字段的类型、数据的结构,描述了接口数据请求的规则,当我们进行一些错误的查询的时候 GraphQL 引擎会负责告诉我们哪里有问题,和详细的错误信息,对开发调试十分友好。...} } Hello world 总是如此愉快,下面我们来进行稍微复杂一点的查询 查询入口 users 查找所有用户列表,返回一个不可空但长度可以为 0 的数组,数组中如果有元素,则必须为 User 类型...;另一个查询入口 user 接受一个字符串,查找 ID 为这个字符串的用户,并返回一个 User 类型的可空字段 # src/schema.graphql # Query 入口 type Query...---- 网上的帖子大多深浅不一,甚至有些前后矛盾,在下的文章都是学习过程中的总结,如果发现错误,欢迎留言指出~ 参考: GraphQL | 一种为你的 API 而生的查询语言 JSON-RPC

    2.5K31

    GraphQL 中的权限与认证:一分钟浅谈

    在GraphQL中实现认证通常涉及以下几个步骤: 生成Token:当用户登录成功后,服务器生成一个JWT或其他类型的token,并将其返回给客户端。...如何在GraphQL中实现授权? 授权通常涉及检查用户的角色或权限,以确定其是否有权执行特定的操作。在GraphQL中,可以通过中间件或自定义字段解析器来实现授权。...常见易错点及如何避免 易错点1:未正确配置Token验证 错误表现:即使提供了无效的token,服务器仍然允许访问受保护的资源。...避免方法:确保在每个请求中都验证token的有效性,并在验证失败时返回适当的错误响应。 易错点2:未正确处理跨域请求 错误表现:前端应用无法从不同的域名请求GraphQL API。...避免方法:在每个受保护的字段或查询中明确指定授权逻辑,并确保在执行操作之前进行授权检查。 结论 GraphQL中的权限与认证是确保应用安全的关键部分。

    9510
    领券