{"id":55945,"date":"2023-01-02T08:56:17","date_gmt":"2023-01-02T11:56:17","guid":{"rendered":"https:\/\/kinsta.com\/pt\/?p=55945&#038;preview=true&#038;preview_id=55945"},"modified":"2025-01-31T11:25:06","modified_gmt":"2025-01-31T14:25:06","slug":"graphql-nodejs","status":"publish","type":"post","link":"https:\/\/kinsta.com\/pt\/blog\/graphql-nodejs\/","title":{"rendered":"Construindo APIs GraphQL com Node"},"content":{"rendered":"<p>GraphQL \u00e9 a nova palavra-chave no desenvolvimento de API. Enquanto as APIs RESTful continuam sendo a forma mais popular de expor dados de aplicativos, elas v\u00eam com muitas limita\u00e7\u00f5es que o GraphQL planeja resolver.<\/p>\n<p>GraphQL \u00e9 uma linguagem de consulta criada pelo Facebook, transformada em um projeto de c\u00f3digo aberto em 2015. Ele oferece uma sintaxe intuitiva e flex\u00edvel para descrever e acessar dados em uma API.<\/p>\n<p>Este guia ir\u00e1 explorar como construir um <a href=\"https:\/\/kinsta.com\/pt\/blog\/como-instalar-o-node-js\/\">projeto GraphQL Node.js<\/a>. Usaremos o GraphQL para construir um aplicativo Todo no <a href=\"https:\/\/kinsta.com\/pt\/blog\/o-que-e-express-js\/\">framework web do Express.js<\/a> para Node.<div><\/div><kinsta-auto-toc heading=\"Table of Contents\" exclude=\"last\" list-style=\"arrow\" selector=\"h2\" count-number=\"-1\"><\/kinsta-auto-toc><\/p>\n<h2>O que \u00e9 GraphQL?<\/h2>\n<p>A partir da <a href=\"https:\/\/graphql.org\/\">documenta\u00e7\u00e3o oficial<\/a>: &#8220;GraphQL \u00e9 uma linguagem de consulta para APIs e um tempo de execu\u00e7\u00e3o para preencher essas consultas com seus dados existentes. GraphQL fornece uma descri\u00e7\u00e3o completa e compreens\u00edvel dos dados em sua API, d\u00e1 aos clientes o poder de pedir exatamente o que eles precisam e nada mais, facilita a evolu\u00e7\u00e3o das APIs ao longo do tempo e permite poderosas ferramentas de desenvolvimento&#8221;<\/p>\n<p>GraphQL \u00e9 um tempo de execu\u00e7\u00e3o do lado do servidor para executar consultas usando o tipo de sistema que voc\u00ea definiu para seus dados. Al\u00e9m disso, o GraphQL n\u00e3o est\u00e1 ligado a nenhum banco de dados ou mecanismo de armazenamento espec\u00edfico. Ao inv\u00e9s disso, ele \u00e9 apoiado pelo seu c\u00f3digo e armazenamento de dados existentes. Voc\u00ea pode obter uma compara\u00e7\u00e3o detalhada dessas tecnologias com o <a href=\"https:\/\/kinsta.com\/pt\/blog\/graphql-vs-rest\/\">guia GraphQL vs RESTful API<\/a>.<\/p>\n<p>Para criar um servi\u00e7o GraphQL, voc\u00ea come\u00e7a definindo tipos de schemas e criando campos usando esses tipos. Em seguida, voc\u00ea fornece um resolvedor de fun\u00e7\u00e3o a ser executado em cada campo e digita sempre que os dados s\u00e3o solicitados pelo lado do cliente.<\/p>\n<h2>Terminologia do GraphQL<\/h2>\n<p>O sistema do tipo GraphQL \u00e9 usado para descrever quais dados podem ser consultados e quais dados voc\u00ea pode manipular. \u00c9 o n\u00facleo do GraphQL. Discutiremos diferentes maneiras de descrever e manipular os dados no GraphQ.<\/p>\n<h3>Tipos de objetos<\/h3>\n<p>Os tipos de objetos GraphQL s\u00e3o modelos de dados contendo campos fortemente digitados. Deve haver um mapeamento de 1 para 1 entre seus modelos e os tipos de GraphQL. Abaixo est\u00e1 um exemplo de tipos de GraphQL:<\/p>\n<pre><code class=\"language-json\">type User {\n  id: ID! # The \"!\" means required\n  firstname: String\n  lastname: String\n  email: String\n  username: String\n  todos: [Todo] # Todo is another GraphQL type\n}<\/code><\/pre>\n<h3 id=\"resolver\" class=\"has-anchor-hash\">Query<\/h3>\n<p>GraphQL Query define todas as consultas que um cliente pode executar na API GraphQL. Voc\u00ea deve definir um <code>RootQuery<\/code> que conter\u00e1 todas as consultas existentes por conven\u00e7\u00e3o.<\/p>\n<p>Abaixo, definimos e mapeamos as consultas para a API RESTful correspondente:<\/p>\n<pre><code class=\"language-json\">type RootQuery {\n  user(id: ID): User           # Corresponds to GET \/api\/users\/:id\n  users: [User]                # Corresponds to GET \/api\/users\n  todo(id: ID!): Todo    # Corresponds to GET \/api\/todos\/:id\n  todos: [Todo]          # Corresponds to GET \/api\/todos\n}<\/code><\/pre>\n<h3>Muta\u00e7\u00f5es<\/h3>\n<p>Se as consultas do GraphQL s\u00e3o pedidos <code>GET<\/code>, as muta\u00e7\u00f5es s\u00e3o <code>POST<\/code>, <code>PUT<\/code>, <code>PATCH<\/code>, e <code>DELETE<\/code> pedidos que manipulam a API do GraphQL.<\/p>\n<p>Colocaremos todas as muta\u00e7\u00f5es em um \u00fanico <code>RootMutation<\/code> para demonstrar:<\/p>\n<pre><code class=\"language-json\">type RootMutation {\n  createUser(input: UserInput!): User             # Corresponds to POST \/api\/users\n  updateUser(id: ID!, input: UserInput!): User    # Corresponds to PATCH \/api\/users\n  removeUser(id: ID!): User                       # Corresponds to DELETE \/api\/users\n  createTodo(input: TodoInput!): Todo\n  updateTodo(id: ID!, input: TodoInput!): Todo\n  removeTodo(id: ID!): Todo\n}<\/code><\/pre>\n<p>Voc\u00ea notou o uso de <code>-input<\/code> tipos para as muta\u00e7\u00f5es como <code>UserInput<\/code>, <code>TodoInput<\/code>. \u00c9 sempre a melhor pr\u00e1tica definir sempre os tipos de entrada para criar e atualizar seus recursos.<\/p>\n<p>Um tipo de entrada pode ser definido como:<\/p>\n<pre><code class=\"language-json\">input UserInput {\n  firstname: String!\n  lastname: String\n  email: String!\n  username: String!\n}<\/code><\/pre>\n<h3>Resolvers<\/h3>\n<p>Os resolvers dizem ao GraphQL o que fazer quando cada consulta ou muta\u00e7\u00e3o \u00e9 solicitada. \u00c9 uma fun\u00e7\u00e3o b\u00e1sica que faz o trabalho duro de acertar a camada do banco de dados para fazer as opera\u00e7\u00f5es CRUD (criar, ler, atualizar, excluir), acertar um endpoint interno RESTful API, ou chamar um <a href=\"https:\/\/kinsta.com\/pt\/blog\/microservicos-vs-api\/\">microsservi\u00e7o<\/a> para atender a solicita\u00e7\u00e3o do cliente.<\/p>\n<p>Voc\u00ea pode criar um novo arquivo <strong>resolvers.js<\/strong> e adicionar o seguinte c\u00f3digo:<\/p>\n<pre><code class=\"language-js\">import sequelize from '..\/models';\nexport default function resolvers () {\n  const models = sequelize.models;\n  return {\n    \/\/ Resolvers for Queries\n    RootQuery: {\n      user (root, { id }, context) {\n        return models.User.findById(id, context);\n      },\n      users (root, args, context) {\n        return models.User.findAll({}, context);\n      }\n    },\n    User: {\n      todos (user) {\n        return user.getTodos();\n      }\n    },\n  }\n  \/\/ Resolvers for Mutations\n  RootMutation: {\n    createUser (root, { input }, context) {\n      return models.User.create(input, context);    \n    },\n    updateUser (root, { id, input }, context) {\n      return models.User.update(input, { ...context, where: { id } });\n    },\n    removeUser (root, { id }, context) {\n      return models.User.destroy(input, { ...context, where: { id } });\n    },\n    \/\/ ... Resolvers for Todos go here\n  }\n}<\/code><\/pre>\n<h3>Schema<\/h3>\n<p>Um Schema GraphQL \u00e9 o que exp\u00f5e o GraphQL ao mundo. Portanto, tipos, consultas e muta\u00e7\u00f5es est\u00e3o contidos em schemas e expostos ao mundo.<\/p>\n<p>Abaixo est\u00e1 como expor tipos, consultas e muta\u00e7\u00f5es para o mundo:<\/p>\n<pre><code class=\"language-json\">schema {\n  query: RootQuery\n  mutation: RootMutation\n}<\/code><\/pre>\n<p>No script acima, inclu\u00edmos o <code>RootQuery<\/code> e <code>RootMutation<\/code> que criamos anteriormente para ser exposto ao mundo.<\/p>\n<h2>Como o GraphQL funciona com o Node.js e Express.js?<\/h2>\n<p>GraphQL fornece uma implementa\u00e7\u00e3o para todas as principais linguagens de programa\u00e7\u00e3o, e o Node.js n\u00e3o est\u00e1 isento. No <a href=\"https:\/\/graphql.org\/\">site oficial do GraphQL<\/a>, h\u00e1 uma se\u00e7\u00e3o para <a href=\"https:\/\/graphql.org\/code\/#javascript\">suporte ao JavaScript<\/a>, e tamb\u00e9m, h\u00e1 outras implementa\u00e7\u00f5es do GraphQL para tornar simples a escrita e a codifica\u00e7\u00e3o.<\/p>\n<p>GraphQL Apollo fornece uma implementa\u00e7\u00e3o para Node.js e Express.js e facilita come\u00e7ar a usar o GraphQL.<\/p>\n<p>Voc\u00ea aprender\u00e1 como criar e desenvolver seu primeiro aplicativo GraphQL no Node.js e <a href=\"https:\/\/kinsta.com\/pt\/blog\/o-que-e-express-js\/\">Express.js<\/a> backend framework usando o GraphQL Apollo na pr\u00f3xima se\u00e7\u00e3o.<\/p>\n<h2>Configurando o GraphQL com o Express.js<\/h2>\n<p>A constru\u00e7\u00e3o de um servidor GraphQL API com o Express.js \u00e9 simples para come\u00e7ar. Nesta se\u00e7\u00e3o, vamos explorar como construir um servidor GraphQL.<\/p>\n<h3>Inicialize o projeto com o Express.js<\/h3>\n<p>Primeiro, voc\u00ea precisa instalar e configurar um novo projeto Express.js. Crie uma pasta para o seu projeto e instale o Express.js usando este comando:<\/p>\n<pre><code class=\"language-bash\">cd &lt;project-name&gt; && npm init -y\nnpm install express<\/code><\/pre>\n<p>O comando acima cria um novo arquivo <strong>package.json<\/strong> e instala a biblioteca Express.js em seu projeto.<\/p>\n<p>A seguir, estruturaremos nosso projeto como mostrado na imagem abaixo. Ele conter\u00e1 diferentes m\u00f3dulos para as funcionalidades do projeto, tais como usu\u00e1rios, todos, etc.<\/p>\n<figure style=\"width: 467px\" class=\"wp-caption aligncenter\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/kinsta.com\/wp-content\/uploads\/2022\/12\/graphql-todo-structrue.png\" alt=\"Arquivos para o graphql-todo\" width=\"467\" height=\"595\"><figcaption class=\"wp-caption-text\">Arquivos para <em>o graphql-todo<\/em>.<\/figcaption><\/figure>\n<h3>Inicialize o GraphQL<\/h3>\n<p>Vamos come\u00e7ar instalando as depend\u00eancias do GraphQL Express.js. Execute o seguinte comando para instalar:<\/p>\n<pre><code class=\"language-bash\">npm install apollo-server-express graphql @graphql-tools\/schema --save<\/code><\/pre>\n<h3>Criando schemas e Types<\/h3>\n<p>A seguir, vamos criar um arquivo <strong>index.js<\/strong> na pasta de m\u00f3dulos e adicionar o seguinte snippet de c\u00f3digo:<\/p>\n<pre><code class=\"language-js\">const { gql } = require('apollo-server-express');\nconst users = require('.\/users');\nconst todos = require('.\/todos');\nconst { GraphQLScalarType } = require('graphql');\nconst { makeExecutableSchema } = require('@graphql-tools\/schema');\nconst typeDefs = gql`\n  scalar Time\n  type Query {\n    getVersion: String!\n  }\n  type Mutation {\n    version: String!\n  }\n`;\nconst timeScalar = new GraphQLScalarType({\n  name: 'Time',\n  description: 'Time custom scalar type',\n serialize: (value) =&gt; value,\n});\nconst resolvers = {\n  Time: timeScalar,\n  Query: {\n    getVersion: () =&gt; `v1`,\n  },\n};\nconst schema = makeExecutableSchema({\n  typeDefs: [typeDefs, users.typeDefs, todos.typeDefs],\n  resolvers: [resolvers, users.resolvers, todos.resolvers],\n});\nmodule.exports = schema;<\/code><\/pre>\n<h4>An\u00e1lise do c\u00f3digo<\/h4>\n<p>Vamos rever o snippet de c\u00f3digo passo a passo:<\/p>\n<h5>Passo 1<\/h5>\n<p>Primeiro, importamos as bibliotecas necess\u00e1rias e criamos os tipos de consulta e muta\u00e7\u00e3o padr\u00e3o. A consulta e a muta\u00e7\u00e3o definiram apenas a vers\u00e3o da API GraphQL por enquanto. Entretanto, estendamos a consulta e a muta\u00e7\u00e3o para incluir outros schemas conforme prosseguimos.<\/p>\n<figure style=\"width: 1266px\" class=\"wp-caption aligncenter\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/kinsta.com\/wp-content\/uploads\/2022\/12\/pasted-image-0-1.png\" alt=\"Importa\u00e7\u00e3o de GraphQL e extens\u00f5es\" width=\"1266\" height=\"904\"><figcaption class=\"wp-caption-text\">Importa\u00e7\u00e3o de GraphQL e extens\u00f5es.<\/figcaption><\/figure>\n<h5>Passo 2:<\/h5>\n<p>Criamos um novo tipo de escalar por tempo e nosso primeiro resolvedor para a consulta e muta\u00e7\u00e3o criada acima. Al\u00e9m disso, tamb\u00e9m geramos um schema usando a fun\u00e7\u00e3o <code>makeExecutableSchema<\/code>.<\/p>\n<p>O schema gerado incluir\u00e1 todos os outros schemas que voc\u00ea importou e ainda mais ap\u00f3s cri\u00e1-los e import\u00e1-los.<\/p>\n<figure style=\"width: 1166px\" class=\"wp-caption aligncenter\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/kinsta.com\/wp-content\/uploads\/2022\/12\/pasted-image-0-2.png\" alt=\"Criando um tipo escalar para o tempo, bem como nosso primeiro resolver.\" width=\"1166\" height=\"1012\"><figcaption class=\"wp-caption-text\">Criando um tipo escalar para o tempo, bem como nosso primeiro resolver.<\/figcaption><\/figure>\n<p>O snippet de c\u00f3digo acima mostra que importamos diferentes schemas para a fun\u00e7\u00e3o makeExecutableSchema. Esta abordagem nos ajuda na estrutura\u00e7\u00e3o do aplicativo por complexidade. Em seguida, criaremos os schemas Todo e Usu\u00e1rio que importamos.<\/p>\n<h3>Criando o schema Todo<\/h3>\n<p>O Schema Todo mostra opera\u00e7\u00f5es simples de CRUD que os usu\u00e1rios do aplicativo podem realizar. Abaixo est\u00e1 o schema que implementa a opera\u00e7\u00e3o de Todo CRUD.<\/p>\n<pre><code class=\"language-js\">const { gql } = require('apollo-server-express');\nconst createTodo = require('.\/mutations\/create-todo');\nconst updateTodo = require('.\/mutations\/update-todo');\nconst removeTodo = require('.\/mutations\/delete-todo');\nconst todo = require('.\/queries\/todo');\nconst todos = require('.\/queries\/todos');\nconst typeDefs = gql`\n  type Todo {\n    id: ID!\n    title: String\n    description: String\n    user: User\n  }\n  input CreateTodoInput {\n    title: String!\n    description: String\n    isCompleted: Boolean\n  }\n  input UpdateTodoInput {\n    title: String\n    description: String\n    isCompleted: Boolean\n  }  extend type Query {\n    todo(id: ID): Todo!\n    todos: [Todo!]\n  }\n  extend type Mutation {\n    createTodo(input: CreateTodoInput!): Todo\n    updateTodo(id: ID!, input: UpdateTodoInput!): Todo\n    removeTodo(id: ID!): Todo\n  }\n`;\n\/\/ Provide resolver functions for your schema fields\nconst resolvers = {\n  \/\/ Resolvers for Queries\n  Query: {\n    todo,\n    todos,\n  },\n  \/\/ Resolvers for Mutations\n  Mutation: {\n    createTodo,\n    updateTodo,\n    removeTodo,\n  },\n};\nmodule.exports = { typeDefs, resolvers };<\/code><\/pre>\n<h4>An\u00e1lise do c\u00f3digo<\/h4>\n<p>Vamos rever o snippet de c\u00f3digo passo a passo:<\/p>\n<h5>Passo 1:<\/h5>\n<p>Primeiro, criamos um Schema Todo usando GraphQL <code>type<\/code>, <code>input<\/code>, e <code>extend<\/code>. A palavra-chave <code>extend<\/code> \u00e9 usada para herdar e adicionar novas consultas e muta\u00e7\u00f5es \u00e0 consulta raiz existente e \u00e0 muta\u00e7\u00e3o que criamos acima.<\/p>\n<figure style=\"width: 1092px\" class=\"wp-caption aligncenter\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/kinsta.com\/wp-content\/uploads\/2022\/12\/pasted-image-0-3.png\" alt=\"Criando o Schema Todo\" width=\"1092\" height=\"1408\"><figcaption class=\"wp-caption-text\">Criando o Schema Todo.<\/figcaption><\/figure>\n<h5>Passo 2:<\/h5>\n<p>Em seguida, criamos um resolvedor, usado para recuperar os dados corretos quando uma determinada consulta ou muta\u00e7\u00e3o \u00e9 chamada.<\/p>\n<figure style=\"width: 1092px\" class=\"wp-caption alignnone\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/kinsta.com\/wp-content\/uploads\/2022\/12\/pasted-image-0.png\" alt=\"Criando um resolver\" width=\"1092\" height=\"904\"><figcaption class=\"wp-caption-text\">Criando um resolver.<\/figcaption><\/figure>\n<p>Com a fun\u00e7\u00e3o resolver implementada, podemos criar m\u00e9todos individuais para a l\u00f3gica de neg\u00f3cios e manipula\u00e7\u00e3o do banco de dados, como mostrado no exemplo do <strong>create-todo.js<\/strong>.<\/p>\n<p>Crie um arquivo <strong>create-user.js<\/strong> na pasta <code>.\/mutations\/<\/code> e adicione a l\u00f3gica do neg\u00f3cio para criar um novo Todo em seu banco de dados.<\/p>\n<pre><code class=\"language-js\">const models = require('..\/..\/..\/models');\nmodule.exports = async (root, { input }, context) =&gt; {\n  return models.todos.push({ ...input });\n};<\/code><\/pre>\n<p>O snippet de c\u00f3digo acima \u00e9 uma forma simplificada de criar um novo Todo em nosso banco de dados usando o ORM Sequelize. Voc\u00ea pode aprender mais sobre o <a href=\"https:\/\/sequelize.org\/\">Sequelize e como configur\u00e1-lo com o Node.js<\/a>.<\/p>\n<p>Voc\u00ea pode seguir o mesmo passo para criar muitos schemas dependendo do seu aplicativo ou voc\u00ea pode <a href=\"https:\/\/github.com\/Kaperskyguru\/graphql-todo-example\">clonar o projeto completo do GitHub<\/a>.<\/p>\n<p>Em seguida, configuraremos o servidor com o Express.js e executar o aplicativo Todo rec\u00e9m-criada com GraphQL e Node.js.<\/p>\n<h3>Configurando e executando o servidor<\/h3>\n<p>Finalmente, configuraremos nosso servidor usando a biblioteca <code>apollo-server-express<\/code> que instalamos anteriormente.<\/p>\n<p>O <code>apollo-server-express<\/code> \u00e9 um pacote simples do Apollo Server para Express.js, \u00e9 recomendado porque foi desenvolvido para se encaixar no desenvolvimento do Express.js.<\/p>\n<p>Usando os exemplos que discutimos acima, vamos configurar o servidor Express.js para trabalhar com o rec\u00e9m-instalado <code>apollo-server-express<\/code>.<\/p>\n<p>Crie um arquivo <strong>server.js<\/strong> no diret\u00f3rio raiz e cole no seguinte c\u00f3digo:<\/p>\n<pre><code class=\"language-js\">\nconst express = require('express');\nconst { ApolloServer } = require('apollo-server-express');\nconst schema = require('.\/modules');\nconst app = express();\nasync function startServer() {\n  const server = new ApolloServer({ schema });\n  await server.start();\n  server.applyMiddleware({ app });\n}\nstartServer();\napp.listen({ port: 3000 }, () =&gt;\n  console.log(`Server ready at http:\/\/localhost:3000`)\n);<\/code><\/pre>\n<p>O c\u00f3digo acima criou com sucesso o primeiro servidor GraphQL CRUD para Todos e Usu\u00e1rios. Voc\u00ea pode iniciar o servidor de desenvolvimento e acessar o playground via <a href=\"http:\/\/localhost:3000\/graphql\">http:\/\/localhost:3000\/graphql<\/a>. Se tudo der certo, voc\u00ea ver\u00e1 a seguinte tela:<\/p>\n<figure style=\"width: 1600px\" class=\"wp-caption alignnone\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/kinsta.com\/wp-content\/uploads\/2022\/12\/new_graphql_playground.png\" alt=\"A tela de verifica\u00e7\u00e3o\" width=\"1600\" height=\"1116\"><figcaption class=\"wp-caption-text\">A tela de verifica\u00e7\u00e3o.<\/figcaption><\/figure>\n<h2>Resumo<\/h2>\n<p>GraphQL \u00e9 uma tecnologia moderna suportada pelo Facebook que simplifica o tedioso trabalho envolvido na cria\u00e7\u00e3o de APIs de larga escala com padr\u00f5es arquitet\u00f4nicos RESTful.<\/p>\n<p>Este guia se aprofundou no GraphQL e mostrou como criar sua primeira API GraphQL usando Express.js.<\/p>\n<p>Deixe-nos saber o que voc\u00ea constr\u00f3i com GraphQL nos coment\u00e1rios abaixo.<\/p>\n","protected":false},"excerpt":{"rendered":"<p>GraphQL \u00e9 a nova palavra-chave no desenvolvimento de API. Enquanto as APIs RESTful continuam sendo a forma mais popular de expor dados de aplicativos, elas v\u00eam &#8230;<\/p>\n","protected":false},"author":193,"featured_media":56212,"comment_status":"open","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"_kinsta_gated_content":false,"_kinsta_gated_content_redirect":"","footnotes":""},"tags":[],"topic":[992,978],"class_list":["post-55945","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","topic-node-js","topic-tutoriais-javascript"],"yoast_head":"<!-- This site is optimized with the Yoast SEO Premium plugin v24.6 (Yoast SEO v24.6) - https:\/\/yoast.com\/wordpress\/plugins\/seo\/ -->\n<title>Construindo APIs GraphQL com Node - Kinsta\u00ae<\/title>\n<meta name=\"description\" content=\"Curioso como usar o GraphQL com o Node.js? N\u00f3s vamos gui\u00e1-lo por todo o processo com exemplos de c\u00f3digo e explica\u00e7\u00f5es f\u00e1ceis de entender.\" \/>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/kinsta.com\/pt\/blog\/graphql-nodejs\/\" \/>\n<meta property=\"og:locale\" content=\"pt_PT\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"Construindo APIs GraphQL com Node\" \/>\n<meta property=\"og:description\" content=\"Curioso como usar o GraphQL com o Node.js? N\u00f3s vamos gui\u00e1-lo por todo o processo com exemplos de c\u00f3digo e explica\u00e7\u00f5es f\u00e1ceis de entender.\" \/>\n<meta property=\"og:url\" content=\"https:\/\/kinsta.com\/pt\/blog\/graphql-nodejs\/\" \/>\n<meta property=\"og:site_name\" content=\"Kinsta\u00ae\" \/>\n<meta property=\"article:publisher\" content=\"https:\/\/www.facebook.com\/kinstapt\/\" \/>\n<meta property=\"article:published_time\" content=\"2023-01-02T11:56:17+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2025-01-31T14:25:06+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/kinsta.com\/pt\/wp-content\/uploads\/sites\/3\/2023\/01\/graphql-nodejs-2.png\" \/>\n\t<meta property=\"og:image:width\" content=\"1460\" \/>\n\t<meta property=\"og:image:height\" content=\"730\" \/>\n\t<meta property=\"og:image:type\" content=\"image\/png\" \/>\n<meta name=\"author\" content=\"Solomon Eseme\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:description\" content=\"Curioso como usar o GraphQL com o Node.js? N\u00f3s vamos gui\u00e1-lo por todo o processo com exemplos de c\u00f3digo e explica\u00e7\u00f5es f\u00e1ceis de entender.\" \/>\n<meta name=\"twitter:image\" content=\"https:\/\/kinsta.com\/pt\/wp-content\/uploads\/sites\/3\/2023\/01\/graphql-nodejs-2.png\" \/>\n<meta name=\"twitter:creator\" content=\"@kaperskyguru\" \/>\n<meta name=\"twitter:site\" content=\"@kinsta_pt\" \/>\n<meta name=\"twitter:label1\" content=\"Escrito por\" \/>\n\t<meta name=\"twitter:data1\" content=\"Solomon Eseme\" \/>\n\t<meta name=\"twitter:label2\" content=\"Tempo estimado de leitura\" \/>\n\t<meta name=\"twitter:data2\" content=\"10 minutos\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"Article\",\"@id\":\"https:\/\/kinsta.com\/pt\/blog\/graphql-nodejs\/#article\",\"isPartOf\":{\"@id\":\"https:\/\/kinsta.com\/pt\/blog\/graphql-nodejs\/\"},\"author\":{\"name\":\"Solomon Eseme\",\"@id\":\"https:\/\/kinsta.com\/pt\/#\/schema\/person\/51c9c77fa35cf1ef9a46308358441ab2\"},\"headline\":\"Construindo APIs GraphQL com Node\",\"datePublished\":\"2023-01-02T11:56:17+00:00\",\"dateModified\":\"2025-01-31T14:25:06+00:00\",\"mainEntityOfPage\":{\"@id\":\"https:\/\/kinsta.com\/pt\/blog\/graphql-nodejs\/\"},\"wordCount\":1558,\"commentCount\":0,\"publisher\":{\"@id\":\"https:\/\/kinsta.com\/pt\/#organization\"},\"image\":{\"@id\":\"https:\/\/kinsta.com\/pt\/blog\/graphql-nodejs\/#primaryimage\"},\"thumbnailUrl\":\"https:\/\/kinsta.com\/pt\/wp-content\/uploads\/sites\/3\/2023\/01\/graphql-nodejs-2.png\",\"inLanguage\":\"pt-PT\",\"potentialAction\":[{\"@type\":\"CommentAction\",\"name\":\"Comment\",\"target\":[\"https:\/\/kinsta.com\/pt\/blog\/graphql-nodejs\/#respond\"]}]},{\"@type\":\"WebPage\",\"@id\":\"https:\/\/kinsta.com\/pt\/blog\/graphql-nodejs\/\",\"url\":\"https:\/\/kinsta.com\/pt\/blog\/graphql-nodejs\/\",\"name\":\"Construindo APIs GraphQL com Node - Kinsta\u00ae\",\"isPartOf\":{\"@id\":\"https:\/\/kinsta.com\/pt\/#website\"},\"primaryImageOfPage\":{\"@id\":\"https:\/\/kinsta.com\/pt\/blog\/graphql-nodejs\/#primaryimage\"},\"image\":{\"@id\":\"https:\/\/kinsta.com\/pt\/blog\/graphql-nodejs\/#primaryimage\"},\"thumbnailUrl\":\"https:\/\/kinsta.com\/pt\/wp-content\/uploads\/sites\/3\/2023\/01\/graphql-nodejs-2.png\",\"datePublished\":\"2023-01-02T11:56:17+00:00\",\"dateModified\":\"2025-01-31T14:25:06+00:00\",\"description\":\"Curioso como usar o GraphQL com o Node.js? N\u00f3s vamos gui\u00e1-lo por todo o processo com exemplos de c\u00f3digo e explica\u00e7\u00f5es f\u00e1ceis de entender.\",\"breadcrumb\":{\"@id\":\"https:\/\/kinsta.com\/pt\/blog\/graphql-nodejs\/#breadcrumb\"},\"inLanguage\":\"pt-PT\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/kinsta.com\/pt\/blog\/graphql-nodejs\/\"]}]},{\"@type\":\"ImageObject\",\"inLanguage\":\"pt-PT\",\"@id\":\"https:\/\/kinsta.com\/pt\/blog\/graphql-nodejs\/#primaryimage\",\"url\":\"https:\/\/kinsta.com\/pt\/wp-content\/uploads\/sites\/3\/2023\/01\/graphql-nodejs-2.png\",\"contentUrl\":\"https:\/\/kinsta.com\/pt\/wp-content\/uploads\/sites\/3\/2023\/01\/graphql-nodejs-2.png\",\"width\":1460,\"height\":730,\"caption\":\"Construindo APIs GraphQL com Node\"},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/kinsta.com\/pt\/blog\/graphql-nodejs\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"Home\",\"item\":\"https:\/\/kinsta.com\/pt\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"Node.js\",\"item\":\"https:\/\/kinsta.com\/pt\/topicos\/node-js\/\"},{\"@type\":\"ListItem\",\"position\":3,\"name\":\"Construindo APIs GraphQL com Node\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/kinsta.com\/pt\/#website\",\"url\":\"https:\/\/kinsta.com\/pt\/\",\"name\":\"Kinsta\u00ae\",\"description\":\"Solu\u00e7\u00f5es de hospedagem Premium, r\u00e1pida e segura\",\"publisher\":{\"@id\":\"https:\/\/kinsta.com\/pt\/#organization\"},\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\/\/kinsta.com\/pt\/?s={search_term_string}\"},\"query-input\":{\"@type\":\"PropertyValueSpecification\",\"valueRequired\":true,\"valueName\":\"search_term_string\"}}],\"inLanguage\":\"pt-PT\"},{\"@type\":\"Organization\",\"@id\":\"https:\/\/kinsta.com\/pt\/#organization\",\"name\":\"Kinsta\",\"url\":\"https:\/\/kinsta.com\/pt\/\",\"logo\":{\"@type\":\"ImageObject\",\"inLanguage\":\"pt-PT\",\"@id\":\"https:\/\/kinsta.com\/pt\/#\/schema\/logo\/image\/\",\"url\":\"https:\/\/kinsta.com\/pt\/wp-content\/uploads\/sites\/3\/2023\/12\/kinsta-logo.jpeg\",\"contentUrl\":\"https:\/\/kinsta.com\/pt\/wp-content\/uploads\/sites\/3\/2023\/12\/kinsta-logo.jpeg\",\"width\":500,\"height\":500,\"caption\":\"Kinsta\"},\"image\":{\"@id\":\"https:\/\/kinsta.com\/pt\/#\/schema\/logo\/image\/\"},\"sameAs\":[\"https:\/\/www.facebook.com\/kinstapt\/\",\"https:\/\/x.com\/kinsta_pt\",\"https:\/\/www.instagram.com\/kinstahosting\/\",\"https:\/\/www.linkedin.com\/company\/kinsta\/\",\"https:\/\/www.pinterest.com\/kinstahosting\/\",\"https:\/\/www.youtube.com\/c\/Kinsta\"]},{\"@type\":\"Person\",\"@id\":\"https:\/\/kinsta.com\/pt\/#\/schema\/person\/51c9c77fa35cf1ef9a46308358441ab2\",\"name\":\"Solomon Eseme\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"pt-PT\",\"@id\":\"https:\/\/kinsta.com\/pt\/#\/schema\/person\/image\/\",\"url\":\"https:\/\/secure.gravatar.com\/avatar\/1c701993f8ff8c8df2a4c5664834a4e5?s=96&d=mm&r=g\",\"contentUrl\":\"https:\/\/secure.gravatar.com\/avatar\/1c701993f8ff8c8df2a4c5664834a4e5?s=96&d=mm&r=g\",\"caption\":\"Solomon Eseme\"},\"description\":\"I am a Software Engineer and Content Creator who is geared toward building high-performing and innovative products following best practices and industry standards. I also love writing about it at Masteringbackend.com. Follow me on Twitter, LinkedIn, and About Me\",\"sameAs\":[\"https:\/\/masteringbackend.com\",\"https:\/\/linkedin.com\/in\/solomoneseme\",\"https:\/\/x.com\/kaperskyguru\"],\"url\":\"https:\/\/kinsta.com\/pt\/blog\/author\/solomoneseme\/\"}]}<\/script>\n<!-- \/ Yoast SEO Premium plugin. -->","yoast_head_json":{"title":"Construindo APIs GraphQL com Node - Kinsta\u00ae","description":"Curioso como usar o GraphQL com o Node.js? N\u00f3s vamos gui\u00e1-lo por todo o processo com exemplos de c\u00f3digo e explica\u00e7\u00f5es f\u00e1ceis de entender.","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/kinsta.com\/pt\/blog\/graphql-nodejs\/","og_locale":"pt_PT","og_type":"article","og_title":"Construindo APIs GraphQL com Node","og_description":"Curioso como usar o GraphQL com o Node.js? N\u00f3s vamos gui\u00e1-lo por todo o processo com exemplos de c\u00f3digo e explica\u00e7\u00f5es f\u00e1ceis de entender.","og_url":"https:\/\/kinsta.com\/pt\/blog\/graphql-nodejs\/","og_site_name":"Kinsta\u00ae","article_publisher":"https:\/\/www.facebook.com\/kinstapt\/","article_published_time":"2023-01-02T11:56:17+00:00","article_modified_time":"2025-01-31T14:25:06+00:00","og_image":[{"width":1460,"height":730,"url":"https:\/\/kinsta.com\/pt\/wp-content\/uploads\/sites\/3\/2023\/01\/graphql-nodejs-2.png","type":"image\/png"}],"author":"Solomon Eseme","twitter_card":"summary_large_image","twitter_description":"Curioso como usar o GraphQL com o Node.js? N\u00f3s vamos gui\u00e1-lo por todo o processo com exemplos de c\u00f3digo e explica\u00e7\u00f5es f\u00e1ceis de entender.","twitter_image":"https:\/\/kinsta.com\/pt\/wp-content\/uploads\/sites\/3\/2023\/01\/graphql-nodejs-2.png","twitter_creator":"@kaperskyguru","twitter_site":"@kinsta_pt","twitter_misc":{"Escrito por":"Solomon Eseme","Tempo estimado de leitura":"10 minutos"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"Article","@id":"https:\/\/kinsta.com\/pt\/blog\/graphql-nodejs\/#article","isPartOf":{"@id":"https:\/\/kinsta.com\/pt\/blog\/graphql-nodejs\/"},"author":{"name":"Solomon Eseme","@id":"https:\/\/kinsta.com\/pt\/#\/schema\/person\/51c9c77fa35cf1ef9a46308358441ab2"},"headline":"Construindo APIs GraphQL com Node","datePublished":"2023-01-02T11:56:17+00:00","dateModified":"2025-01-31T14:25:06+00:00","mainEntityOfPage":{"@id":"https:\/\/kinsta.com\/pt\/blog\/graphql-nodejs\/"},"wordCount":1558,"commentCount":0,"publisher":{"@id":"https:\/\/kinsta.com\/pt\/#organization"},"image":{"@id":"https:\/\/kinsta.com\/pt\/blog\/graphql-nodejs\/#primaryimage"},"thumbnailUrl":"https:\/\/kinsta.com\/pt\/wp-content\/uploads\/sites\/3\/2023\/01\/graphql-nodejs-2.png","inLanguage":"pt-PT","potentialAction":[{"@type":"CommentAction","name":"Comment","target":["https:\/\/kinsta.com\/pt\/blog\/graphql-nodejs\/#respond"]}]},{"@type":"WebPage","@id":"https:\/\/kinsta.com\/pt\/blog\/graphql-nodejs\/","url":"https:\/\/kinsta.com\/pt\/blog\/graphql-nodejs\/","name":"Construindo APIs GraphQL com Node - Kinsta\u00ae","isPartOf":{"@id":"https:\/\/kinsta.com\/pt\/#website"},"primaryImageOfPage":{"@id":"https:\/\/kinsta.com\/pt\/blog\/graphql-nodejs\/#primaryimage"},"image":{"@id":"https:\/\/kinsta.com\/pt\/blog\/graphql-nodejs\/#primaryimage"},"thumbnailUrl":"https:\/\/kinsta.com\/pt\/wp-content\/uploads\/sites\/3\/2023\/01\/graphql-nodejs-2.png","datePublished":"2023-01-02T11:56:17+00:00","dateModified":"2025-01-31T14:25:06+00:00","description":"Curioso como usar o GraphQL com o Node.js? N\u00f3s vamos gui\u00e1-lo por todo o processo com exemplos de c\u00f3digo e explica\u00e7\u00f5es f\u00e1ceis de entender.","breadcrumb":{"@id":"https:\/\/kinsta.com\/pt\/blog\/graphql-nodejs\/#breadcrumb"},"inLanguage":"pt-PT","potentialAction":[{"@type":"ReadAction","target":["https:\/\/kinsta.com\/pt\/blog\/graphql-nodejs\/"]}]},{"@type":"ImageObject","inLanguage":"pt-PT","@id":"https:\/\/kinsta.com\/pt\/blog\/graphql-nodejs\/#primaryimage","url":"https:\/\/kinsta.com\/pt\/wp-content\/uploads\/sites\/3\/2023\/01\/graphql-nodejs-2.png","contentUrl":"https:\/\/kinsta.com\/pt\/wp-content\/uploads\/sites\/3\/2023\/01\/graphql-nodejs-2.png","width":1460,"height":730,"caption":"Construindo APIs GraphQL com Node"},{"@type":"BreadcrumbList","@id":"https:\/\/kinsta.com\/pt\/blog\/graphql-nodejs\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"Home","item":"https:\/\/kinsta.com\/pt\/"},{"@type":"ListItem","position":2,"name":"Node.js","item":"https:\/\/kinsta.com\/pt\/topicos\/node-js\/"},{"@type":"ListItem","position":3,"name":"Construindo APIs GraphQL com Node"}]},{"@type":"WebSite","@id":"https:\/\/kinsta.com\/pt\/#website","url":"https:\/\/kinsta.com\/pt\/","name":"Kinsta\u00ae","description":"Solu\u00e7\u00f5es de hospedagem Premium, r\u00e1pida e segura","publisher":{"@id":"https:\/\/kinsta.com\/pt\/#organization"},"potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/kinsta.com\/pt\/?s={search_term_string}"},"query-input":{"@type":"PropertyValueSpecification","valueRequired":true,"valueName":"search_term_string"}}],"inLanguage":"pt-PT"},{"@type":"Organization","@id":"https:\/\/kinsta.com\/pt\/#organization","name":"Kinsta","url":"https:\/\/kinsta.com\/pt\/","logo":{"@type":"ImageObject","inLanguage":"pt-PT","@id":"https:\/\/kinsta.com\/pt\/#\/schema\/logo\/image\/","url":"https:\/\/kinsta.com\/pt\/wp-content\/uploads\/sites\/3\/2023\/12\/kinsta-logo.jpeg","contentUrl":"https:\/\/kinsta.com\/pt\/wp-content\/uploads\/sites\/3\/2023\/12\/kinsta-logo.jpeg","width":500,"height":500,"caption":"Kinsta"},"image":{"@id":"https:\/\/kinsta.com\/pt\/#\/schema\/logo\/image\/"},"sameAs":["https:\/\/www.facebook.com\/kinstapt\/","https:\/\/x.com\/kinsta_pt","https:\/\/www.instagram.com\/kinstahosting\/","https:\/\/www.linkedin.com\/company\/kinsta\/","https:\/\/www.pinterest.com\/kinstahosting\/","https:\/\/www.youtube.com\/c\/Kinsta"]},{"@type":"Person","@id":"https:\/\/kinsta.com\/pt\/#\/schema\/person\/51c9c77fa35cf1ef9a46308358441ab2","name":"Solomon Eseme","image":{"@type":"ImageObject","inLanguage":"pt-PT","@id":"https:\/\/kinsta.com\/pt\/#\/schema\/person\/image\/","url":"https:\/\/secure.gravatar.com\/avatar\/1c701993f8ff8c8df2a4c5664834a4e5?s=96&d=mm&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/1c701993f8ff8c8df2a4c5664834a4e5?s=96&d=mm&r=g","caption":"Solomon Eseme"},"description":"I am a Software Engineer and Content Creator who is geared toward building high-performing and innovative products following best practices and industry standards. I also love writing about it at Masteringbackend.com. Follow me on Twitter, LinkedIn, and About Me","sameAs":["https:\/\/masteringbackend.com","https:\/\/linkedin.com\/in\/solomoneseme","https:\/\/x.com\/kaperskyguru"],"url":"https:\/\/kinsta.com\/pt\/blog\/author\/solomoneseme\/"}]}},"acf":[],"_links":{"self":[{"href":"https:\/\/kinsta.com\/pt\/wp-json\/wp\/v2\/posts\/55945","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/kinsta.com\/pt\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/kinsta.com\/pt\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/kinsta.com\/pt\/wp-json\/wp\/v2\/users\/193"}],"replies":[{"embeddable":true,"href":"https:\/\/kinsta.com\/pt\/wp-json\/wp\/v2\/comments?post=55945"}],"version-history":[{"count":9,"href":"https:\/\/kinsta.com\/pt\/wp-json\/wp\/v2\/posts\/55945\/revisions"}],"predecessor-version":[{"id":56288,"href":"https:\/\/kinsta.com\/pt\/wp-json\/wp\/v2\/posts\/55945\/revisions\/56288"}],"alternate":[{"embeddable":true,"hreflang":"en","title":"English","href":"https:\/\/kinsta.com\/pt\/wp-json\/kinsta\/v1\/posts\/55945\/translations\/en"},{"embeddable":true,"hreflang":"it","title":"Italian","href":"https:\/\/kinsta.com\/pt\/wp-json\/kinsta\/v1\/posts\/55945\/translations\/it"},{"embeddable":true,"hreflang":"pt","title":"Portuguese","href":"https:\/\/kinsta.com\/pt\/wp-json\/kinsta\/v1\/posts\/55945\/translations\/pt"},{"embeddable":true,"hreflang":"fr","title":"French","href":"https:\/\/kinsta.com\/pt\/wp-json\/kinsta\/v1\/posts\/55945\/translations\/fr"},{"embeddable":true,"hreflang":"de","title":"German","href":"https:\/\/kinsta.com\/pt\/wp-json\/kinsta\/v1\/posts\/55945\/translations\/de"},{"embeddable":true,"hreflang":"ja","title":"Japanese","href":"https:\/\/kinsta.com\/pt\/wp-json\/kinsta\/v1\/posts\/55945\/translations\/jp"},{"embeddable":true,"hreflang":"nl","title":"Dutch","href":"https:\/\/kinsta.com\/pt\/wp-json\/kinsta\/v1\/posts\/55945\/translations\/nl"},{"embeddable":true,"hreflang":"es","title":"Spanish","href":"https:\/\/kinsta.com\/pt\/wp-json\/kinsta\/v1\/posts\/55945\/translations\/es"},{"embeddable":true,"hreflang":"sv","title":"Swedish","href":"https:\/\/kinsta.com\/pt\/wp-json\/kinsta\/v1\/posts\/55945\/translations\/se"},{"embeddable":true,"hreflang":"da","title":"Danish","href":"https:\/\/kinsta.com\/pt\/wp-json\/kinsta\/v1\/posts\/55945\/translations\/dk"},{"href":"https:\/\/kinsta.com\/pt\/wp-json\/kinsta\/v1\/posts\/55945\/tree"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/kinsta.com\/pt\/wp-json\/wp\/v2\/media\/56212"}],"wp:attachment":[{"href":"https:\/\/kinsta.com\/pt\/wp-json\/wp\/v2\/media?parent=55945"}],"wp:term":[{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/kinsta.com\/pt\/wp-json\/wp\/v2\/tags?post=55945"},{"taxonomy":"topic","embeddable":true,"href":"https:\/\/kinsta.com\/pt\/wp-json\/wp\/v2\/topic?post=55945"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}