Easy-DotNET Easy-DotNET
🏠首页
  • 知识地图
  • 源码脑图

    • 总览
    • Program
    • WebApplication
    • Host主机
    • WebHost主机
    • 依赖注入
    • Autofac
    • Middleware中间件
    • RateLimiter限制速率
    • 响应缓存、请求解压缩
  • 设计初衷
  • 克隆
  • 类型转换
  • 日期时间
  • IO流
  • 工具类
  • 语言特性
  • 集合类
  • Codec编码
  • 文本操作
  • 数学
  • 图片
  • 网络
  • Emoji表情
  • C# 12
  • C# 11
  • C# 10
  • C# 9.0
  • C# 8.0
  • C# 早期版本
  • C# 教程
  • ORM
  • 定时任务
  • 日志
  • 认证与授权
  • Swagger
  • 对象映射
  • 熔断重试限流
  • 缓存
  • 注册发现
  • 网关
  • GraphQL
  • 更多
  • Docker

    • 简介
    • Adminer
    • Apisix
    • Apollo
    • Cassandra
    • Cerebro
    • ClickHouse
    • Consul
    • EasyMock
    • Elasticsearch
    • Emqx
    • FastDFS
    • Flink
    • Gitlab
    • Jenkins
    • Jrebel
    • MariaDB
    • MySQL
    • Percona
    • Phpmyadmin
    • PostgreSQL
    • Redis
  • Linux

    • 查看Linux系统信息
    • CentOS7调整磁盘分区
    • IO压测
    • 图形化监控工具Cockpit
  • 总览
  • 列表

    • 算法数据结构
    • API
    • 应用框架
    • 应用模板
    • 操作系统
    • 工作流
    • 入门套件
    • 示例
    • 人工智能
    • 程序集
    • Assets
    • 认证授权
    • Blazor
    • 区块链
    • 书籍
    • 自动构建
    • 报表
    • 缓存
    • 日历
    • 聊天
    • CLI
    • CLR
    • CMS
    • 代码分析和指标
    • 代码片段
    • 压缩
    • 持续集成
    • 密码学
    • 数据库
    • 数据库驱动
    • 日期时间
    • 反编译
    • 部署
    • DirectX
    • 分布式计算
    • DLR
    • 文档
    • 电商支付
    • 模拟器
    • 环境管理
    • ETL
    • 事件消息
    • Exception
    • 扩展
    • 函数式编程
    • 游戏引擎
    • GIS
    • Git工具
    • 绘图
    • GraphQL
    • GUI
    • HTML-CSS
    • HTTP
    • IDE
    • 图片处理
    • 安装工具
    • 交互式编程
    • 国际化
    • 互操作性
    • IoC
    • JS引擎
    • 日志
    • 机器学习和数据科学
    • Markdown
    • 邮件
    • 数学
    • 媒体
    • 指标
    • 微型框架
    • 最小化器
    • MVVM
    • 网络
    • 对象映射
    • Office
    • OpenAI
    • ORM
    • 包管理器
    • PDF
    • 性能分析工具
    • 协议
    • 推送通知
    • SQL构建器
    • 消息队列
    • RPC
    • 响应式编程
    • 实时通信
    • 正则表达式
    • 任务调度
    • SDK和API
    • 搜索引擎
    • 序列化
    • SMS
    • 状态机
    • 静态站点生成
    • 强命名
    • 风格指南
    • 模板引擎
    • 测试
    • 工具
    • 交易
    • UI自动测试
    • Visual Studio 插件
    • Web浏览器
    • Web框架
    • WebServers
    • WebSocket
    • Windows服务
    • WPF
    • 解析器
    • 源码生成
    • 其他
    • 资源
  • AspNetCore面试题
  • Elasticsearch面试题
  • MongoDB面试题
  • MySql面试题
  • Nginx面试题
  • RabbitMQ面试题
  • Redis面试题
  • 设计模式
  • 微服务
