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

Laravel 应用构建 GraphQL API

代码示例:产品列表和用户列表的 API 例子 昨天我们学习了 Visual Code 搭建 Laravel 环境,现在我们来学习 Facebook 的 GraphQL 。...GraphQL 是一种 API 查询语言,还是一种根据你为数据定义的类型系统执行查询的服务器端运行时。GraphQL 不依赖于任何指定的数据库或存储引擎,而是由你的代码和数据来作支持的。...安装 Laravel 使用下面命令安装最新版本的 Laravel : # 命令行执行 composer global require "laravel/installer" laravel new...创建查询和定义 GraphQL 的类型 GraphQL 的查询与 Restful API 的末端路径查询是一样的,查询只是用于获取数据,以及创建、更新、删除操作。...GraphQL 的 类型 用于定义查询每个字段的类型定义,类型会帮助我们格式化查询结果的有格式的字段,例如布尔类型,字符串类型,浮点类型,整数类型等等,以及我们的自定义类型。

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

GraphQL 名词 101:解析 GraphQL 的查询语法》【译】

在你的查询,对根节点字段的处理和最底层字段应该是一样的。 参数(Arguments):一组与特定字段关联的键值对。这些参数会跟它们相关的字段一起被传递到服务器端执行,并影响服务器对字段的处理方式。...这样,无论你是在网络日志或者GraphQL服务器上发现错误,你都可以通过名字很轻松的代码库定位问题,而不是靠猜测(类似的工具有 Apollo Optics)。...变量定义(Variable definitions):当客户端向GraphQL服务器发送查询时,会存在查询文档不变,当某些字段会动态变化的情况。这些就是查询的变量。...变量使用特定的序列化协议(目前的 GraphQL 服务实现,通常是使用JSON )通过查询文档独立传输。...指令(Directive): 字段、片段或者查询的一个注释,include 指令表示只有 if 参数为 true 时才引入片段表示的字段。

2.8K20

GraphQL 微服务架构的实践

这篇文章,首先会简单介绍 GraphQL 是什么,它能够解决的问题;在这之后,我们会重点分析 GraphQL 微服务架构的使用以及实践过程遇到的棘手问题,最后作者将给出心中合理的 GraphQL...和 mutation,它们是 GraphQL 中所有查询的入口,使用时所有查询接口都是 query 的子字段,所有改变服务器资源的请求都应该属于 mutation 类型。...GraphQL Schema Stitching 其实已经是一套包含路由系统的 GraphQL 微服务架构的解决方案了,它能够在网关服务器 Resolve 请求时,通过 HTTP 协议将对应请求的片段交由其他微服务进行处理...和 mutation,它们是 GraphQL 中所有查询的入口,使用时所有查询接口都是 query 的子字段,所有改变服务器资源的请求都应该属于 mutation 类型。...GraphQL Schema Stitching 其实已经是一套包含路由系统的 GraphQL 微服务架构的解决方案了,它能够在网关服务器 Resolve 请求时,通过 HTTP 协议将对应请求的片段交由其他微服务进行处理

2.6K20

GraphQL 微服务架构的实践

这篇文章,首先会简单介绍 GraphQL 是什么,它能够解决的问题;在这之后,我们会重点分析 GraphQL 微服务架构的使用以及实践过程遇到的棘手问题,最后作者将给出心中合理的 GraphQL...GraphQL 这种方式能够将原有 RESTful 风格时的多次请求聚合成一次请求,不仅能够减少多次请求带来的延迟,还能够降低服务器压力,加快前端的渲染速度。...的子字段,所有改变服务器资源的请求都应该属于 mutation 类型。...id 绑定到一起,组合后才能一个类型特定的 ID;为了保证 id 的不透明性,返回的 id 往往都是 Base64 编码的字符串,GraphQL 服务器接收到对应 id 时进行解码就可以得到相关的信息...GraphQL Schema Stitching 其实已经是一套包含路由系统的 GraphQL 微服务架构的解决方案了,它能够在网关服务器 Resolve 请求时,通过 HTTP 协议将对应请求的片段交由其他微服务进行处理

1.5K10

docker部署Apollo配置中心,rancher中部署并使用

