Java 通过API操作GraphQL
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对象实现查询,需要先构建响应的数据对象和构建响应的数据
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();
}
public static GraphQLFieldDefinition createGraphQLFieldDefinition(GraphQLObjectType userType) {
return GraphQLFieldDefinition.newFieldDefinition()
.name("User")
.type(userType)
// 静态数据
.dataFetcher(new StaticDataFetcher(new User(1L, "测试", 10)))
.build();
}
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中可以获取到参数通过参数实现自定义查询,参数需要按照规范定义
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();
}
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();
}
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定义接口~~
以上就是Java 通过API操作GraphQL的详细内容,更多关于Java 操作GraphQL的资料请关注编程网其它相关文章!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341