【发布时间】:2021-03-14 05:44:33
【问题描述】:
我使用 retrofit2 连接到一个 api 并接收数据 数据是嵌套的
D/OkHttp: {"success":{"token":"eyJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiJ9}}
如果数据如上例所示,正常接收 但是如果是如下,就报错了
D/OkHttp: {"message":"Unauthenticated."}
我在第一个例子中这样做
data class Response(var success : AutoLoginUser)
data class AutoLoginUser(var token: String)
...
...
...
Log.w("OK FROM SERVER", response.body()!!.success!!.token)
对于第二个示例,我执行以下操作
data class UserDetails(var message : String)
...
...
...
Log.w("OK FROM SERVER", response.body()!!.message)
第二个例子的错误
D/OkHttp: <-- 401 Unauthorized http://192.168.1.8/api/details (252ms)
Host: 192.168.1.8
Date: Wed, 02 Dec 2020 09:01:03 GMT
Connection: close
X-Powered-By: PHP/7.4.12
Cache-Control: no-cache, private
Date: Wed, 02 Dec 2020 09:01:03 GMT
Content-Type: application/json
Access-Control-Allow-Origin: *
D/OkHttp: {"message":"Unauthenticated."}
<-- END HTTP (30-byte body)
D/AndroidRuntime: Shutting down VM
E/AndroidRuntime: FATAL EXCEPTION: main
Process: ir.i9i.splendor, PID: 5740
java.lang.NullPointerException
at ir.i9i.splendor.Profile$getUserDetails$1.onResponse(Profile.kt:39)
at retrofit2.ExecutorCallAdapterFactory$ExecutorCallbackCall$1$1.run(ExecutorCallAdapterFactory.java:70)
at android.os.Handler.handleCallback(Handler.java:739)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:135)
at android.app.ActivityThread.main(ActivityThread.java:5254)
at java.lang.reflect.Method.invoke(Native Method)
at java.lang.reflect.Method.invoke(Method.java:372)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:903)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:698)
【问题讨论】:
-
不清楚问题所在,但您应该在标头中附加 API 令牌吗?
-
@lbasek 我明白token是错误的,我想得到消息
-
如果您使用 Retrofit2,请尝试使用
response.errorBody()检查响应。
标签: android kotlin retrofit retrofit2 retrofit2.6