apollo-android不在请求

时间:2018-03-03 14:53:18

标签: java android graphql express-graphql apollo-android

我使用apollo-server-express来设置具有以下架构的GraphQL服务器:

input IGetUser {
    email: String
    ID: String
    UserID: Int!
}
interface Entity {
    createdAt: String
    updatedAt: String
}
schema {
    query: Query
}
type Query {
    getUser(params:IGetUser): User!
}
type User implements Entity {
    UserID: Int!
    firstName: String!
    lastName: String
    email: String!
    ID: String
    ...
    confirmed: Boolean!
    createdAt: String!
    updatedAt: String!
}

基本上User类型表示我的MySQL数据库中的表。服务器完全可以运行。这是我的查询

query GetUserQuery($UserID: Int!, $email: String, $ID: String) {
    getUser(params:{ email: $email, ID: $ID, UserID: $UserID }) {
        ...UserDetails
        ...EntityDetails
    }
}
fragment EntityDetails on Entity {
    createdAt
    updatedAt
}
fragment UserDetails on User {
    UserID
    firstName
    lastName
    email
    ID
    ...
    confirmed
}

注意我缩短了User类型和UserDetails片段。

查询位于我的Android Studio项目中,apollo-android插件正确生成Java对象。我正在尝试获取ID为1的用户。我的Java代码如下所示:

RestClient.getInstance(getApplicationContext())
    .getApolloClient(getString(R.string.urlGraphQLEndpoint))
    .query(
        GetUserQuery.builder()
            .userID(userID) // userID = 1 is a local variable
            .build()
    )
    .httpCachePolicy(HttpCachePolicy.NETWORK_ONLY)
    .enqueue(new ApolloCall.Callback<GetUserQuery.Data>() {
        @Override
        public void onFailure(@Nonnull ApolloException e) {
            Log.e(TAG, e.getMessage(), e);
        }

        @Override
        public void onResponse(@Nonnull Response<GetUserQuery.Data> response) {
            // Doesn't matter
        }
    })

RestClient类是Singleton,它提供对ApolloClient实例的访问,资源字符串urlGraphQLEndpoint指向我本地GraphQL服务器的IP地址和端口: http://10.0.2.2:3000/graphql。当我尝试执行我的Android应用程序时,收到以下错误消息:

HTTP 400 Bad Request
com.apollographql.apollo.exception.ApolloHttpException: HTTP 400 Bad Request
    at com.apollographql.apollo.internal.interceptor.ApolloParseInterceptor.parse(ApolloParseInterceptor.java:105)
    at com.apollographql.apollo.internal.interceptor.ApolloParseInterceptor.access$100(ApolloParseInterceptor.java:28)
    at com.apollographql.apollo.internal.interceptor.ApolloParseInterceptor$1.onResponse(ApolloParseInterceptor.java:53)
    at com.apollographql.apollo.internal.interceptor.ApolloServerInterceptor$1$1.onResponse(ApolloServerInterceptor.java:93)
    at okhttp3.RealCall$AsyncCall.execute(RealCall.java:153)
    at okhttp3.internal.NamedRunnable.run(NamedRunnable.java:32)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1162)
    at java.util.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:636)
    at java.lang.Thread.run(Thread.java:764)

在服务器端,我收到以下控制台日志:

GraphQLError: Variable "$UserID" of requiredtype "Int!" was not provided!
    at getVariableValues ...

当我尝试完全相同的查询时,apollo-android客户端应该使用GraphiQL,一切正常,我收到ID为1的用户。对我来说,似乎是apollo-android lib的内部错误,但是因为我的Java代码和我的GraphQL查询与apollo-android示例Generate Code using Apollo和{{3}看起来并不相同我真的不知道我的错误在哪里。

在此先感谢,我感谢您的一切帮助!

1 个答案:

答案 0 :(得分:0)

我发现了错误......正如您在查询中看到的那样,我在一些变量的开头使用大写字母。 apollo-android区分大小写,就像它应该的那样,但它忽略变量开头的大写字母并将它们转换为小写字母。 在Postman代理的帮助下,我能够检查我的应用程序的网络请求,并看到变量仍然是小写字母。