关闭

项目中快速搭建Retrofit

标签: androidRetrofit封装
271人阅读 评论(0) 收藏 举报
分类:

本篇博客将和大家分享如何在项目中快速搭建Retrofit。关于Retrofit的基本使用方法网上的例子很多,大家可自行参考,这里,我也给大家分享几个比较好的入门文章,仅供参考:

https://gold.xitu.io/entry/579f1749a633bd006009eca4
首先要引入该库:
compile 'com.squareup.retrofit2:retrofit:2.1.0'
compile 'com.squareup.retrofit2:converter-gson:2.1.0'

今天的主题是和大家分享如何在项目中快速搭建一个Retrofit。首先我们知道,网络请求实例在App中都是以单例模式存在的。所以我们就需要创建一个网络请求工具类来封装。

关于单例模式的写法,相信大家都不陌生,单例模式的实现方式很多种:懒汉式,饿汉式,枚举,内部类等等。。这里我就不一一详细说明了。下面来看代码:

package com.example.song.retrofittest.model;

import retrofit2.Retrofit;
import retrofit2.converter.gson.GsonConverterFactory;

/**
 * Created by Song on 2016/8/30.
 */
public class HttpUtils {

    private static Retrofit mRetrofit;
    private static volatile HttpUtils httpUtils;
    private HttpUtils() {
        mRetrofit = new Retrofit.Builder()
                .baseUrl("")
                .addConverterFactory(GsonConverterFactory.create())
                .build();

    }

    public static HttpUtils getInstance() {
        if(httpUtils == null) {
            synchronized (HttpUtils.class) {
                if(httpUtils == null) {
                    httpUtils = new HttpUtils();
                    return httpUtils;
                }
            }
        }
        return httpUtils;
    }
从上面代码我们看到:

(1)私有构造函数中,我们初始化了Retrofit。

(2)公开getInstance方法用来实现单例模式。

现在Retorfit初始化完了。就可以使用该对象来操作网络请求了。我们知道,Retrofit发送请求需要使用create方法。来看下源码:

public <T> T create(final Class<T> service) {
  Utils.validateServiceInterface(service);
  if (validateEagerly) {
    eagerlyValidateMethods(service);
  }
  return (T) Proxy.newProxyInstance(service.getClassLoader(), new Class<?>[] { service },
      new InvocationHandler() {
        private final Platform platform = Platform.get();

        @Override public Object invoke(Object proxy, Method method, Object... args)
            throws Throwable {
          // If the method is a method from Object then defer to normal invocation.
          if (method.getDeclaringClass() == Object.class) {
            return method.invoke(this, args);
          }
          if (platform.isDefaultMethod(method)) {
            return platform.invokeDefaultMethod(method, service, proxy, args);
          }
          ServiceMethod serviceMethod = loadServiceMethod(method);
          OkHttpCall okHttpCall = new OkHttpCall<>(serviceMethod, args);
          return serviceMethod.callAdapter.adapt(okHttpCall);
        }
      });
}
上面就是Retrofit的create方法的源码,大致可以看出,create方法使用了泛型来控制参数和返回参数的类型保持一致。细心的小伙伴肯定看到了Proxy.newProxyInstance()方和new InvocationHandler(){}!!没错,这不就是Java中的动态代理机制吗!!!并且我们看到在invoke方法中,对method进行一些判断并封装成ServiceMethod方法,通过okhttpCall来发送请求。

通过上面的分析,我们就需要公开一个create方法,下面来看代码:

public <T>T create(Class<T> cls) {
    return mRetrofit.create(cls);
}
可以看到,我们在create方法中,通过调用Retrofit实例的create方法来返回具体的请求服务实例。
这样,一个Retrofit的网络请求封装就完成了。在Activity中具体使用:
public class MainActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.content_main);
        LoadData loadData = HttpUtils.getInstance().create(LoadData.class);
        loadData.loadData("001");
    }
}
ok,到这里对Retorfit的封装就完成了。分分钟搞定Retrofit的集成使用!!

0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:421072次
    • 积分:5319
    • 等级:
    • 排名:第5804名
    • 原创:185篇
    • 转载:8篇
    • 译文:2篇
    • 评论:498条
    博客专栏
    文章分类
    最新评论
    关于我