retrofit日下最火的联网请求框架,但是对于我这样的小白,还是不很容易上手的,在此记录,一下自认为不方便的的地方。
1.LOG打印,联网的请求在实际项目中肯定是要打印请求数据,响应数据,接口信息等。这样才会方便以后的调试,但是retrofit没有提供联网的start回调方法,并切那个repson的打印永远是地址值。
此处可以采用自定义okhttp拦截器的方法来实现。代码如下:
OkHttpClient httpClient = new OkHttpClient();
if (BuildConfig.DEBUG) {
HttpLoggingInterceptor logging = new HttpLoggingInterceptor();
logging.setLevel(HttpLoggingInterceptor.Level.BODY);
httpClient = new OkHttpClient.Builder()
<span style="color:#ff6666;">.addInterceptor(logging)</span>
.build();
只需要在
retrofit = new Retrofit.Builder()
.baseUrl(UrlManageCenter.URL_BASE)
.addConverterFactory(GsonConverterFactory.create((gson)))
<span style="color:#ff6666;">.client(httpClient)</span>
.build();
注意此时你的依赖库必须包含
compile 'com.squareup.retrofit2:retrofit:2.0.0-beta4' // retrofit
compile 'com.squareup.okhttp3:logging-interceptor:3.1.2'
compile 'com.squareup.okhttp3:okhttp:3.1.2'
就可以实现 联网的时时打印了。
还有一个问题就是参数的加密,由于项目的接口一旦被抓,所有的参数全部都暴露出来,及其不安全,但是retrofit是将一个DTO实体类来当成一个JsonObject提交后台的,这就不好加密了。
还好retrofit有这个方法:
RequestBody body=RequestBody.create(MediaType.parse("application/json; charset=utf-8"),Sting str);
我们可以使用Gson.tojson的方法将一个DTO的Object转换成一个String,当然此时也就完全可以不使用DTO,看个人。拿到这个String后就可以实施加密处理了,
<pre name="code" class="html"> String objLogin = gson.toJson(dto);
RequestBody body=RequestBody.create(MediaType.parse("application/json; charset=utf-8"),objLogin);
最后将body当作参数请求网络就可以了。
暂且这么多。。。