我用Postman发送以下Body数据返回的结果正常(以原始JSON格式):
{"payload":{"email":"","username":"","password":""}}
但是当我尝试通过Retrofit发送时,它不起作用(返回500错误):
public Observable<JsonObject> signup(String email, String userName, String password) {
JsonObject data = new JsonObject();
JsonObject payload = new JsonObject();
data.addProperty("email", email);
data.addProperty("username", userName);
data.addProperty("password", password);
payload.add("payload", data);
return mShoutApiService.signup(payload);
}
以下是服务调用和适配器:
服务:
@POST("/signup")
Observable<JsonObject> signup(@Body JsonObject payload);
适配器:
private RestAdapter createRestAdapter(String hostUrl, GsonConverter gsonConverter, OkClient okClient) {
return new RestAdapter.Builder()
.setClient(okClient)
.setConverter(gsonConverter)
.setEndpoint(hostUrl)
.setLogLevel(LogLevel.FULL)
.setLog(new AndroidLog("SHOUT_LOG"))
.build();
}
private GsonConverter getGsonConverter(Gson gson) {
return new GsonConverter(gson);
}
private OkClient getOkClient() {
OkHttpClient okHttpClient = new OkHttpClient();
okHttpClient.setReadTimeout(READ_TIMEOUT, TimeUnit.SECONDS);
okHttpClient.setConnectTimeout(CONNECT_TIMEOUT, TimeUnit.SECONDS);
return new OkClient(okHttpClient);
}
日志如下所示
03-23 05:04:00.380 2442-3468/shout.surge.com.shout D/SHOUT_LOG: ---> HTTP POST http://shout-api.herokuapp.com/signup
03-23 05:04:00.380 2442-3468/shout.surge.com.shout D/SHOUT_LOG: Content-Type: application/json; charset=UTF-8
03-23 05:04:00.380 2442-3468/shout.surge.com.shout D/SHOUT_LOG: Content-Length: 52
03-23 05:04:00.384 2442-3468/shout.surge.com.shout D/SHOUT_LOG: {"payload":{"email":"","username":"","password":""}}
03-23 05:04:00.384 2442-3468/shout.surge.com.shout D/SHOUT_LOG: ---> END HTTP (52-byte body)
03-23 05:04:09.180 2442-3468/shout.surge.com.shout D/SHOUT_LOG: <--- HTTP 500 http://shout-api.herokuapp.com/signup (8796ms)
看起来它们是完全相同的调用,但出现在我的移动应用程序中失败了。请问我错过了什么东西?任何见解都将是极好的!
03-22 02:16:20.326 2427-2661/shout.surge.com.shout D/SHOUT_LOG: Content-Type: text/html; charset=utf-8
如果我使用@Header或使用TypedInput作为正文,这不会改变。 - 1tSurge