首页 > 编程 > .NET > 正文

ASP.NET Core使用GraphQL第一章之Hello World

2024-07-10 12:48:38
字体:
来源:转载
供稿:网友

前言

你是否已经厌倦了REST风格的API? 让我们来聊一下GraphQL。

 下面是GraphQL的定义:

GraphQL 既是一种用于 API 的查询语言也是一个满足你数据查询的运行时。 GraphQL 对你的 API 中的数据提供了一套易于理解的完整描述,使得客户端能够准确地获得它需要的数据,而且没有任何冗余,也让 API 更容易地随着时间推移而演进,还能用于构建强大的开发者工具。

GraphQL由Facebook开发,始于2012年,2015年公开。

GraphQL牛逼之处是它可以让客户端精确的查询它们想要的,不附加额外的东西,这样的话就很容易让客户端随着API的演进去使用。

GraphQL提供了一种声明式的方式从服务器拉取数据。你可以从GraphQL官网中了解到GraphQL的所有优点。在这一系列博客中,我将展示如何在ASP.NET Core中集成GraphQL, 并使用GraphQL作为你的API查询语言。

使用GraphQL的声明式查询,你可以自定义API返回的属性列表。这与REST API中每个API只返回固定字段不同。

安装GraphQL

为了在C#中使用GraphQL, GraphQL社区中提供了一个开源组件 graphql-dotnet 。本系列博客中我们都将使用这个组件。

首先我们创建一个空的ASP.NET Core App

dotnet new web --name chatper1

然后我们添加对 graphql-dotnet 库的引用

dotnet add package GraphQL

创建第一个Query

下面我们来创建一个 query 类, 我们将它命名为 HelloWorldQuery 。 graphql-dotnet 中,查询类都需要继承 ObjectGraphType 类,所以 HelloWorldQuery 的代码如下

using GraphQL.Types;public class HelloWorldQuery : ObjectGraphType{  public HelloWorldQuery()  {    Field<StringGraphType>(      name: "hello",      resolve: context => "world"    );  }}

这里你可能注意到我们使用了一个泛型方法 Field ,并传递了一个GraphQL的字符串类型 StringGraphType 来定义了一个 hello 字段, resolve 参数是一个Func委托,在其中定义了如何返回当前字段的值,这里我们是直接返回了一个字符串hello。

查询类中的返回字段都是定义在查询类的构造函数中的

现在我们一个有了一个查询类,下一步我们需要使用这个查询类构建一个结构(schema)。

在 Startup.cs 文件的 Configure 方法中,使用以下代码替换原有代码

var schema = new Schema {  Query = new HelloWorldQuery() };app.Run(async (context) =>{  var result = await new DocumentExecuter()    .ExecuteAsync(doc =>    {      doc.Schema = schema;      doc.Query = @"        query {          hello        }      ";    }).ConfigureAwait(false);  var json = new DocumentWriter(indent: true)    .Write(result)  await context.Response.WriteAsync(json);});            
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表