Retrofit源码分析一 概览

0

Retrofit源码分析一 概览

  • Retrofit的本质和与Okhttp的关系

​ 说到Retrofit,免不了要提起Okhttp,因为二者通常是绑定到一起使用的。那么我们首先要明确一点Retrofit并不是一个网络请求框架,而是一个对网络请求框架(也就是Okhttp)的封装。二者都是Squire公司的开源框架,Retrofit并不能脱离OKhttp,因为底层的网络访问是由Okhttp来实现的。说到对网络请求的封装,这里小伙伴们可能会有一些疑问,什么叫做对网络请求的封装?这里我们先简单的贴一些代码来看一下

    //登录
    @FormUrlEncoded
    @POST("${BuildConfig.EXTRA_URL}account/login.do")
    fun login(@Field("username") userName: String, @Field("password") pwd: String, @Field("clientType") clientType: Int): Observable<HttpResultEntity<UserEntity>>

在上面这个Kotlin编写的的网络请求方法中,@FormUrlEncoded@POST("${BuildConfig.EXTRA_URL}account/login")@Field("username")@Field( "password") @Field("clientType")Observable<HttpResultEntity<UserEntity>> 这些都是对网络请求的封装。这里需要知道的是,对网络请求的封装包括两个方面:1. 对请求参数的封装2. 对网络返回结果的封装。上面列出来的几项中除了Observable<HttpResultEntity<UserEntity>> 之外都是对请求参数的封装,即使是对Retrofit不太了解的同学应该也是可以很轻松的看懂一些参数代表的意义,比如@POST代表这个网络请求采用post方式,@Field("username")代表post请求域中要包含一个username的请求参数。而与之相对应的Observable<HttpResultEntity<UserEntity>>就是对网络返回结果的封装,对Rxjava了解的同学应该明白,Retrofit把网络返回的原始数据包装成了一个Observable,便于我们的开发。

  • Retrofit流程分析
    Retrofit的流程图如下所示

Retrofit流程图
关于更加详细的流程我们之后的章节会进行分析,大家先看个大概,心里有个印象就行。等我们对整个Retrofit的源码分析结束之后,相信大家对这幅图会有更加深入的认知。

你可能感兴趣的

wangchunlei · 2018年04月18日

大佬,为啥我的Retrofit不能使用@POST("${BuildConfig.EXTRA_URL}account/login.do")中的BuildConfig的方式,这个BuildConfig是自己自定义的一个类吗

回复

0

首先你得在你的gradle文件中定义EXTRA_URL,如下所示
buildTypes{

    debug {
        buildConfigField "String", "APP_URL", "\"http://gank.io/\""
        buildConfigField "String", "EXTRA_URL", "\"api/\""
        minifyEnabled false
        def appName = "kcommon"
        applicationIdSuffix ".debug"
        manifestPlaceholders = [APPLICATION_NAME: "${appName}"]
    }
    release {
        buildConfigField "String", "APP_URL", "\"http://gank.io/\""
        buildConfigField "String", "EXTRA_URL", "\"api/\""
        minifyEnabled false
        signingConfig signingConfigs.release
        def appName = "kcommon"
        manifestPlaceholders = [APPLICATION_NAME: "${appName}"]
        proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
    }
}

然后再编译一遍代码,BuildConfig会自动生成的。

BlackFlagBin 作者 · 2018年04月18日
0

这个跟Retrofit版本号有关系吗,我按照你的做法是能生成BuildConfig,但是${BuildConfig.EXTRA_URL}并不能解析出来,是怎么回事

wangchunlei · 2018年04月19日
0

"${BuildConfig.EXTRA_URL}account/login.do"是kotlin中字符串模板的写法。Java的话就是BuildConfig.EXTRA_URL+"account/login.do"。其实它就代表一个字符串,没什么特别的,只不过公司debug和release的地址不太一致所以这么写,主要是为了切换debug和release的时候比较方便。

BlackFlagBin 作者 · 2018年04月19日
载入中...