在 go 语言中使用 graphql 与端点交互可以分为五个步骤:安装 github.com/graphql-go/graphql 库。设置 graphql 请求,包括客户端和查询。发送请求,调用 run 方法传递查询。解析响应,将结果解析成指定的结构体类型。实战案例演示了向 graphql api 发送查询的代码实现。
Go 语言中与 GraphQL 端点交互
GraphQL 是一种用于 API 交互的查询语言,它允许客户端获取所需的确切数据,从而提高了效率和灵活性。在 Go 语言中,我们可以使用 github.com/graphql-go/graphql 库与 GraphQL 端点进行交互。
安装
立即学习“go语言免费学习笔记(深入)”;
go get github.com/graphql-go/graphql
设置 GraphQL 请求
要向 GraphQL 端点发送请求,我们需要创建一个 graphql.Client 实例并提供端点 URL。
import "github.com/graphql-go/graphql" client := graphql.NewClient("https://api.example.com/graphql")
接下来,我们需要构造 GraphQL 查询。一个简单的查询可以获取所有用户的列表:
query := ` { users { id name email } } `
发送请求
要发送请求,我们调用 Run 方法并传递查询。
type User struct { ID string Name string Email string } userResponse := User{} err := client.Run(query, &userResponse)
响应解析
如果请求成功,Run 方法会将响应解析成指定的结构体类型。在上面的示例中,响应将解析成 User 结构体。
实战案例
考虑一个使用 Go 作为后端的 GraphQL API。我们可以使用以下代码从客户端向 API 发送查询:
import ( "context" "fmt" "log" "github.com/graphql-go/graphql" ) func main() { // API URL url := "https://localhost:8080/graphql" // New client client := graphql.NewClient(url) // Create request query := ` { users { name } } ` // Run query ctx := context.Background() request := graphql.NewRequest(query) response := graphql.Response{} if err := client.Run(ctx, request, &response); err != nil { log.Fatal(err) } // Print data for _, u := range response.Data["users"].([]interface{}) { fmt.Println(u.(map[string]interface{})["name"]) } }
以上就是Golang GraphQL:如何与 GraphQL 端点交互的详细内容,更多请关注php中文网其它相关文章!