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

GraphQL 初体验,Node.js 构建 GraphQL API 指南

另一部分涉及实际获取数据,这是通过使用解析器完成的,解析器是一个返回字段基础值的函数。 让我们看一下如何在 Node.js 中实现解析器。...GraphQL 解析器相当于一个 Object,key 是要检索的字段名,value 是返回数据的函数。...} } } 这个解析器需要两个参数:一个代表父的对象(在最初的根查询中,这个对象通常是未使用的),一个包含传递给你的字段的参数的 JSON 对象。...只需要 Schema 表达几行清晰的代码,就可以在客户端和服务端之间建立强类型的契约,这样可以防止你的服务接受虚假数据,并向请求着清晰地表明错误。...,只是为了检索两个不同的列,会导致两个数据库查询来获取 ID 为 1 的 User。

8.3K40

与我一起学习微服务架构设计模式8—外部API模式

它可以由三部分组成: GraphQL模式:定义服务器端数据模型及其支持的查询 解析器函数:解析函数将模式的元素映射到各种后端服务。 代理类:代理类调用应用程序的服务。...简单情况下,查询文档包含查询的名称,参数值及要返回结果的对象字段。 把模式连接到数据源 当GraphQL服务器执行查询时,必须从一个或多个数据存储中检索所请求的数据。...通过将解析函数附加到模式定义的对象类型字段,可以将GraphQL模式与数据源相关联。GraphQL通过调用解析器函数检索数据,以此实现API组合模式。...GraphQL通过递归调用Query文档中指定的字段解析器函数来执行查询。首先,它执行查询解析器,然后递归调用结果对象层次结构中字段的解析器。...缓存会利用先前获取的同一对象结果,以避免不必要的重复调用。 为了让客户端调用GraphQL,你需要将它与Web框架集成,如Express Web

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

    一种不错的 BFF Microservice GraphQLREST API 层的开发方式

    客户端 API 当我们构建基于 GraphQL 的服务器时,可能需要从其他下游基于 GraphQL 的 API 服务器获取数据。...Mocks 作为 TDD 的一部分,我们可能需要模拟 graphql 响应,直到我们能够实现解析器为止 该基础结构设置为仅为当前未实现的解析器添加模拟。...因此,一旦实现可用,实际的解析器就会接手。同样,如果解析器执行失败,那么这将落在模拟响应上。此功能只能在开发期间使用,因此已添加检查以禁用“生产”版本中的此功能。...当前添加了一个使用 @date 指令的示例(如 graphql-tools 文档中所述) Query ({ today(format: "mmm-dd-yy") }) - 这里的格式基于@date scheme...此处的区别在于,我们使用 @auth 指令根据角色来处理身份验证,而不是对解析程序中的实现进行硬编码。这是更清蒸的方法,并且与解析器分离。

    2.4K10

    【GraphQL】225-GraphQL真香入门教程

    GraphQL 对你的 API 中的数据提供了一套易于理解的完整描述,使得客户端能够准确地获得它需要的数据,而且没有任何冗余,也让 API 更容易地随着时间推移而演进,还能用于构建强大的开发者工具。...特点 请求你所要的数据,不多不少; 如: hero 中有 name, age, sex 等,可以只取得需要的字段。...客户端 这一节我们学习如何在客户端中访问 graphql 的接口。...在 express 中,可以很简单的使用中间件来将请求进行拦截,将没有权限的请求过滤并返回错误提示。 中间件实际上是一个函数,在接口执行之前,先拦截请求,再决定我们是否接着往下走,还是返回错误提示。...就是这里要学习使用的构造函数 graphql.GraphQLObjectType 定义,它有这么几个优点和缺点: 优点:报错提醒更直观,结构更清晰,更便于维护。 缺点:代码量上升。 1.

    8.1K21

    GraphQL真香入门教程

    GraphQL 对你的 API 中的数据提供了一套易于理解的完整描述,使得客户端能够准确地获得它需要的数据,而且没有任何冗余,也让 API 更容易地随着时间推移而演进,还能用于构建强大的开发者工具。...特点 请求你所要的数据,不多不少; 如: hero 中有 name, age, sex 等,可以只取得需要的字段。...客户端 这一节我们学习如何在客户端中访问 graphql 的接口。...在 express 中,可以很简单的使用中间件来将请求进行拦截,将没有权限的请求过滤并返回错误提示。 中间件实际上是一个函数,在接口执行之前,先拦截请求,再决定我们是否接着往下走,还是返回错误提示。...就是这里要学习使用的构造函数 graphql.GraphQLObjectType 定义,它有这么几个优点和缺点: 优点:报错提醒更直观,结构更清晰,更便于维护。 缺点:代码量上升。 1.

    7.3K30

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

    引言 随着现代Web应用的发展,GraphQL逐渐成为一种强大的API查询语言,它允许客户端精确地请求所需的数据,从而减少不必要的数据传输。...在GraphQL中,授权通常基于角色或策略来实现。 常见问题 1. 如何在GraphQL中实现认证?...代码案例 以下是一个简单的示例,展示如何在GraphQL中实现JWT认证: using System; using System.IdentityModel.Tokens.Jwt; using System.Security.Claims...如何在GraphQL中实现授权? 授权通常涉及检查用户的角色或权限,以确定其是否有权执行特定的操作。在GraphQL中,可以通过中间件或自定义字段解析器来实现授权。...代码案例 以下是一个简单的示例,展示如何在GraphQL中实现基于角色的授权: using GraphQL; using GraphQL.Types; using Microsoft.AspNetCore.Http

    9510

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

    引言随着现代Web应用的发展,GraphQL逐渐成为一种强大的API查询语言,它允许客户端精确地请求所需的数据,从而减少不必要的数据传输。然而,随着GraphQL的流行,权限管理和认证也变得尤为重要。...如何在GraphQL中实现认证?在GraphQL中实现认证通常涉及以下几个步骤:生成Token:当用户登录成功后,服务器生成一个JWT或其他类型的token,并将其返回给客户端。...代码案例以下是一个简单的示例,展示如何在GraphQL中实现JWT认证:using System;using System.IdentityModel.Tokens.Jwt;using System.Security.Claims...如何在GraphQL中实现授权?授权通常涉及检查用户的角色或权限,以确定其是否有权执行特定的操作。在GraphQL中,可以通过中间件或自定义字段解析器来实现授权。...代码案例以下是一个简单的示例,展示如何在GraphQL中实现基于角色的授权:using GraphQL;using GraphQL.Types;using Microsoft.AspNetCore.Http

    11710

    【译】如何在 Node.js 中创建安全的 GraphQL API

    原文地址:How to Create a Secure Node.js GraphQL API 作者:Marcos 本文的目的是提供一份快速指南 -- 《如何快速在如何在 Node.js 中创建安全的...简而言之,它基于两部分: GraphQL Queries(查询):允许客户端进行读取和操作,并可以指定数据的接收格式 GraphQL Mutations(变更):向服务端写入数据,可以约定数据的写入方式...所以当两者通过 API 的形式来进行通信时,其他项目也可以使用同样的方式来工作。 如果你在一个大团队中工作,可以将它拆分成前端和后端两个团队,这样他们就可以使用相同的技术栈来工作从而提高效率。...本文的所有示例可以在这个链接中获得:https://github.com/makinhs/node-graphql-tutorial 我们将会处理两种类型的资源(两个集合): Users:用来展示如何进行基本的...(查询):我们要从服务器获取的内容 Mutations(变更):请求将会改变服务器中的数据 现在,我们重新执行一下 npm start,我们可以看到在控制台中显示了以下消息:Node Graphql API

    2.5K20

    Salesforce 构建可扩展 API 的旅程

    鉴于以下的原因,GraphQL 是最合适的方案: GraphQL 是数据库无关的技术,能够从任何地方为我们预先定义的业务领域提供数据。...GraphLQ 支持内省(introspection),所以模式定义可以通过各种工具进行共享和下载,如 GraphiQL、GraphQL-playground 或 cli 工具。...简单来讲,解析器就是由开发人员提供的一个函数,用来解析模式中定义的每个字段并从配置的资源(如数据库、其他 API 或缓存等)中返回值。...该字段的解析器函数很可能会访问一个数据库,并构造和返回 ClassificationInsightByUser 对象的一个列表。...执行查询 // 它将会调用解析器来获取数据并且只返回请求的数据 val executionResult = graphQL.execute(executionInput) // 发送响应

    1K10

    graphql+koa2 前端bff层

    promise.all,graphql可以更加便利的一次请求多个数据) (利于服务同学)他们可以专心开发微服务,不用再去管数据聚合这类事情 需要预定义类型,开发之前我们就能知道数据结构的基本样子 我们团队的后端使用的是...写了这两个配置之后,带有两个关键字的请求都讲代理到本地node服务的8080端口。接下来配置node中间层。 前端中间服务层的配置 中间服务层使用koa2搭建,当然你也可以使用express等等其他。...Query是graphql中的顶层类型,除开Query我们常用的还有Mutation。...那么这里定义了类型实现在哪里,实现就在resolvers中,每个类型定义在resolver中都必须有解析器一一对应。...在解析器中,他们的数据来源可以是任何地方,有可能是数据库,也可能是其他接口。我们这里是做中间层转发。所以直接使用axios转发到后端了。那么类型定义的参数就在这里获取使用。

    14610

    基于React和GraphQL的黛梦设计与实现

    后端这块是Node结合express和GraphQL做的接口,数据库用的是MySQL。 GraphQL的接口设计 我们先抛开GraphQL,就单纯的接口而言。...Mock数据库的实现 第一步:导包 const express = require('express'); const { buildSchema } = require('graphql'); const...graphqlHTTP用来将相应的实现以中间件的形式注入到express中。...在React中,我们可以通过Class和Function的方式创建组件,前者通过Class创建的组件,具有相应的生命周期函数,而且有相应的state, 而后者通过Function创建的更多的是做展示用...React Hooks的钩子, useState使得函数组件可以像Class组件一样可以使用state, useEffect它接受两个参数,第一个是函数,第二个是一个数组,数组中的元素的变化会触发这个钩子的函数的执行

    1.8K20

    干货 | 携程机票Node.js开发实践

    在机票H5实践前后端分离过程中,我们改进了技术架构,在前端的应用层,采用PM2+Node.js(8.9.4)+Express(4.0)框架,内部基于携程基础框架ctriputil,同时对一些常用功能的封装...,如Redis的调用,ABTest的获取,Qconfig的集成。...对于基础数据信息采用Localstore进行本地持久化存储,对于状态数据采用Sessionstore进行管理,确保状态在当次session中是有效的。...APP多的多,PC与APP在显示的信息上是有差异的,相同的契约数据下发对于某一端来说会存在浪费,从而加大网络开销, 在APP上也会存在着版本之间的差异,比如7.15的版本和7.16的版本,7.16上了一些新的功能...PM2+Node.js+Express+Express-GraphQL,选用Express-GraphQL作为核心中间件,统一客户端的请求入口为/graphql?

    1.4K20

    防止你的GraphQL API被恶意查询

    在这篇文章中,他描述了他们是如何在攻击中保护GraphQL API。 使用GraphQL,你可以随时查询想要的内容。 这对于使用API来说是惊人的,但也具有复杂的安全隐患。 ...虽然在其他应用层有一些缓解措施使在开始发送查询变得困难(如CORS),但它们无法完全防止发生。 大小限制 我们考虑的第一种天真的方法是通过原始字节来限制传入查询的大小。 ...不幸的是,它还有两个主要的折衷: 1、我们永远不能更改或删除查询,只能添加新的查询:如果任何用户运行过时的客户端,我们不能阻止他们的请求。 ...我们使用graphql-cost-analysis进行分析,因为我们最快的解析器(20μs)和最慢的解析器(10s +)之间存在很大差异,所以我们需要从中获得控制。 ...我通过Apollo Engine公开的性能跟踪数据确定了某些解析器的复杂程度。 我看了整个模式,并根据p99服务时间分配了一个值。

    1.9K10

    使用 React 和 GraphQL 做一个todo list

    GraphQL GraphQL 允许我们定义 一个查询来提供一个通用的接口在客户端和服务端之间来请求和处理数据。...介绍 GraphQL.js GraphQL.js 是一种基于js的GraphQL参考模型,它提供了两个重要的功能: 创建一种类型的语法模型(schema)。...query: queryType}); 让我们现在看一下给我们一个JSON数据结果的js文件的代码: var graphql = require ('graphql').graphqlvar express...一个值得注意的事是我们在所有的修改中传递参数,所以有的字段都 可接收参数。追加参数是相当简单,并且它们都可以被resolve函数捕获。...这个代码对比之前的版本有两个主要的变更。首先,服务端的TodoModel已经被修改了。 ? 第二,我们本地创建了一个服务端代理来直接使用GraphQL 请求我们创建的服务。

    2K130

    大厂都在实践的GraphQL,你了解吗?

    前言 最近,GraphQL 在构建后端 API 方面获得越来越多大公司的青睐, 如 PayPal、Facebook、Hasura、去哪儿等公司都做了大量实践。...它有助于减少传输的数据量。 这些只是其中的一些优势。今天本文将介绍如何在 springboot 项目中实践 GrapQL API....定义模型后,让我们将其放在资源目录中的文件夹 graphql 下,文件名为 schema.graphqls 。Spring 会自动读取扩展名为 *.graphqlss 的模型文件。...带有@QueryMapping注释的函数将成为查询的处理程序。 查询名称会自动映射到函数名称,或者使用 @QueryMapping接口的value参数(在本例中为person)显式定义它。...第一个操作创建一个人,只返回 id 和 name,因为我们只对这两个属性感兴趣。同样,创建地址接口返回地址的类型和街道。 现在,让我们查询刚刚存储的数据。

    2.6K40
    领券