preface

Retrofit is an HTTP framework developed by Square for Android and Java. Retrofit transforms all HTTP network request apis into Java interfaces, which are simple and easy to use. Let’s start by learning the process and principles of Retrofit and analyzing the relevant source code.

Introduction of Retrofit

Retrofit is also known as the encapsulation of Restful Http Web request framework. It is worth noting that Retrofit2 is only the encapsulation of the Web request framework. It is not a framework itself, nor does the work itself. So its Okhttp kernel does the job

You can look at the flow chart of the analysis

  • Our Application layer encapsulates request parameters, urls, and associated configuration information through the Retrofit layer
  • Subsequent requests are made through the Okhttp layer
  • After the server returns the data to the Okhttp layer, the Okhttp layer in turn passes the raw results to the Retrofit layer, and then back to the application layer through the Retrofit layer, which is the process of parsing

In short, having Retrofit focus on interface encapsulation and Okhttp focus on network request efficiency is more efficient if the two work together

Simple summary

  • The APP application requests through the Retrofit network, essentially encapsulating the request parameters (headers, urls, request messages, etc.) using the Retrofit interface layer, and then Okhttp does the subsequent request operations
  • After completing the server’s return of data, Okhttp hands the raw results to Retrofit, which parses the results based on the user’s needs
  • Its main role is to encapsulate our underlying network framework, OkHttp, and do all sorts of data transformation and adaptation, which leads Retrofit to use a lot of design patterns, which means it also has great scalability and seamlessly ADAPTS to mainstream OkHttp, Rxjava libraries and so on

Retrofit is simple to use

After reading the above, does Retrofit feel very powerful, which is the main reason why so many projects now use Retrofit? Here’s a quick look at Retrofit using official examples and my own.

Examples from the official website

  1. The first step is to define a GithubService interface
interface GithubService {

    @GET("user/{user}/repos")
    fun listRepos(@Path("user") user: String): Call<List<Repo>>
    
}
Copy the code
  • The listRepos method here defines a Get annotation to indicate that this is a Get request. The string in the Get annotation writes the requested path, which is concatenated with the following BaseUrl to form a complete URL
  • Then there is a **{user}** in the string, where the value changes dynamically and is passed in by the listRepos method
  • If we pass the string user as an empty string, we will use the string from Path as the default URL address
  1. Create our Retfrofit request
 val retrofit = Retrofit.Builder()
            .baseUrl("https://api.github.com/")
            .addConverterFactory(GsonConverterFactory.create())
            .build()
val service = retrofit.create(GithubService::class.java)
Copy the code
  • Using the builder pattern, we then pass in a baseurl base path
  • The addConvertFactory method is basically used to convert the returned httpResponse into a Java object for rendering on the UI. This will be analyzed later in the source code
  • Call the Build () method to complete the Retrofit configuration
  • Create an instance of GtihubService by calling the create method with Retrofit, passing in its bytecode
  1. Invoke methods in the interface to perform network requests through OKHTTP
val repos: Call<List<Repo>> = service.listRepos("octocat")


        repos.enqueue(object : Callback<List<Repo>> {
            override fun onResponse(call: Call<List<Repo>>, response: Response<List<Repo> >) {
                TODO("Not yet implemented")}override fun onFailure(call: Call<List<Repo>>, t: Throwable) {
                TODO("Not yet implemented")}})Copy the code
  • As you can see, retrofit does the real work of network requests over to Okhttp, using enqueue() asynchronous requests, which will be explained in more detail later

Simple examples for your own use

Here I’ve broken down the Retrofit web request process into roughly six steps

  1. The first step is to add a retrofit library dependency and add network permissions
  //retrofit
    implementation 'com. Squareup. Retrofit2: retrofit: 2.9.0'
    implementation 'com. Squareup. Retrofit2: converter - gson: 2.3.0'
    implementation 'com. Squareup. Retrofit2: adapter - rxjava: 2.3.0'
Copy the code
  1. The second step is to create an entity class to receive the Bean type returned by the server
class MyResponse(
    name: String.age: Int.color: String.address: String
)
Copy the code
  1. The third step is to create an interface for describing network requests
interface MyInterface{
    @GET("... /..." )
    fun getCall(a):Call<List<MyResponse>>

}
Copy the code
  • Retrofit abstracts each HTTP request into a Java interface, using an annotation pattern to describe and configure the entire web request
  • Retrofit’s internal mechanism for annotations is to translate the entire annotation into a single HTTP request through a dynamic proxy pattern (I won’t go into detail here)
  1. The fourth step is to start creating Retrofit and add the relevant configuration
        val retrofit = Retrofit.Builder()
            .baseUrl("http://xxx.xxx.com/") // Set the network request URL
            .addConverterFactory(GsonConverterFactory.create()) // Set the data parser
            .addCallAdapterFactory(RxJavaCallAdapterFactory.create()) // Support Rxjava platform
            .build()
Copy the code
  • We’ve added two parameters here, so ConvertFactory, which is actually a data parser, retrofit doesn’t just support Gson, things like JSON, Protobuf, so we’re adding a converter factory here, and it’s worth noting that each time you use a different data parser, You need to add a dependency to Gradle
  • Retrofit also supports multiple network request adaptors, so if you use Android’s default CallAdapter, you don’t need to add a network request adapter dependency
  1. Step five, create an instance of the network request interface
val myInterface = retrofit.create(MyInterface::class.java)
val call = myInterface.getCall()
Copy the code
  • Retrofit calls the create method to create an instance of MyInterface, passing in a bytecode file for the interface
  • Once created, Call the **getCall()** method in the interface to get an instance of Call(the actual request in Okhttp)
  1. Step 6: Make the actual network request (call enQueue for asynchronous request or execute for synchronous request)
 call.enqueue(object : Callback<List<MyResponse>>{
            override fun onResponse( call: Call
       
        >, response: Response
        
         > )
        
        {
               println(response.body())
            }

            override fun onFailure(call: Call<List<MyResponse>>, t: Throwable) {
                println("Request failed")}})Copy the code

That’s a complete Retrofit request

conclusion

In summary, we have learned about the simple uses of Retrofit, which are as follows:

  • Add a Retrofit library dependency and add network permissions
  • Create a class that receives data from the server
  • Create an interface to describe network requests
  • Creating a Retroifit instance (Builder pattern)
  • Create a network request interface instance
  • Sending network requests (asynchronous/synchronous)
  • Process the data returned by the server

This is the simple process of using Retrofit. Now that you are familiar with the above, let’s go into the source world of Retrofit and learn how the internal mechanism of Retrofit is implemented

To be continued