Retrofit2 使用FastJson作为Converter

Retortfit2
Retrofit是由Square公司出品的针对于Android和Java的类型安全的Http客户端,网络服务基于OkHttp 。 个人觉得更为准确的说法是,Retrofit是OkHttp的一个包装工具类,可以更加方便的调用Restful API。

Retrofit2 默认提供的Converter
Gson: com.squareup.retrofit2:converter-gson
Jackson: com.squareup.retrofit2:converter-jackson
Moshi: com.squareup.retrofit2:converter-moshi
Protobuf: com.squareup.retrofit2:converter-protobuf
Wire: com.squareup.retrofit2:converter-wire
Simple XML: com.squareup.retrofit2:converter-simplexml
Scalars (primitives, boxed, and String): com.squareup.retrofit2:converter-scalars

那么问题来了,服务器端使用FastJson进行数据的序列化,正常使用和Gson,JackSon都差不多,但是当FastJson发现有循环引用的话,会使用自己定义的一个数据格式$ref这样的,那么解析的时候就会报错。(当然也可以不让FastJson使用这种引用格式的方法,参见https://github.com/alibaba/fastjson/wiki/%E5%BE%AA%E7%8E%AF%E5%BC%95%E7%94%A8)

如果条件很苛刻,只能客户端进行修改,那么修改方式就有两种。
一种是返回String,自行使用FastJson进行解析,这个也很容易实现。
第二种当然是扩展Converter。

下面就来讲解如何扩展

首先创建FastJsonConverterFactory 类,并继承Converter.Factory,重写其中的responseBodyConverter方法与requestBodyConverter方法。
 


import java.lang.annotation.Annotation;
import java.lang.reflect.Type;

import okhttp3.RequestBody;
import okhttp3.ResponseBody;
import retrofit2.Converter;
import retrofit2.Retrofit;

/**
 * <b>类名称:</b> FastJsonConverterFactory <br/>
 * <b>类描述:</b> FastJsonCoverter<br/>
 * <b>创建人:</b> Lincoln <br/>
 * <b>修改人:</b> Lincoln <br/>
 * <b>修改时间:</b> 2016年03月08日 下午3:48<br/>
 * <b>修改备注:</b> <br/>
 *
 * @version 1.0.0 <br/>
 */
public class FastJsonConverterFactory extends Converter.Factory{

    public static FastJsonConverterFactory create() {
        return new FastJsonConverterFactory();
    }

    /**
    * 需要重写父类中responseBodyConverter,该方法用来转换服务器返回数据
    */
    @Override
    public Converter<ResponseBody, ?> responseBodyConverter(Type type, Annotation[] annotations, Retrofit retrofit) {
        return new FastJsonResponseBodyConverter<>(type);
    }

    /**
    * 需要重写父类中responseBodyConverter,该方法用来转换发送给服务器的数据
    */
    @Override
    public Converter<?, RequestBody> requestBodyConverter(Type type, Annotation[] parameterAnnotations, Annotation[] methodAnnotations, Retrofit retrofit) {
        return new FastJsonRequestBodyConverter<>();
    }

}

创建FastJsonResponseBodyConverter 类 


import okhttp3.ResponseBody;
import okio.BufferedSource;
import okio.Okio;
import retrofit2.Converter;

/**
 * <b>类名称:</b> FastJsonResponseBodyConverter <br/>
 * <b>类描述:</b> ResponseBody转换器<br/>
 * <b>创建人:</b> Lincoln <br/>
 * <b>修改人:</b> Lincoln <br/>
 * <b>修改时间:</b> 2016年03月08日 下午3:58<br/>
 * <b>修改备注:</b> <br/>
 *
 * @version 1.0.0 <br/>
 */
public class FastJsonResponseBodyConverter<T> implements Converter<ResponseBody, T> {
    private final Type type;

    public FastJsonResponseBodyConverter(Type type) {
        this.type = type;
    }

    /*
    * 转换方法
    */
    @Override
    public T convert(ResponseBody value) throws IOException  {
        BufferedSource bufferedSource = Okio.buffer(value.source());
        String tempStr = bufferedSource.readUtf8();
        bufferedSource.close();
        return JSON.parseObject(tempStr, type);

    }
}

创建FastJsonRequestBodyConverter 

import com.alibaba.fastjson.JSON;

import java.io.IOException;

import okhttp3.MediaType;
import okhttp3.RequestBody;
import retrofit2.Converter;

/**
 * <b>类名称:</b> FastJsonRequestBodyConverter <br/>
 * <b>类描述:</b> RequestBody转换器<br/>
 * <b>创建人:</b> Lincoln <br/>
 * <b>修改人:</b> Lincoln <br/>
 * <b>修改时间:</b> 2016年03月08日 下午5:02<br/>
 * <b>修改备注:</b> <br/>
 *
 * @version 1.0.0 <br/>
 */
public class FastJsonRequestBodyConverter<T> implements Converter<T, RequestBody> {
    private static final MediaType MEDIA_TYPE = MediaType.parse("application/json; charset=UTF-8");

    @Override
    public RequestBody convert(T value) throws IOException {
        return RequestBody.create(MEDIA_TYPE, JSON.toJSONBytes(value));
    }
}

使用方法 

 retrofit = new Retrofit.Builder()
                .baseUrl(BASE_URL)
                .client(CustomerOkHttpClient.getClient())
                .addCallAdapterFactory(RxJavaCallAdapterFactory.create())
                //在此处声明使用FastJsonConverter做为转换器
                .addConverterFactory(FastJsonConverterFactory.create())
                .build();

以上就是使用FastJson作为Retrofit2转换器的全部代码。

github上写了一个Demo项目,有兴趣的可以看看
https://github.com/ChineseLincoln/BaseProject

compile 'org.ligboy.retrofit2:converter-fastjson-android:2.1.0'
Retrofit retrofit = new Retrofit.Builder()
  .baseUrl("https://api.example.com")
  .addConverterFactory(FastJsonConverterFactory.create())
  .build();

 

 

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Boot可以使用Retrofit2和RestTemplate来进行网络请求。 首先,我们来看如何使用Retrofit2。首先,你需要在你的`pom.xml`文件中添加Retrofit2的依赖: ```xml <dependency> <groupId>com.squareup.retrofit2</groupId> <artifactId>retrofit</artifactId> <version>2.9.0</version> </dependency> ``` 接下来,创建一个Retrofit的实例,并定义一个接口来描述你的API: ```java Retrofit retrofit = new Retrofit.Builder() .baseUrl("http://api.example.com/") .addConverterFactory(GsonConverterFactory.create()) .build(); interface MyApi { @GET("endpoint") Call<MyResponse> getData(); } ``` 然后,你可以使用该接口来发起网络请求: ```java MyApi myApi = retrofit.create(MyApi.class); Call<MyResponse> call = myApi.getData(); call.enqueue(new Callback<MyResponse>() { @Override public void onResponse(Call<MyResponse> call, Response<MyResponse> response) { // 处理响应 if (response.isSuccessful()) { MyResponse myResponse = response.body(); // 处理成功的响应 } else { // 处理错误的响应 } } @Override public void onFailure(Call<MyResponse> call, Throwable t) { // 处理请求失败 } }); ``` 接下来,我们来看如何使用RestTemplate。首先,你需要在你的`pom.xml`文件中添加Spring Web的依赖: ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> ``` 然后,在你的代码中创建一个RestTemplate实例,并使用它来发送HTTP请求: ```java RestTemplate restTemplate = new RestTemplate(); MyResponse response = restTemplate.getForObject("http://api.example.com/endpoint", MyResponse.class); ``` 以上就是使用Retrofit2和RestTemplate进行网络请求的基本步骤。你可以根据具体的需求进行适当的配置和定制化。 注意,在使用Retrofit2时,你需要定义一个接口来描述API,并使用注解来标记请求的方法和参数。而在使用RestTemplate时,你可以直接调用其提供的方法来发送请求,并将响应转换为你需要的对象类型。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值