首页
学习
活动
专区
圈层
工具
发布

在 Laravel 应用中构建 GraphQL API

代码示例:产品列表和用户列表的 API 例子 昨天我们学习了 在 Visual Code 中搭建 Laravel 环境,现在我们来学习 Facebook 的 GraphQL 。...安装 Laravel 使用下面命令安装最新版本的 Laravel : # 在命令行中执行 composer global require "laravel/installer" laravel new...创建查询和定义 GraphQL 的类型 GraphQL 中的查询与 Restful API 中的末端路径查询是一样的,查询只是用于获取数据,以及创建、更新、删除操作。...GraphQL 中的 类型 用于定义查询中每个字段的类型定义,类型会帮助我们格式化查询结果中的有格式的字段,例如布尔类型,字符串类型,浮点类型,整数类型等等,以及我们的自定义类型。...,我们需要编辑 config/graphql.php 文件,将查询语句和类型注册到 Schema 中。

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

    GraphQL 在微服务架构中的实践

    这篇文章中,首先会简单介绍 GraphQL 是什么,它能够解决的问题;在这之后,我们会重点分析 GraphQL 在微服务架构中的使用以及在实践过程中遇到的棘手问题,在最后作者将给出心中合理的 GraphQL...Schema Stitching 的过程中,最重要的方法其实就是 mergeSchemas,它总共接受三个参数,需要粘合的 Schema 数组、多个 Resolver 以及类型出现冲突时的回调: mergeSchemas...架构的演进 从今年年初选择使用 GraphQL 作为服务对外暴露的 API 到现在大概有半年的事件,服务的架构也在不断演进和改变,在这个过程中确实经历了非常多的问题,也一次一次地对现有的服务架构进行调整...这篇文章中,首先会简单介绍 GraphQL 是什么,它能够解决的问题;在这之后,我们会重点分析 GraphQL 在微服务架构中的使用以及在实践过程中遇到的棘手问题,在最后作者将给出心中合理的 GraphQL...Schema Stitching 的过程中,最重要的方法其实就是 mergeSchemas,它总共接受三个参数,需要粘合的 Schema 数组、多个 Resolver 以及类型出现冲突时的回调: mergeSchemas

    3.3K20

    GraphQL 在微服务架构中的实践

    这篇文章中,首先会简单介绍 GraphQL 是什么,它能够解决的问题;在这之后,我们会重点分析 GraphQL 在微服务架构中的使用以及在实践过程中遇到的棘手问题,在最后作者将给出心中合理的 GraphQL...Schema 中绝大多数的类型都是普通的对象类型,但是每一个 Schema 中都有两个特殊类型:query 和 mutation,它们是 GraphQL 中所有查询的入口,在使用时所有查询接口都是 query...Faction 和 Ship 两个类型都拥有唯一标识符 id 字段,我们可以通过该标识符重新从服务端取回对应的对象,Node 接口和字段在默认情况下会假定整个服务中的所有资源的 id 都是不同的,但是很多时候我们都会将类型和...在整个 Schema Stitching 的过程中,最重要的方法其实就是 mergeSchemas,它总共接受三个参数,需要粘合的 Schema 数组、多个 Resolver 以及类型出现冲突时的回调:...架构的演进 从今年年初选择使用 GraphQL 作为服务对外暴露的 API 到现在大概有半年的事件,服务的架构也在不断演进和改变,在这个过程中确实经历了非常多的问题,也一次一次地对现有的服务架构进行调整

    2K10

    Apollo在基础架构中的实践经验

    Config Service 和 Admin Service 都是多实例、无状态部署,所以需要将自己注册到 Eureka 中并保持心跳 在 Eureka 之上我们架了一层 Meta Server 用于封装...Portal 侧会做 load balance、错误重试 为了简化部署,我们实际上会把 Config Service、Eureka 和 Meta Server 三个逻辑角色部署在同一个 JVM 进程中。...客户端从Apollo配置中心服务端获取到应用的最新配置后,会保存在内存中 客户端会把从服务端获取到的配置在本地文件系统缓存一份 在遇到服务不可用,或网络不通的时候,依然能从本地恢复配置 应用程序从Apollo...客户端获取最新的配置、订阅配置更新通知 长连接实现上是使用的异步+轮询实现 4 Apollo 高可用部署 在 Apollo 架构说明中我们提到过 client 和 portal 都是在客户端负载均衡,根据...同时关闭 apollo 远程获取配置,在 VM options 中增加 -Denv=local。 ?

    1.9K10

    Apollo在基础架构中的实践经验

    Config Service 和 Admin Service 都是多实例、无状态部署,所以需要将自己注册到 Eureka 中并保持心跳 在 Eureka 之上我们架了一层 Meta Server 用于封装...Portal 侧会做 load balance、错误重试 为了简化部署,我们实际上会把 Config Service、Eureka 和 Meta Server 三个逻辑角色部署在同一个 JVM 进程中。...客户端从Apollo配置中心服务端获取到应用的最新配置后,会保存在内存中 客户端会把从服务端获取到的配置在本地文件系统缓存一份 在遇到服务不可用,或网络不通的时候,依然能从本地恢复配置 应用程序从Apollo...客户端获取最新的配置、订阅配置更新通知 长连接实现上是使用的异步+轮询实现 4 Apollo 高可用部署 在 Apollo 架构说明中我们提到过 client 和 portal 都是在客户端负载均衡,根据...同时关闭 apollo 远程获取配置,在 VM options 中增加 -Denv=local。 ?

    1.6K10

    LeetCode-303-区域和检索-数组不可变

    # LeetCode-303-区域和检索-数组不可变 给定一个整数数组 nums,求出数组从索引 i 到 j (i ≤ j) 范围内元素的总和,包含 i, j 两点。...# 解题思路 方法1、DP暴力破解: 显然这个方法可以用一维DP解决 状态:dp[in]代表从i开始到当前位置的元素和 状态转移方程: 当是第一个元素时,直接赋值 当是元素i,且i!...=0时,dp[i]由dp[i-1]个元素和决定 需要一个dp数组指针in,线性遍历一次数组,dp数组的最后位置就是元素和 这个方法勉强能通过,但是每次调用都要计算[i,j]范围的和,速度很慢 方法2、缓存...: 提前计算出所有范围的累和,能不能计算出第i个元素的和 sum[k]定义为nums[0...k-1]的累和,sum[0]=0 对于上述示例数组sum数组为[0,-2,-2,1,-4,-2,-3] sumrange...(i,j)=sum[j+1]-sum[i],也就是把后面部分的和前去并集部分即可 这种方法只需要计算一次和,之后仅需要从数组取值相减即可得到结果 # Java代码 class NumArray {

    30210

    GraphQL在现代Web应用中的应用与优势

    前端设置(使用Apollo Client)接着,我们需要在前端应用中配置Apollo Client,与我们的GraphQL服务器通信:npm install apollo-boost @apollo/client...查询语言:查询、突变、订阅在GraphQL中,查询和突变是通过JSON-like结构表示的字符串。...查询结构:字段和参数查询结构由字段和参数组成。在上面的查询示例中,user是字段,id和email是user字段的子字段。参数如id: 1用于定制查询。4....这就是GraphQL查询、类型系统和层次结构在实际应用中的体现。...: Post}在Query类型中,我们定义了获取单个用户、所有用户、单篇帖子和所有帖子的查询。而在Mutation类型中,我们定义了创建新用户和新帖子的操作。

    1.4K10
    领券