使用 apollo server 将 graphql 集成到 golang 框架中:安装 apollo server 和 gqlgen 依赖项。使用 gqlgen cli 生成 graphql 模式。定义和实现 graphql 解析器。使用 apollo server 创建 graphql 服务器。运行应用程序,并使用 graphql playground 访问 graphql api。
如何使用 Apollo Server 将 GraphQL 集成到 Golang 框架中
GraphQL 是一种查询语言,允许客户端以声明性方式请求和处理数据。通过将 GraphQL 集成到 Golang 应用程序中,您可以创建提供灵活且强大的查询和突变功能的 API。
使用 Apollo Server
立即学习“go语言免费学习笔记(深入)”;
Apollo Server 是一个流行的 GraphQL 服务器框架,它提供了一组工具来帮助您快速轻松地构建 GraphQL API。本教程将向您展示如何使用 Apollo Server 将 GraphQL 集成到 Golang 应用程序中。
实战案例:创建一个简单的 GraphQL API
首先,让我们创建一个简单的 Golang 应用程序,它将使用 Apollo Server 公开一个 GraphQL API。
安装依赖项
go get <a style='color:#f60; text-decoration:underline;' href="https://www.php.cn/zt/15841.html" target="_blank">git</a>hub.com/99designs/gqlgen
go get github.com/vektah/gqlparser/v2
生成 GraphQL 模式
使用 gqlgen CLI 生成一个基本的 GraphQL 模式:
gqlgen init
这将在您的项目中创建一个名为 schema.graphql 的文件,其中包含您的 GraphQL 模式的定义。
定义 GraphQL 模式
在 schema.graphql 中,定义一个包含单个查询解析器的 GraphQL 类型,该解析器将返回一个字符串:
type Query {
hello: String
}
实现 GraphQL 解析器
在 resolver.go 文件中,为查询解析器编写实现了函数:
package resolvers
import (
"context"
)
// QueryResolver is a resolver for the Query type.
type QueryResolver struct{}
// Hello resolves the hello field.
func (r *QueryResolver) Hello(ctx context.Context) string {
return "Hello, world!"
}
创建 GraphQL 服务器
在 main.go 文件中,创建使用 Apollo Server 的 GraphQL 服务器:
package main
import (
"log"
"net/http"
"github.com/99designs/gqlgen/graphql/handler"
"github.com/99designs/gqlgen/graphql/playground"
resolvers "github.com/username/project/graph/resolvers"
)
func main() {
// 创建 GraphQL 服务器
srv := handler.NewDefaultServer(
resolvers.NewExecutableSchema(resolvers.New()),
)
playgroundHandler := playground.Handler("GraphQL Playground", "/query")
// 路由器,将查询和 Playground 添加到 HTTP 路由器中
http.Handle("/", playgroundHandler)
http.Handle("/query", srv)
// 启动 HTTP 服务器
log.Printf("server listening on port %s", "8080")
log.Fatal(http.ListenAndServe(":8080", nil))
}
运行应用程序
使用以下命令运行应用程序:
go run main.go
现在,您可以使用 GraphQL Playground(http://localhost:8080/)对 GraphQL API 进行查询和突变。