这个问题导致返回的数据一致报空指针,记录一下
我后来加了Log.d
比如这样写:那么只有在第一次Log.d那行,才能得到response.body().string()数据
而下面的if中和msg.obj都得不到,所以导致最后在handlerMessage中报空指针异常
public void onResponse(okhttp3.Call call, okhttp3.Response response) throws IOException {
Log.d("Json数据",response.body().string());
if(response.body().string().indexOf("Success") != -1) {
mACache.put(param, response.body().string(), ACache.TIME_DAY);
Message msg = Message.obtain();
msg.what = 1;
msg.obj = response.body().string();
mHandler.sendMessage(msg);
}
}
});
正确的写法就是第一次把他赋给json,得到这个值,就用json,然后这样response.body().string()就只用了一次
public void onResponse(okhttp3.Call call, okhttp3.Response response) throws IOException {
String json = response.body().string();
Log.d("Json数据",json);
if(json.indexOf("Success") != -1) {
mACache.put(param, response.body().string(), ACache.TIME_DAY);
Message msg = Message.obtain();
msg.what = 1;
msg.obj = json;
mHandler.sendMessage(msg);
}
}
});
记录下来,以后查阅