Apollo配置中心是携程开源的知名配置中心项目,类似的有disconf等,它的GitHub地址是:https://github.com/ctripcorp/apollo 由于我们主要使用docker...(rancher)来运维管理项目,所以Apollo也要部署到docker里,来做为SpringCloud的配置中心。...rancher里的配置如下: ? ? 环境变量里配置好Portal的数据库地址和Config的数据库地址。Portal默认端口是8070. ? 需要注意的地方是eureka。...Apollo是依赖于eureka注册中心的。 假定你已经rancher里部署过了eureka了,那么就添加一下eureka的服务链接,然后config数据库里修改一下eureka的地址就可以了。...eureka里就可以看到Apollo注册成功的信息。 ? 如果你做了和宿主机器的端口映射的话,就可以访问了,注意内部端口是8070。初始账号密码apollo,admin,进去后就是这样的界面 ?

1.6K20

写在 2021: 值得关注学习的前端框架和工具库

你可能同样犹豫要不要学这玩意,我的意见是:学!因为确实NodeJS目前没有特别全面的框架(虽然NestJSSpring面前也是弟弟)。...TS这个工具的主要能力就是生成TS的类型定义,同时它的插件体系还提供了更多的额外能力,如Apollo-Client的插件,让你可以直接使用封装好的的useXXXQuery等,前端连查询语句都不用写了...,提供了一堆让你对GraphQL Schema为所欲为的方法,从Directive到Resolver到Schema,都给你安排的明明白白。...Parcel[57],最大的亮点是零配置,我一些中小型项目使用过,很适合中小型规模以及只是想跑一下demo的场景,速度也挺快。...,Apollo的useQuery接收的是GraphQL Document,BlitzJS的则接收的是后端方法,其中会直接db.entity.create()这样去写数据库)。

4.2K10

用ServBay快速构建下一代GraphQL应用

我们深入构建微服务的过程之前,了解 GraphQL 在此架构的作用非常重要。什么是GraphQL?...主要功能包括声明式数据获取:使用 GraphQL,客户端可以查询精确指定所需的数据,包括字段和关系。这消除了传统 REST API 经常出现的数据过度获取和获取不足的问题。...高效的类型系统: GraphQL 拥有强大的类型系统,可以 API 定义数据的结构和关系。高效的数据加载功能: GraphQL 使客户端能够单个请求检索多个资源。...如何构建GraphQL微服务构建GraphQL微服务时,我们将遵循以下步骤:第1步:使用ServBay设置环境不同于传统的手动安装Node.js,ServBay提供了预配置的环境,包括各个版本的Node.js...Node.js安装部署指南第2步:初始化Apollo服务器Apollo Server是一个开源的、与GraphQL规范兼容的服务器,它简化了GraphQL API的构建。

11300

写在2021: 值得关注学习的前端框架和工具库

你可能同样犹豫要不要学这玩意,我的意见是:学! 因为确实NodeJS目前没有特别全面的框架(虽然NestJSSpring面前也是弟弟)。...TS这个工具的主要能力就是生成TS的类型定义,同时它的插件体系还提供了更多的额外能力,如Apollo-Client的插件,让你可以直接使用封装好的的useXXXQuery等,前端连查询语句都不用写了...Schema为所欲为的方法,从Directive到Resolver到Schema,都给你安排的明明白白。...Parcel,最大的亮点是零配置,我一些中小型项目使用过,很适合中小型规模以及只是想跑一下demo的场景,速度也挺快。...Reactive.How,生动的展示RxJS Observable操作符管道的流动,入门期间使用有奇效。

2.8K10

Apollo基础架构的实践经验

客户端从Apollo配置中心服务端获取到应用的最新配置后,会保存在内存 客户端会把从服务端获取到的配置本地文件系统缓存一份 遇到服务不可用,或网络不通的时候,依然能从本地恢复配置 应用程序从Apollo...客户端获取最新的配置、订阅配置更新通知 长连接实现上是使用的异步+轮询实现 4 Apollo 高可用部署 Apollo 架构说明我们提到过 client 和 portal 都是客户端负载均衡,根据...同时关闭 apollo 远程获取配置 VM options 增加 -Denv=local。 ?...默认配置文件取 app.id 的值,调整优先级 spring.application.name 之前 * * @return apollo app id */ private...编辑权限允许用户 Apollo 界面上创建、修改、删除配置 配置修改后只 Apollo 界面上变化,不会影响到应用实际使用的配置 发布权限允许用户 Apollo 界面上发布、回滚配置 配置只有发布

1.6K10

GraphQL最突出的架构优势是什么?

