我试图使用Retrofit2.0.2获得原始响应.
到目前为止,我尝试使用以下代码行打印响应,但它打印的是地址而不是确切的响应正文.
Log.i(“RAW MESSAGE”,response.body().toString());
编译’com.squareup.retrofit2:retrofit:2.0.2′
Retrofit retrofit = new Retrofit.Builder() .baseUrl(BASE_URL) .addConverterFactory(GsonConverterFactory.create()) .build(); GitAPI gitAPI = retrofit.create(GitAPI.class); Call<Addresses> call = gitAPI.getFeed(user); call.enqueue(new Callback<Addresses>() { @OverrIDe public voID onResponse(Response<Addresses> response, Retrofit retrofit) { try { mdisplayDetails.setText(response.body().getSuburbs().get(0).getText()); **Log.i("RAW MESSAGE",response.body().toString());** } catch (Exception e) { mdisplayDetails.setText(e.getMessage()); } mProgressbar.setVisibility(VIEw.INVISIBLE); } @OverrIDe public voID onFailure(Throwable t) { mdisplayDetails.setText(t.getMessage()); mProgressbar.setVisibility(VIEw.INVISIBLE); } });
解决方法:
那是因为它已经通过转换器转换为对象.要获取原始Json,您需要在http客户端上使用拦截器.值得庆幸的是,你不需要编写自己的类,Square已经为你提供了httpLoggingInterceptor类.
在您的应用级gradle上添加此项
compile 'com.squareup.okhttp3:logging-interceptor:3.5.0'
并在你的OkhttpClIEnt中使用它
httpLoggingInterceptor interceptor = new httpLoggingInterceptor();interceptor.setLevel(httpLoggingInterceptor.Level.BODY);OkhttpClIEnt clIEnt = new OkhttpClIEnt.Builder() .addInterceptor(interceptor).build();
不要忘记在Retrofit中更改您的httpClIEnt.
Retrofit retrofit = new Retrofit.Builder() .clIEnt(clIEnt) .baseUrl("https://yourAPI.com/API/") .build();
在Log Cat中,您将看到原始Json响应.更多信息可在Square的OkHttp github上获得.
警告!
不要忘记在生产中删除拦截器(或将记录级别更改为NONE)!否则,人们将能够在Log Cat上看到您的请求和响应.
总结以上是内存溢出为你收集整理的如何使用Retrofit 2.0获取原始响应和请求全部内容,希望文章能够帮你解决如何使用Retrofit 2.0获取原始响应和请求所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)