🧑‍💻.NET Blog
GitHub (opens new window)
🏠首页
  • 知识地图
  • 源码脑图

    • 总览
    • Program
    • WebApplication
    • Host主机
    • WebHost主机
    • 依赖注入
    • Autofac
    • Middleware中间件
    • RateLimiter限制速率
    • 响应缓存、请求解压缩
  • 设计初衷
  • 克隆
  • 类型转换
  • 日期时间
  • IO流
  • 工具类
  • 语言特性
  • 集合类
  • Codec编码
  • 文本操作
  • 数学
  • 图片
  • 网络
  • Emoji表情
  • C# 12
  • C# 11
  • C# 10
  • C# 9.0
  • C# 8.0
  • C# 早期版本
  • C# 教程
  • ORM
  • 定时任务
  • 日志
  • 认证与授权
  • Swagger
  • 对象映射
  • 熔断重试限流
  • 缓存
  • 注册发现
  • 网关
  • GraphQL
  • 更多
  • Docker

    • 简介
    • Adminer
    • Apisix
    • Apollo
    • Cassandra
    • Cerebro
    • ClickHouse
    • Consul
    • EasyMock
    • Elasticsearch
    • Emqx
    • FastDFS
    • Flink
    • Gitlab
    • Jenkins
    • Jrebel
    • MariaDB
    • MySQL
    • Percona
    • Phpmyadmin
    • PostgreSQL
    • Redis
  • Linux

    • 查看Linux系统信息
    • CentOS7调整磁盘分区
    • IO压测
    • 图形化监控工具Cockpit
  • 总览
  • 列表

    • 算法数据结构
    • API
    • 应用框架
    • 应用模板
    • 操作系统
    • 工作流
    • 入门套件
    • 示例
    • 人工智能
    • 程序集
    • Assets
    • 认证授权
    • Blazor
    • 区块链
    • 书籍
    • 自动构建
    • 报表
    • 缓存
    • 日历
    • 聊天
    • CLI
    • CLR
    • CMS
    • 代码分析和指标
    • 代码片段
    • 压缩
    • 持续集成
    • 密码学
    • 数据库
    • 数据库驱动
    • 日期时间
    • 反编译
    • 部署
    • DirectX
    • 分布式计算
    • DLR
    • 文档
    • 电商支付
    • 模拟器
    • 环境管理
    • ETL
    • 事件消息
    • Exception
    • 扩展
    • 函数式编程
    • 游戏引擎
    • GIS
    • Git工具
    • 绘图
    • GraphQL
    • GUI
    • HTML-CSS
    • HTTP
    • IDE
    • 图片处理
    • 安装工具
    • 交互式编程
    • 国际化
    • 互操作性
    • IoC
    • JS引擎
    • 日志
    • 机器学习和数据科学
    • Markdown
    • 邮件
    • 数学
    • 媒体
    • 指标
    • 微型框架
    • 最小化器
    • MVVM
    • 网络
    • 对象映射
    • Office
    • OpenAI
    • ORM
    • 包管理器
    • PDF
    • 性能分析工具
    • 协议
    • 推送通知
    • SQL构建器
    • 消息队列
    • RPC
    • 响应式编程
    • 实时通信
    • 正则表达式
    • 任务调度
    • SDK和API
    • 搜索引擎
    • 序列化
    • SMS
    • 状态机
    • 静态站点生成
    • 强命名
    • 风格指南
    • 模板引擎
    • 测试
    • 工具
    • 交易
    • UI自动测试
    • Visual Studio 插件
    • Web浏览器
    • Web框架
    • WebServers
    • WebSocket
    • Windows服务
    • WPF
    • 解析器
    • 源码生成
    • 其他
    • 资源
  • AspNetCore面试题
  • Elasticsearch面试题
  • MongoDB面试题
  • MySql面试题
  • Nginx面试题
  • RabbitMQ面试题
  • Redis面试题
  • 设计模式
  • 微服务
