apollo-android 在请求中不提供变量

Posted

技术标签:

【中文标题】apollo-android 在请求中不提供变量【英文标题】:apollo-android does not provide variables in request 【发布时间】:2018-08-11 15:09:17 【问题描述】:

我使用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 和 Consuming Code 没有太大不同,我真的不知道我的错误在哪里.

提前致谢,感谢每一个帮助!

【问题讨论】:

【参考方案1】:

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

【讨论】:

我真的浪费了 1 天半的时间,非常感谢您回答您自己的问题。

以上是关于apollo-android 在请求中不提供变量的主要内容,如果未能解决你的问题,请参考以下文章

apollo-android可以用作java客户端吗?

如何在 GraphQL apollo-android 客户端中获取 HTTP 状态码

类变量分配在 Alamofire 请求块中不起作用

JSON stringify 中的变量在 Rest 请求中不起作用

api 请求中不接受 REACT.js 变量

是否可以将 apollo-android v2 与 Gradle 5 一起使用?