我正在尝试使用GraphQL -spring starter构建graphql服务器,并对阿波罗跟踪(https://github.com/apollographql/apollo-tracing)感兴趣,后者在扩展中的跟踪键下添加了额外的数据。
在我添加跟踪工具之后,我的响应没有任何变化。我是不是漏掉了什么?
请求:
query getalllink{
allLinks(filter:{description_contains:"ab"}){
url,
postedBy {
id
,name
}
}
}答复:
{
"data": {
"allLinks": [
{
"url": "1a",
"postedBy": {
"id": "1",
"name": "1"
}
}
]
}我提供了TracingInstrumentation豆。豆子也是被GraphQLWebAutoConfiguration捡到的。
我尝试在GraphQLWebAutoConfiguration上调试并命中一个断点,该工具已经添加到GraphQLServlet bean中。
下面是有关我的示例项目的一些详细信息:
@SpringBootApplication
public class DemographqlApplication {
public static void main(String[] args) {
SpringApplication.run(DemographqlApplication.class, args);
}
@Bean
Instrumentation instrumentation() {
return new TracingInstrumentation();
}
}resources/graphql/schema.graphqls
schema {
query: Query
}
type Query {
allLinks: [Link]
}
type Link {
id: ID!
url: String!
description: String
postedBy: User
}
type User {
id: ID!
name: String!
}User和Link的实体和存储库
Resolver和Query Resolver:
@Component
public class LinkResolver implements GraphQLResolver<Link> {
@Autowired
private final UserRepository userRepository;
LinkResolver(UserRepository userRepository) {
this.userRepository = userRepository;
}
public User postedBy(Link link) {
if (link.getUserId() == null) {
return null;
}
return userRepository.findOne(link.getUserId());
}
}
@Component
public class Query implements GraphQLQueryResolver {
private final LinkRepository linkRepository;
@Autowired
public Query(LinkRepository linkRepository) {
this.linkRepository = linkRepository;
}
public List<Link> allLinks() {
return linkRepository.findAll());
}
}build.gradle
dependencies {
compile('org.springframework.boot:spring-boot-starter-web')
testCompile('org.springframework.boot:spring-boot-starter-test')
compile('org.springframework.boot:spring-boot-starter-data-jpa')
compile 'com.graphql-java:graphql-spring-boot-starter:3.10.0'
compile 'com.graphql-java:graphql-java-tools:4.3.0'
compile 'javax.xml.bind:jaxb-api:2.3.0'
compile 'com.h2database:h2'
// to embed GraphiQL tool
compile 'com.graphql-java:graphiql-spring-boot-starter:3.10.0'
compile 'org.springframework.boot:spring-boot-starter-data-jpa'
// Use MySQL Connector-J
compile 'mysql:mysql-connector-java'
}谢谢。
发布于 2018-01-31 17:18:08
我今天也面临着同样的问题。我打开源代码是为了了解出了什么问题。
这个问题与的版本有关。4.6.0的GraphQLServlet.java代码片段:
final ExecutionResult executionResult = newGraphQL(schema).execute(new ExecutionInput(query, operationName, context, rootObject, transformVariables(schema, query, variables)));
final List<GraphQLError> errors = executionResult.getErrors();
final Object data = executionResult.getData();
final String response = getMapper().writeValueAsString(createResultFromDataAndErrors(data, errors));executionResult包含扩展(executionResult#getExtensions),因此TracingInstrumentation完成了工作。但是如您所见,响应只考虑数据和错误(但不考虑扩展)。这就是为什么跟踪工具值没有添加到响应中的原因。
如果您查看graphql (https://github.com/graphql-java/graphql-java-servlet/blob/master/src/main/java/graphql/servlet/GraphQLServlet.java)的分支母版,您将看到扩展被考虑在内。我不知道这个版本是否已经发布到maven central。
在我的项目中,我使用了graphql-spring starter 3.10.0,我只是在gradle配置中添加了正确的依赖项:
compile "com.graphql-java:graphql-java-servlet:4.7.0"现在它起作用了:我可以使用GraphiQL或更好的GraphQL Plauyground 1.4.2来跟踪所有信息
希望它能帮上忙
https://stackoverflow.com/questions/48273780
复制相似问题