Java 通过API操作GraphQL

作者:唐宋XY 时间:2021-12-24 03:21:49 

目录
  • 引入依赖

  • Java中使用GraphQL的API

    • 无参数简单查询

    • 带参数简单查询

GraphQL可以通过Java的API来实现数据的查询,通过特定的SDL查询语句,获取特定的查询数据。相当于后端作为提供数据源的"数据库",前端根据定义的SDL语句查询需要的数据,将查询数据的控制权交给前端,提高后端接口的通用性和灵活性

引入依赖


<dependency>
   <groupId>com.graphql-java</groupId>
   <artifactId>graphql-java</artifactId>
   <version>11.0</version>
</dependency>

需要配置第三方的maven仓库才可以下载这个jar包,要不然从中央仓库无法下载。

官方网站,在快速开始中有需要配置的仓库www.graphql-java.com

Java中使用GraphQL的API

根据定义的简单查询语法通过Java的API查询数据

无参数简单查询

通过定义的查询格式,通过GraphQL对象实现查询,需要先构建响应的数据对象和构建响应的数据


/**
* 简单展示 GraphQL的查询,以及通过JavaAPI响应数据
*/
public class GraphQLSimpleDemo {

public static void main(String[] args) {
       // 定义数据响应对象
       GraphQLObjectType userType = createGraphQLObjectType();
       // 根据定义的数据响应对象构建响应的数据
       GraphQLFieldDefinition userDefinition = createGraphQLFieldDefinition(userType);
       // 创建查询响应
       GraphQLSchema graphQLSchema = createGraphQLSchema(userDefinition);
       GraphQL graphQL = GraphQL.newGraphQL(graphQLSchema).build();

// 查询语句
       String graph1 = "{User{id, name}}";
       // 查询多个字段
       String graph2 = "{User{id, name, age}}";

// 执行查询
       ExecutionResult execute = graphQL.execute(graph1);
       // 获取结果
       System.out.println(execute.toSpecification());

// 执行查询
       ExecutionResult execute2 = graphQL.execute(graph2);
       // 获取结果
       System.out.println(execute2.toSpecification());
   }

// 创建GraphQLSchema
   public static GraphQLSchema createGraphQLSchema(GraphQLFieldDefinition userDefinition) {
       GraphQLObjectType userQuery = GraphQLObjectType.newObject()
                                                              .name("userQuery")
                                                              .field(userDefinition)
                                                              .build();
       return GraphQLSchema.newSchema().query(userQuery).build();
   }

/**
    * 创建GraphQLFieldDefinition对象
    *
    * 根据定义的查询对象做真正的查询,返回查询数据
    *
    * 这里使用静态对象构建数据,如果是查询数据,可以在这里进行做查询
    *
    */
   public static GraphQLFieldDefinition createGraphQLFieldDefinition(GraphQLObjectType userType) {
       return GraphQLFieldDefinition.newFieldDefinition()
               .name("User")
               .type(userType)
               // 静态数据
               .dataFetcher(new StaticDataFetcher(new User(1L, "测试", 10)))
               .build();
   }

/**
    * 定义GraphQLObjectType对象
    * 该对象是用来做查询响应对象的名称和查询的字段的定义
    */
   public static GraphQLObjectType createGraphQLObjectType() {
       return GraphQLObjectType.newObject()
               .name("User")
               .field(GraphQLFieldDefinition.newFieldDefinition().name("id").type(Scalars.GraphQLLong))
               .field(GraphQLFieldDefinition.newFieldDefinition().name("name").type(Scalars.GraphQLString))
               .field(GraphQLFieldDefinition.newFieldDefinition().name("age").type(Scalars.GraphQLInt))
               .build();
   }

}

带参数简单查询

自定义的查询规范中,可以通过定义参数实现查询,在API中可以获取到参数通过参数实现自定义查询,参数需要按照规范定义