🧑‍💻.NET Blog
GitHub (opens new window)
npm
  • 简介
  • ORM

    • EFCore
    • Dapper
    • FreeSql
    • SqlSugar
  • 任务调度

    • Hangfire
    • Quartz
    • FluentScheduler
    • Coravel
    • Quartzmin
  • 日志

    • Serilog
    • NLog
    • Log4Net
    • Stackdriver
    • ExceptionLess
  • 身份认证与授权

    • IdentityServer4
    • Identity
    • JWTBearer
    • Auth0
    • OpenIddict
  • Swagger文档

    • Swagger
    • Swashbuckle
    • NSwag
    • ReDoc
  • 对象映射

    • AutoMapper
    • EmitMapper
    • AgileMapper
    • Mapster
  • 消息传递

    • MediatR
    • MassTransit
    • Rebus
    • NServiceBus
  • 熔断重试限流

    • Polly
    • Resilience4j
    • AkkaNET
  • 缓存

    • CsRedis
    • FreeRedis
    • EasyCaching
    • StackExchangeRedis
    • CacheCow
    • NCache
    • Memory
  • 注册发现

    • Consul
    • Nacos
    • Apollo
  • 网关

    • Ocelot
    • Kong
    • Traefik
    • Zuul
  • GraphQL

    • GraphQLPlatform
      • 安装和配置 GraphQL-Platform
      • 创建 GraphQL 查询
      • 添加查询参数
      • 添加 GraphQL 基因库
      • 添加 GraphQL 突变
      • 结论
    • GraphQLdotnet
  • 更多

    • NodaTime
    • FluentAssertions
    • Humanizer
    • 爬虫-AngleSharp
    • 邮件-MailKit
  • NET微服务
  • GraphQL
一个大西瓜
2023-04-25
目录

GraphQLPlatform

开源地址

Github:https://github.com/ChilliCream/graphql-platform (opens new window)

GraphQL 是一种查询语言和运行时环境,可用于构建 API。它由 Facebook 开发,并已在许多大型应用程序中得到广泛应用。而 .NET 中的 GraphQL-Platform 提供了一个完整的、开放的和可扩展的解决方案,使开发人员可以轻松地使用 GraphQL API。

在本篇文章中,我们将介绍如何在 .NET 中使用 GraphQL-Platform 构建和部署 API,并提供一些详细的使用示例。

# 安装和配置 GraphQL-Platform

首先,我们需要安装 GraphQL-Platform 的 NuGet 包。我们可以使用 Visual Studio 中的 NuGet 包管理器或在控制台中使用以下命令:


Install-Package GraphQL-Platform

接下来,我们需要在我们的应用程序中配置 GraphQL-Platform。在 Startup.cs 文件中,我们需要添加以下代码:


public void ConfigureServices(IServiceCollection services)
{
    services.AddGraphQL()
        .AddSystemTextJson()
        .AddGraphTypes(typeof(Startup));
}

public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
{
    app.UseGraphQL()
       .UsePlayground();
}

这段代码将启用 GraphQL-Platform,并配置系统文本 JSON 作为默认序列化程序。它还将自动扫描应用程序程序集,找到我们定义的所有 GraphQL 类型,并将它们添加到 GraphQL 架构中。

最后,我们需要使用 UsePlayground() 方法来启用 GraphQL Playground。这是一个用于测试和调试 GraphQL API 的交互式 IDE。我们可以在浏览器中打开以下 URL 来启动 Playground:


http://localhost:5000/graphql

# 创建 GraphQL 查询

现在,我们已经完成了 GraphQL-Platform 的安装和配置,我们可以开始定义我们的 GraphQL 查询。让我们创建一个简单的查询来获取所有用户:


public class Query
{
    [GraphQLName("users")]
    [GraphQLDescription("Get all users.")]
    public IEnumerable<User> GetUsers()
    {
        // TODO: Implement logic to get all users.
    }
}

在上面的代码中,我们定义了一个名为 users 的查询,它返回一个 IEnumerable<User> 类型。我们还为查询添加了一个 GraphQLName 属性,以便在 GraphQL Playground 中显示一个更友好的名称。

接下来,我们需要定义 User 类型:


public class User
{
    public int Id { get; set; }
    public string FirstName { get; set; }
    public string LastName { get; set; }
}

现在我们已经定义了我们的查询和类型,我们可以重新启动应用程序,并在 Playground 中测试查询。我们可以使用以下查询来获取所有用户:


query {
  users {
    id
    firstName
    lastName
  }
}

# 添加查询参数

GraphQL-Platform 允许我们向查询添加参数,以便过滤、排序和分页结果。让我们向我们的 GetUsers() 方法添加一个名为 search 的参数来过滤结果:


public class Query
{
    [GraphQLName("users")]
    [GraphQLDescription("Get all users.")]
    public IEnumerable<User> GetUsers(string search)
    {
    // TODO: Implement logic to get users based on search criteria.
    }
}

现在,我们可以重新启动应用程序,并在 Playground 中测试带有搜索参数的查询:

