使用Retrofit打印请求日志,过滤改变服务器返回结果,直接获取String字符串直接获取字符串手动解析查看Retrofit请求网络日志自定义Interceptor实现过滤改变请求返回的数据(可使用

Retrofit框架越来越流行了,Retrofit是基于OKHTTP的大家都知道,在之前的话,在Retrofit1.x的时候,是必须要自己手动导入OKHTTP 和 OKio的包的,因为Retrofit依赖于这两个库的。但是自从升级了Retrofit2之后,就可以不用手动导入了,因为已经自己引入了。

Retrofit有一个优点,就是可以自动根据获取到的数据转换成相对应的Bean,它内部提供了一个转换机制,只需要你重写,就能写出自己的转换规则。

dependencies {
    compile 'com.squareup.retrofit2:retrofit:2.2.0'
    compile 'com.squareup.retrofit2:converter-scalars:2.0.0'
    compile 'com.squareup.retrofit2:converter-gson:2.0.2'
    compile 'com.google.code.gson:gson:2.7'
    compile 'com.squareup.okhttp3:logging-interceptor:3.4.1'
    }

可以看到,我上面引入了Retrofit2的库

compile 'com.squareup.retrofit2:retrofit:2.2.0' 但是除了这个份之外,我还引入了其他的。

这两个,是在从请求Json数据到Bean需要使用到的。依赖了谷歌的Gson库

compile 'com.squareup.retrofit2:converter-gson:2.0.2'
compile 'com.google.code.gson:gson:2.7'

直接获取字符串手动解析

除了这种情况,我们经常会因为后台传来的数据的不稳定性,我们需要自己手动去解析字符串,那么就引入了这个 compile 'com.squareup.retrofit2:converter-scalars:2.0.0'

使用方式好简单:

new Retrofit.Builder()  //01:获取Retrofit对象
.baseUrl(Globals.SERVER_ADDRESS) //02采用链式结构绑定Base url
.addConverterFactory(ScalarsConverterFactory.create())//首先判断是否需要转换成字符串,简单类型
.addConverterFactory(GsonConverterFactory.create())//再将转换成bean
.client(okHttpClient)
.build();//03执行操作
public interface StartPageNet
{
    @GET("hao123-soft-online-bcs/soft/2017_02_22_W.P.S.5041.19.552.exe")
    public Call<String> getIndex();
}

首先在这里定义,Call<String> 里的泛型可以写这几种类型:

if (type == String.class
        || type == boolean.class
        || type == Boolean.class
        || type == byte.class
        || type == Byte.class
        || type == char.class
        || type == Character.class
        || type == double.class
        || type == Double.class
        || type == float.class
        || type == Float.class
        || type == int.class
        || type == Integer.class
        || type == long.class
        || type == Long.class
        || type == short.class
        || type == Short.class) {
      return ScalarRequestBodyConverter.INSTANCE;
    }

这里会自动根据返回数据转换成你泛型里写的类型的数据。

 StartPageNet startPageNet = streamRetrofit.create(StartPageNet.class);
 Call<String> download = startPageNet.getIndex();
 download.enqueue(new Callback<String>()
 {
     @Override
     public void onResponse(Call<String> call, Response<String> response)
     {
         String result = response.body();
     }
     @Override
     public void onFailure(Call<String> call, Throwable t)
     {

     }
});

查看Retrofit请求网络日志

有时候需要随时查看网络请求日志,我们这里可以利用OKHttpInterceptor机制 上面我们引入了这个库: compile 'com.squareup.okhttp3:logging-interceptor:3.4.1'

使用代码如下:

HttpLoggingInterceptor loggingInterceptor = new HttpLoggingInterceptor(new HttpLoggingInterceptor.Logger()
{
     @Override
     public void log(String message) 
     {
         if (BuildConfig.DEBUG) Log.d("Http", message+"");
     }
});
loggingInterceptor.setLevel(HttpLoggingInterceptor.Level.BODY);//设置日志打印等级
        
 OkHttpClient  okHttpClient = new OkHttpClient.Builder()             
         .addInterceptor(loggingInterceptor)//设置日志打印
         .retryOnConnectionFailure(true)//失败重连
         .connectTimeout(30, TimeUnit.SECONDS)//网络请求超时时间单位为秒
         .build();

.addInterceptor()可以调用多次

自定义Interceptor实现过滤改变请求返回的数据(可使用与保证APP的稳定性)

import com.alibaba.fastjson.JSON;

import java.io.ByteArrayInputStream;
import java.io.IOException;

import okhttp3.Interceptor;
import okhttp3.MediaType;
import okhttp3.Request;
import okhttp3.Response;
import okhttp3.ResponseBody;
import okio.BufferedSource;
import okio.Okio;

/**
 * 网络请求的拦截器
 * Created by xiaolei on 2017/3/2.
 */

public class SessionInterceptor implements Interceptor
{
    @Override
    public Response intercept(Chain chain) throws IOException
    {
        Request request = chain.request();
        Response response = chain.proceed(request);
        return new Response.Builder()
                .body(newResponseBody(response))
                .headers(response.headers())
                .message(response.message())
                .code(response.code())
                .request(response.request())
                .protocol(response.protocol())
                .build();
    }
    private ResponseBody newResponseBody(final Response response)
    {
        return new ResponseBody()
        {
            @Override
            public MediaType contentType()
            {
                return response.body().contentType();
            }
            @Override
            public long contentLength()
            {
                return response.body().contentLength();
            }
            @Override
            public BufferedSource source()
            {
                try
                {
                    String result = response.body().string();
                    if(JSON.parseObject(result).getInteger("code") == 500)
                    {
                        /**
                        *这里改变返回的数据,如果服务器返回的是一个HTML网页,
                        *那么移动端也能拿到一个Json数据,用于保证数据可解析不至于崩溃
                        */
                        ByteArrayInputStream tInputStringStream = new ByteArrayInputStream("{code:500,success:false}".getBytes());
                        BufferedSource source = Okio.buffer(Okio.source(tInputStringStream));
                        return source;
                    }else
                    {
                        ByteArrayInputStream tInputStringStream = new ByteArrayInputStream(result.getBytes());
                        BufferedSource source = Okio.buffer(Okio.source(tInputStringStream));
                        return source;
                    }
                } catch (IOException e)
                {
                    e.printStackTrace();
                    return null;
                }
            }
        };
    }
}

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏猿天地

知识点-Spring Boot 统一异常处理汇总

上面讲的是做页面开发的时候遇到的问题,还有一种情况就是用来开发Rest接口,当错误的时候我们希望返回给用户的是我们接口的标准格式,不是返回一段html代码。

1142
来自专栏IT笔记

SpringBoot开发案例之整合mongoDB

? mongodb.jpg 开始前,建议大家去了解以下文章,当然不看也没问题: MongoDB从入门到“精通”之简介和如何安装 MongoDB从入门到“精通”...

4698
来自专栏Java 源码分析

SpringBoot 笔记(十一):Servlet容器

1872
来自专栏JadePeng的技术博客

使用SpringBoot开发REST服务

本文介绍如何基于Spring Boot搭建一个简易的REST服务框架,以及如何通过自定义注解实现Rest服务鉴权 搭建框架 pom.xml 首先,引入相关依赖,...

4365
来自专栏非著名程序员

你真的会用Retrofit2吗?Retrofit2完全教程

本文注目录: Retrofit入门 Retrofit注解详解 Gson与Converter RxJava与CallAdapter 自定义Converter 自定...

3587
来自专栏程序猿DD

@FeignClient中的@RequestMapping也被Spring MVC加载的问题解决

问题描述 在之前发布的《Spring Cloud实战小贴士:Feign的继承特性(伪RPC模式)》一文中,我们介绍了如果使用Feign的继承特性来完成服务的提供...

37914
来自专栏小灰灰

Spring之RestTemplate中级使用篇

前面一篇介绍了如何使用RestTemplate发起post和get请求,然而也只能满足一些基本的场景,对于一些特殊的如需要设置请求头,添加认证信息等场景,却没有...

911
来自专栏小筱月

SSM整合开发

controller:作为请求转发,调用service接口处理逻辑,页面所有路径的访问方法:控制层的命名空间+@RequestMapping的value ser...

751
来自专栏互联网开发者交流社区

SpringBoot与Web开发

814
来自专栏java达人

SpringMVC下Excel文件的上传下载

在实际应用中,经常会遇到上传Excel或者下载Excel的情况,比如导入数据、下载统计数据等等场景。针对这个问题,我写了个基于SpringMVC的简单上传下载示...

2089

扫码关注云+社区