2015-10-21 85 views
0

我目前有一個問題,我無法查看改造請求的完整響應,只有一切似乎。Android Retrofit 2得到全身響應

我ApiManager:

public class ApiManager { 

public interface AmbiApi { 

    @POST("users/register") 
    Call<User> registerUser(@Body User user); 
} 

private static final String API_URL = "http://api.staging.ambiapp.com/v1/"; 

private static final Retrofit RETROFIT = new Retrofit.Builder() 
     .baseUrl(API_URL) 
     .addConverterFactory(GsonConverterFactory.create()) 
     .build(); 

private static final AmbiApi AMBI_API = RETROFIT.create(AmbiApi.class); 

public static AmbiApi getApi() { 
    return AMBI_API; 
} 

使得API調用:

Call<User> registerUserCall = ApiManager.getApi().registerUser(user); 
registerUserCall.enqueue(registerCallback); 

回調:

@Override 
public void onResponse(Response<User> response, Retrofit retrofit) { 
    Log.e("LOG", "Retrofit Response: " + response.raw().toString()); 
} 

@Override 
public void onFailure(Throwable t) { 
    // 
} 

現在,當前呼叫只輸出:

Retrofit Response: Response{protocol=http/1.1, code=500, message=Internal Server Error, url=http://api.staging.ambiapp.com/v1/users/register} 

這是因爲我知道什麼是錯誤的,但無論錯誤是否包含在響應中,我只是無法確定如何看到內部服務器錯誤是什麼。

任何幫助,將不勝感激

回答

1
@Override 
public void onResponse(Response<User> response, Retrofit retrofit) { 

    if (!response.isSuccess()) { 
     try { 
      Log.e("LOG", "Retrofit Response: " + response.errorBody().string()); 
     } catch (IOException e) { 
      e.printStackTrace(); 
     } 
    } 
} 

我傻

0

我強烈建議你使用OkHttpHttpLoggingInterceptor

+0

我不能包括在我的項目?當試圖向我的依賴 –

+0

添加'compile'c​​om.squareup.okhttp:logging-interceptor:2.5.0''時,只是在解決錯誤時才解決錯誤,它僅在2.6.0-SNAPSHOT版本中可用 –

0

這是我用來捕獲改造2錯誤的方法。

Call List<data> call=MyService.loadData(); 
    call.enqueue(new Callback<List<data>>() { 
      @Override 
      public void onResponse(Response<List<data>> response, Retrofit retrofit) { 
       if (response.isSuccess()) { 
        //Response success. Handle data here 
           } 
           else{ 
          //For getting error message 
        Log.d("Error message",response.response.raw().message()); 
          //For getting error code. Code is integer value like 200,404 etc 
        Log.d("Error code",String.valueOf(response.response.raw().code()));   
           } 
      } 


      @Override 
      public void onFailure(Throwable t) { 
       if (t instanceof IOException){ 
         //Add your code for displaying no network connection error 
          } 
      } 
     }); 
0

改造2

// create upload service client 
    APIInterface service = 
      ServiceGenerator.createService(APIInterface.class); 

Call<SubmitFormModel> call = service.upload(description, body, STATE_CD); 

call.enqueue(new Callback<SubmitFormModel>() { 
     @Override 
     public void onResponse(Call<SubmitFormModel> call, 
           Response<SubmitFormModel> response) { 
      Log.v("Upload", "success"); 

      if (mProgressDialog != null && mProgressDialog.isShowing()) 
       mProgressDialog.dismiss(); 

      System.out.println("response call " + call); 
      System.out.println("response Response " + response.body().toString()); 

      SubmitFormModel result = response.body(); 
      System.out.println("response message " + result.getResponseData().getMessage()); 

       /* Create an Intent that will start the next Activity. */ 
      Intent mainIntent = new Intent(CaptureImgUpload.this 
        , SuccessScreenActivity.class); 
      CaptureImgUpload.this.startActivity(mainIntent); 

     } 

客戶爲目標代碼格式

public class SubmitFormModel { 

private int statusCode; 
private String status; 
private ResponseData responseData; 

public String getStatus() { 
    return status; 
} 

public void setStatus(String status) { 
    this.status = status; 
} 

public int getStatusCode() { 
    return statusCode; 
} 

public void setStatusCode(int statusCode) { 
    this.statusCode = statusCode; 
} 

public ResponseData getResponseData() { 
    return responseData; 
} 

public void setResponseData(ResponseData responseData) { 
    this.responseData = responseData; 
} 

public class ResponseData { 

    private String message; 
    public Data data; 

    public String getMessage() { 
     return message; 
    } 

    public void setMessage(String message) { 
     this.message = message; 
    } 

    public Data getData() { 
     return data; 
    } 

    public void setData(Data data) { 
     this.data = data; 
    } 
} 

public class Data { 

    private int application_id; 

    public int getApplication_id() { 
     return application_id; 
    } 
    public void setApplication_id(int application_id) { 
     this.application_id = application_id; 
    } 
} 

}