【发布时间】:2017-12-05 11:31:52
【问题描述】:
我为调试和发布设置了相同的构建类型,
buildTypes {
debug {
buildConfigField "String", "API_BASE_URL", "\"https://www.testUrl.com/api/\""
minifyEnabled true
shrinkResources true
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
signingConfig signingConfigs.release_key
}
release {
buildConfigField "String", "API_BASE_URL", "\"https://www.testUrl.com/api/\""
minifyEnabled true
shrinkResources true
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
signingConfig signingConfigs.release_key
}
}
但如果我使用该版本进行构建,则会出现以下错误。 此外,服务器响应完全相同。
W/System.err: java.lang.NullPointerException: The mapper function returned a null value.
W/System.err: at b.a.e.b.b.a(Unknown Source)
W/System.err: at b.a.e.e.b.bs$a.onNext(Unknown Source)
W/System.err: at b.a.e.e.b.cm$a.onNext(Unknown Source)
W/System.err: at retrofit2.adapter.rxjava2.BodyObservable$BodyObserver.onNext(Unknown Source)
W/System.err: at retrofit2.adapter.rxjava2.BodyObservable$BodyObserver.onNext(Unknown Source)
W/System.err: at retrofit2.adapter.rxjava2.CallExecuteObservable.subscribeActual(Unknown Source)
W/System.err: at b.a.l.subscribe(Unknown Source)
W/System.err: at retrofit2.adapter.rxjava2.BodyObservable.subscribeActual(Unknown Source)
W/System.err: at b.a.l.subscribe(Unknown Source)
W/System.err: at b.a.e.e.b.cm$a.a(Unknown Source)
W/System.err: at b.a.e.e.b.cm.subscribeActual(Unknown Source)
W/System.err: at b.a.l.subscribe(Unknown Source)
W/System.err: at b.a.e.e.b.bs.subscribeActual(Unknown Source)
W/System.err: at b.a.l.subscribe(Unknown Source)
W/System.err: at b.a.e.e.b.bw.subscribeActual(Unknown Source)
W/System.err: at b.a.l.subscribe(Unknown Source)
W/System.err: at b.a.e.e.b.dd$b.run(Unknown Source)
W/System.err: at b.a.s$a.run(Unknown Source)
W/System.err: at b.a.e.g.j.run(Unknown Source)
W/System.err: at b.a.e.g.j.call(Unknown Source)
W/System.err: at java.util.concurrent.FutureTask.run(FutureTask.java:237)
W/System.err: at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.run(ScheduledThreadPoolExecutor.java:272)
W/System.err: at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1133)
W/System.err: at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:607)
W/System.err: at java.lang.Thread.run(Thread.java:761)
【问题讨论】:
-
您能否尝试在禁用 proguard 的发布版本上重现该问题?
-
@MichaelDodd 是的,它可以在禁用 proguard 的情况下使用!那么它在调试模式下是如何工作的呢?它具有相同的 proguard 集。你能看看我的proguard-rules吗?
-
Retrofit2 calls sometimes result in 一个
null正文,然后无条件转发到 RxJava。您必须使用完整的Response<T>而不是直接检索。
标签: java android rx-java retrofit2 rx-java2