作者 | Khalil Stemmler 策划 | 田晓旭 服务器上使用 GraphQL 代替 REST 是有很多好处的,使用 Apollo Client 取代自己编写的数据获取逻辑也有很多优势。...GraphQL API 的配置工作包括: 安装 GraphQL 公开一个服务器端点 设计一个模式(schema) 将解析器连接到数据源 这是我们需要做的工作,但不是我们项目的工作重心。...数据图从客户端延伸到服务器,并为现代 Web 应用程序获取数据和更改状态时面临的最常见基础架构问题提供了答案 为了通过 GraphQL 与后端服务通信,Apollo Client 公开了几种客户端方法...通过 Apollo Federation,我们可以绘制并公开由多个 GraphQL 端点组成的单个数据图 Federation ,你可以组成模式并解析其他服务 / 限界上下文中的字段。...10总结 现代 Web 应用程序架构GraphQL 和 RESTfulWeb 服务器都是基础架构组件。 基础架构组件是基本组件,它们构成了我们编写的特定领域 Web 应用程序的基础。

2.1K20

Apollo基础架构的实践经验

客户端从Apollo配置中心服务端获取到应用的最新配置后,会保存在内存 客户端会把从服务端获取到的配置本地文件系统缓存一份 遇到服务不可用,或网络不通的时候,依然能从本地恢复配置 应用程序从Apollo...客户端获取最新的配置、订阅配置更新通知 长连接实现上是使用的异步+轮询实现 4 Apollo 高可用部署 Apollo 架构说明我们提到过 client 和 portal 都是客户端负载均衡,根据...同时关闭 apollo 远程获取配置 VM options 增加 -Denv=local。 ?...默认配置文件取 app.id 的值,调整优先级 spring.application.name 之前 * * @return apollo app id */ private...编辑权限允许用户 Apollo 界面上创建、修改、删除配置 配置修改后只 Apollo 界面上变化,不会影响到应用实际使用的配置 发布权限允许用户 Apollo 界面上发布、回滚配置 配置只有发布

1.3K10

怎样使用 apollo-link-state 管理本地数据

此外,GraphQL 有能力将对多个数据源的请求集成单次查询,在此我们将充分利用这个特性。 . 以上是 Apollo Client 的数据流架构图。...Apollo Client 的状态管理 Apollo Link 是 Apollo 的模块化网络栈,可以用于某个 GraphQL 请求的生命周期的任意阶段插入钩子代码。...Apollo Link 使得 Apollo Client 管理本地的数据成为可能,从一个 GraphQL 服务器获取数据,可以使用 HttpLink,而从 Apollo 的缓存请求数据,则需要使用一个新的...如果你以前服务器端使用过 graphql-tools,那么你会发现两者的 resolver 的类型签名是一样的。 ....在下面的例子,我们同一条 query 内查询了 GraphQL 服务器存储的 user 数据以及 Apollo cache 的 visibilityFilter 数据。 .

2.3K100

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

GraphQL 对你的 API 的数据提供了一套易于理解的完整描述,使得客户端能够准确地获得它需要的数据,而且 没有任何冗余。... graphql--save 引入express-graphql配置中间件 app完善配置 // app.js var express=require('express'); var DB=require...将它与vue-apollographql一起安装: npm install vue-apollo graphql apollo-boost --save src/main.js引入apollo-boost...控制台查看查询结果 src/main.js配置vue-apollo插件 import VueApollofrom'vue-apollo' Vue.use(VueApollo); 创建Apollo...:h=>h(App) }) 简单查询 组件加载的时候就会去服务器请求数据,请求的数据会放在navList这个属性上面,模板可以直接使用当前属性 简单查询文档 带参数查询参考 import gql from'graphql-tag

5.1K42

如何在 React.js 项目中使用 GraphQL

:npm install graphql @apollo/client@apollo/client 软件包是 Apollo Client,这是一个强大的库,用于 React 应用程序管理状态并进行...连接到 GraphQL 服务器要在 React.js 项目中使用 GraphQL,您需要连接到 GraphQL 服务器。...在这个例子,假设您有一个 http://localhost:4000/graphql 上运行的 GraphQL 服务器。您可以将此 URL 替换为实际的 GraphQL 服务器端点。...项目的 src 文件夹创建一个名为 client.js 的文件,并设置 Apollo Client:// src/client.jsimport { ApolloClient, InMemoryCache...: new InMemoryCache(),});export default client; React 组件中使用 GraphQL 获取数据现在,让我们使用 GraphQL React 组件获取数据

31440
领券