query {
  users(search: "John") {
    id
    firstName
    lastName
  }
}

# 添加 GraphQL 基因库

现在我们已经了解了如何创建和测试 GraphQL 查询,让我们介绍一下 GraphQL 基因库。GraphQL 基因库是一组 .NET 类型,它们提供了一种将现有数据模型转换为 GraphQL 查询的简单方法。GraphQL 基因库还提供了一个可扩展的框架,使开发人员可以轻松地添加自定义逻辑和验证规则。

让我们通过添加 GraphQL 基因库来改进我们的示例。我们将使用 Entity Framework Core(EF Core)作为数据访问层,并使用 GraphQL 基因库自动生成我们的查询。首先,我们需要安装以下 NuGet 包:


Install-Package GraphQL-Genius -Version 3.0.0-preview6
Install-Package GraphQL-Genius.EntityFrameworkCore -Version 3.0.0-preview6

接下来,我们需要定义我们的数据模型和 DbContext:


public class User
{
    public int Id { get; set; }
    public string FirstName { get; set; }
    public string LastName { get; set; }
}

public class UserDbContext : DbContext
{
    public UserDbContext(DbContextOptions<UserDbContext> options)
        : base(options)
    {
    }

    public DbSet<User> Users { get; set; }
}

现在我们已经定义了我们的数据模型和 DbContext,我们可以使用以下代码自动生成我们的查询:


public class Query : EfObjectGraphType<UserDbContext>
{
    public Query(UserDbContext db) : base(db)
    {
        Field<ListGraphType<UserGraphType>>(
            "users",
            resolve: context => db.Users.ToListAsync());
    }
}

在上面的代码中,我们使用 EfObjectGraphType<TContext> 类型作为查询基类,其中 TContext 是我们的 DbContext 类型。然后,我们使用 Field() 方法添加一个名为 users 的字段,并使用 EF Core 异步查询返回所有用户。

现在我们已经定义了我们的查询,我们可以重新启动应用程序,并在 Playground 中测试我们的查询:


query {
  users {
    id
    firstName
    lastName
  }
}

# 添加 GraphQL 突变

到目前为止,我们已经学习了如何创建 GraphQL 查询。现在,让我们学习如何创建 GraphQL 突变。突变允许我们修改数据并在同一请求中返回结果。

让我们创建一个简单的突变来创建新用户。首先,我们需要定义一个输入类型:


public class UserInput
{
    public string FirstName { get; set; }
    public string LastName { get; set; }
}

然后,我们可以使用以下代码定义我们的突变:


public class Mutation
{
    public Mutation(UserDbContext db)
    {
        FieldAsync<UserGraphType>(
            "createUser",
            arguments: new QueryArguments(
                new QueryArgument<NonNullGraphType<UserInputGraphType>> { Name = "user" }
                ),
            resolve: async context =>
            {
                var user = context.GetArgument<User>("user");
                db.Users.Add(user);
                await db.SaveChangesAsync();
                return user;
            });
    }
}

在上面的代码中,我们使用 FieldAsync() 方法添加一个名为 createUser 的突变。我们还定义了一个名为 user 的输入参数,并将其包装在 NonNullGraphType 中,以确保它不为空。然后,我们在突变的解析函数中获取 user 参数,并将其添加到数据库中。最后,我们返回新用户。

现在我们已经定义了我们的突变,我们可以重新启动应用程序,并在 Playground 中测试我们的突变:

mutation {
  createUser(user: { firstName: "John", lastName: "Doe" }) {
    id
    firstName
    lastName
  }
}

# 结论

在本文中,我们介绍了如何在 .NET 中使用 GraphQL-Platform 构建和部署 API。我们学习了如何创建 GraphQL 查询和突变,并介绍了如何使用 GraphQL 基因库自动生成查询。

GraphQL-Platform 提供了一个完整的、开放的和可扩展的解决方案,使开发人员可以轻松地使用 GraphQL API。如果您正在寻找一种快速、安全和可扩展的方法来构建 API,那么 GraphQL-Platform 是一个不错的选择。

上次更新: 2023/04/26, 22:10:06
Zuul
GraphQLdotnet

← Zuul GraphQLdotnet→

Theme by Vdoing | Copyright © 2019-2024 一个大西瓜 | MIT License | 苏ICP备2023013501号
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式