后端开发工程师-API设计与开发-GraphQL_GraphQL简介与基本概念.docx

后端开发工程师-API设计与开发-GraphQL_GraphQL简介与基本概念.docx

  1. 1、本文档共25页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多

PAGE1

PAGE1

GraphQL的起源与发展

GraphQL,一种用于API的查询语言,由Facebook在2012年内部开发,于2015年正式开源。它的设计初衷是为了更高效、更灵活地获取数据,解决传统RESTfulAPI在数据获取上的局限性。在Facebook内部,GraphQL被用于驱动Instagram、FacebookMessenger等应用,其高效的数据获取能力得到了充分的验证。

1起源

在Facebook内部,开发团队面临着一个共同的问题:不同的前端应用需要从后端获取的数据各不相同,而传统的RESTfulAPI往往只能提供固定的数据结构,这导致了前端应用需要多次请求才能获取所需的所有数据,或者获取了大量不需要的数据,增加了网络负担。为了解决这个问题,Facebook的工程师们设计了GraphQL,它允许前端应用精确地指定需要的数据,从而减少了网络传输的数据量,提高了数据获取的效率。

2发展

自2015年开源以来,GraphQL迅速获得了广泛的关注和应用。它不仅被Facebook及其相关产品使用,也被许多其他公司和项目采纳,包括GitHub、Shopify、Netflix等。随着GraphQL的流行,围绕它的生态系统也逐渐成熟,包括各种语言的实现、工具、框架等,使得GraphQL的使用更加方便和广泛。

1GraphQL与RESTful的比较

在API设计领域,RESTful和GraphQL是两种常见的数据获取方式。RESTfulAPI基于HTTP协议,通过URL来定位和操作资源,而GraphQL则提供了一种更灵活、更高效的数据获取方式。

1.1数据获取方式

1.1.1RESTful

在RESTfulAPI中,数据获取通常需要通过多个HTTP请求来完成。例如,如果一个应用需要获取用户信息、用户的朋友列表和用户的帖子,可能需要发送三个不同的GET请求,分别指向/users/{userId}、/users/{userId}/friends和/users/{userId}/posts。

#Python示例代码

importrequests

#获取用户信息

user_response=requests.get(f/users/{user_id})

user_data=user_response.json()

#获取用户的朋友列表

friends_response=requests.get(f/users/{user_id}/friends)

friends_data=friends_response.json()

#获取用户的帖子

posts_response=requests.get(f/users/{user_id}/posts)

posts_data=posts_response.json()

1.1.2GraphQL

相比之下,GraphQL允许在单个请求中获取多个资源。使用GraphQL,上述三个请求可以合并为一个请求,通过定义查询来精确指定需要的数据。

#GraphQL查询示例

query{

user(id:123){

name

friends{

id

name

}

posts{

id

title

content

}

}

}

1.2数据结构

1.2.1RESTful

RESTfulAPI返回的数据结构通常是固定的,与请求的资源相关。这意味着,如果应用只需要用户的一部分信息,仍然需要接收整个用户资源的数据。

1.2.2GraphQL

GraphQL则允许应用指定返回的数据结构。在上述查询中,我们只请求了用户的名字、朋友的ID和名字、以及帖子的ID、标题和内容,GraphQL服务器将只返回这些数据,而不会包含任何额外的信息。

1.3总结

GraphQL与RESTfulAPI相比,提供了更灵活、更高效的数据获取方式。它允许在单个请求中获取多个资源,并且可以精确指定需要的数据结构,从而减少了网络传输的数据量,提高了数据获取的效率。然而,RESTfulAPI在某些场景下,如简单的数据获取和更新,仍然具有其优势。选择哪种方式,需要根据具体的应用场景和需求来决定。#GraphQL的基本语法

1.4查询(Query)的使用

GraphQL的查询是用于从服务器获取数据的主要方式。查询使用一个简单的语法,允许客户端精确地指定它需要的数据。下面是一个查询的例子:

{

user(id:1){

name

email

friends{

id

name

}

您可能关注的文档

文档评论(0)

kkzhujl + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档