无法通过Retrofit获得json响应

时间:2015-12-13 23:27:36

标签: java android json post retrofit

我正在使用改装1.9.0,我尝试使用以下代码以json格式获取响应:

public void Execute(String email, String password, Callback<User> callback) {
    final Callback<User> cb = callback;
    RestAdapter restAdapter = buildRestAdapter();
    System.out.println("Email " + email + " passowrd " + password);
    User user = new User();
    user.setEmail(email);
    user.setPassword(password);
    restAdapter.create(YutonAPI.class).postLogin(
            user,
            new Callback<User>() {
                @Override
                public void success(User user, Response response) {
                    System.out.println("succes");
                    System.out.println(response.getBody());
                }

                @Override
                public void failure(RetrofitError error) {
                    System.out.println("error "+ error);
                }
            });
}

所以这行代码:

System.out.println(response.getBody());

应该以json格式给我一个响应,但它不起作用,因为我得到以下输出:

链接:http://i.imgur.com/mBQs1LL.png

所以这就是我在json格式中的响应应该是这样的:

{
    "user": {
        "image": "https://www.gravatar.com/avatar/e0a190604dc3dd2ee7b66bb95c20ef7f?d=identicon&s=512"
        "email": "a@hotmail.com"
        "name": "a"
        "id": "566dfac21043a31820bf1ae6"
    } -
}

我已经在我的服务器上测试了它,我正在发布帖子请求。您可以在下面看到它的屏幕截图:

链接:http://i.imgur.com/PtEMR12.png

1 个答案:

答案 0 :(得分:3)

这里的问题是response.getBody()会返回一个TypedInputStream对象,由于它不是String,因此无法直接输出。

要阅读TypedInputStream,有以下几个选项:Retrofit callback get response body,最简单的是:

String body = new String(((TypedByteArray) response.getBody()).getBytes());

如果抛出以下错误:

java.lang.ClassCastException: retrofit.client.UrlConnectionClient$TypedInputStream cannot be cast to retrofit.mime.TypedByteArray

然后确保在用于创建服务的RestAdapter上设置.setLogLevel(RestAdapter.LogLevel.FULL)