gpt4 book ai didi

java - graphql java : global dataFetcher and dynamic object

转载 作者:太空宇宙 更新时间:2023-11-04 11:12:26 24 4
gpt4 key购买 nike

我正在尝试像 REST API 客户端一样使用 GraphQL。我的后端返回 JSON,但在我的应用程序客户端中,我编写 graphQL,并在客户端中将 graphQL 查询转换为 HTTP 调用。

我的架构:

type Query {
students: [Student]
}
type Student {
name: String
}

POJO 示例:

public class Student {
private Integer id;
private String name;
}

我的解析器:

public class Query implements GraphQLQueryResolver {
public List<Post> students() {
// HTTP Request
}
}

在所有库的实现中,我需要为 Student 创建一个 POJO,并在我的 API 中为请求编写一个解析器。

是否存在不需要创建 POJO 和创建全局执行解析器的方法?

最佳答案

如果您使用像 graphql-java-tools 这样的库(似乎是这种情况),您需要 POJO,因为这是库获取其类型映射的地方。但如果您只是使用 graphql-java 本身,您可以以任何您喜欢的方式连接它 - 包括拥有一个全局解析器(即 DataFetcher)。

有关如何执行此操作的想法,请参阅 http://graphql-java.readthedocs.io/en/latest/schema.html#idl

你想要这样的东西:

SchemaParser schemaParser = new SchemaParser();
SchemaGenerator schemaGenerator = new SchemaGenerator();

File schemaFile = loadSchema("yourStudentSchema.graphqls");

TypeDefinitionRegistry typeRegistry = schemaParser.parse(schemaFile);
RuntimeWiring wiring = buildRuntimeWiring();
GraphQLSchema graphQLSchema = schemaGenerator.makeExecutableSchema(typeRegistry, wiring);

RuntimeWiring 是挂接解析器的地方,例如:

RuntimeWiring buildRuntimeWiring() {
return RuntimeWiring.newRuntimeWiring()
// this uses builder function lambda syntax
.type("Query", typeWiring -> typeWiring
.dataFetcher("students", env -> fetchDataSomeHow(env)))
.build();
}

因此,您可以为每个 dataFetcher 调用提供相同的 DataFetcher 实现,这就是您所追求的。 graphql-java 本身不对它的连接和实现方式做出任何假设,例如它不强制执行 POJO 或其他任何内容。

关于java - graphql java : global dataFetcher and dynamic object,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45852050/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com