/**
* 简单展示 GraphQL的查询,以及通过JavaAPI响应数据
*
* 传递参数进行查询
*/
public class GraphQLSimpleDemoWithArgs {

public static void main(String[] args) {
       GraphQLObjectType userType = createGraphQLObjectType();
       GraphQLFieldDefinition userDefinition = createGraphQLFieldDefinition(userType);
       GraphQLSchema graphQLSchema = createGraphQLSchema(userDefinition);
       GraphQL graphQL = GraphQL.newGraphQL(graphQLSchema).build();

String graph3 = "{User(id:1){id, name, age}}";
       ExecutionResult execute3 = graphQL.execute(graph3);
       // 获取结果
       System.out.println(execute3.toSpecification());
   }

// 创建GraphQLSchema
   public static GraphQLSchema createGraphQLSchema(GraphQLFieldDefinition userDefinition) {
       GraphQLObjectType userQuery = GraphQLObjectType.newObject()
                                                              .name("userQuery")
                                                              .field(userDefinition)
                                                              .build();
       return GraphQLSchema.newSchema().query(userQuery).build();
   }

/**
    * 创建GraphQLFieldDefinition对象
    *
    * 根据定义的查询对象做真正的查询,返回查询数据
    *
    * 这里使用静态对象构建数据,如果是查询数据,可以在这里进行做查询
    *
    */
   public static GraphQLFieldDefinition createGraphQLFieldDefinition(GraphQLObjectType userType) {
       return GraphQLFieldDefinition.newFieldDefinition()
               .name("User")
               .type(userType)
               // 设置参数查询数据
               .argument(GraphQLArgument.newArgument().name("id").type(Scalars.GraphQLLong).build())
               .dataFetcher(environment -> {
                   Long id = environment.getArgument("id");
                   return new User(id, "name" + id, id.intValue());
               })

.build();
   }

/**
    * 定义GraphQLObjectType对象
    * 该对象是用来做查询响应对象的名称和查询的字段的定义
    */
   public static GraphQLObjectType createGraphQLObjectType() {
       return GraphQLObjectType.newObject()
               .name("User")
               .field(GraphQLFieldDefinition.newFieldDefinition().name("id").type(Scalars.GraphQLLong))
               .field(GraphQLFieldDefinition.newFieldDefinition().name("name").type(Scalars.GraphQLString))
               .field(GraphQLFieldDefinition.newFieldDefinition().name("age").type(Scalars.GraphQLInt))
               .build();
   }

}

上面两个关于GraphQL的简单示例,一个是没有参数的查询,一个是通过传递参数的查询,可以看出来,GraphQL的在查询数据的控制权交给定义的查询语句,GraphQL构建的数据作为基础的数据源,如果使用GraphQL定义的接口具有灵活性和通用性,但是可以看出来,在使用方面也是较为复杂,并且接口多和较为复杂的情况下,相对于Restful来讲,较为复杂,两种方式各有优缺点

下一篇,将简单示例在Springboot中使用GraphQL定义接口~~

来源:https://juejin.cn/post/6915807665121656845

标签:Java,GraphQL,API
0
投稿

猜你喜欢

  • Java Valhalla Project项目介绍

    2021-10-03 00:29:28
  • seata-1.4.0安装及在springcloud中使用详解

    2023-02-21 00:49:21
  • java Mail邮件接收工具类

    2022-04-24 14:17:17
  • 关于idea中Java Web项目的访问路径问题

    2023-01-04 21:23:32
  • java版十大排序经典算法:完整代码(3)

    2021-07-17 05:09:09
  • C#中事件处理的个人体会

    2023-11-02 02:14:39
  • 详解java8在Collection中新增加的方法removeIf

    2022-06-04 20:51:45
  • C#中数组初始化与数组元素复制的方法

    2023-05-14 15:45:06
  • C#调用海康工业相机SDK采集图像并在Halcon窗口中显示方式

    2022-06-26 00:48:02
  • C#集合之字典的用法

    2022-04-11 23:27:19
  • C#使用Ado.net读取Excel表的方法

    2022-04-22 02:01:47
  • 浅析Java中的GC垃圾回收器的意义及与GC的交互

    2022-11-10 13:07:05
  • 深入浅析jni中的java接口使用

    2023-07-22 19:54:23
  • 关于Java中@SuppressWarnings的正确使用方法

    2023-07-22 17:17:58
  • 使用SpringBoot配置多数据源的经验分享

    2022-05-25 04:02:57
  • 如何利用JAVA实现走迷宫程序

    2022-06-23 10:52:06
  • Android滑动拼图验证码控件使用方法详解

    2021-10-03 02:56:06
  • java easyUI实现自定义网格视图实例代码

    2022-05-16 23:52:54
  • sprng和struts有什么区别?

    2022-03-02 02:13:35
  • C#自定义画刷原理解析

    2021-06-19 19:17:32
  • asp之家 软件编程 m.aspxhome.com