【Android】最好用的网络库:Retrofit

https://github.com/square/retrofit

Retrofit和OkHttp的定位完全不同:OkHttp 侧重的是底层通信的实现,而Retrofit 侧重的是上层接口的封装。

事实上,Retrofit 就是Square 公司在OkHttp 的基础上进一步开发出来的应用层网络通信库,使得我们可以用更加面向对象的思维进行网络操作。

Retrofit 的设计基于以下几个事实:

  • 同一款应用程序中所发起的网络请求绝大多数指向的是同一个服务器域名。
  • 另外,服务器提供的接口通常是可以根据功能来归类的。
  • 最后,开发者肯定更加习惯于"调用一个接口,获取它的返回值"这样的编码方式。

Retrofit 的用法就是基于以上几点来设计的:

  • 首先我们可以配置好一个根路径,然后在指定服务器接口地址时只需要使用相对路径即可,这样就不用每次都指定完整的URL地址了。

  • 另外,Retrofit 允许我们对服务器接口进行归类。

  • 最后,我们也完全不用关心网络通信的细节,只需要在接口文件中声明一系列方法和返回值, 然后通过注解的方式指定该方法对应哪个服务器接口,以及需要提供哪些参数。当我们在程序中调用该方法时,Retrofit 会自动向对应的服务器接口发起请求,并将响应的数据解析成返回值声明的类型 。这就使得我们可以用更加面向对象的思维来进行网络操作

kt 复制代码
interface AppService {
	//GET http://example.com/get_data.json
	@GET("get_data.json")
	fun getAppData(): Call<List<App>>

	//GET http://example.com/<page>/get_data.json
	@GET("{page}/get_data.json")
	fun getData(@Path("page") page: Int): Call<Data>

	//GET http://example.com/get_data.json?u=<user>&t=<token>
	@GET("get_data.json")
	fun getData(@Query("u") user: String, @Query("t") token: String): Call<Data>

	...
}
kt 复制代码
class MainActivity : AppCompatActivity() {
	override fun onCreate(savedInstanceState: Bundle?) { 
		super.onCreate(savedInstanceState) 
		setContentView(R.layout.activity_main) 
		getAppDataBtn.setOnClickListener {
			/**
			首先,使用了Retrofit.Builder来构建一个Retrofit 对象。注意:baseUrl() addConverterFactory() 两个方法都是必须调用的。
			*/
			val retrofit = Retrofit.Builder() 
			.baseUrl("http://10.0.2.2/") //baseUrl() 用于指定所有Retrofit 请求的根路径, 
			.addConverterFactory(GsonConverterFactory.create()) //addConverterFactory() 用于指定Retrofit 在解析数据时所使用的转换库,这里指定成 GsonConverterFactory。
			.build()
			
			/**
			调用create()方法,并传入具体Service接口所对应的Class类型,创建一个该接口的动态代理对象。
			*/
			val appService = retrofit.create(AppService::class.java)
			
			/**
			对应到上述的代码当中,当调用了AppService的getAppData()方法时,会返回一个 Call<List<App>>对象,再调用一下它的enqueue()方法,Retrofit 就会根据注解中配置的服务器接口地址去进行网络请求了,服务器响应的数据会回调到enqueue()方法中传入的Callback实现里面。
			需要注意的是,当发起请求的时候,Retrofit 会自动在内部开启子线程,当数据回调到Callback中之后,Retr ofit 又会自动切换回主线程,整个操作过程中我们都不用考虑线程切换问题。
			*/ 
			appService.getAppData().enqueue(object : Callback<List<App>> {
				override fun onResponse(call: Call<List<App>>, response: Response<List<App>>) {
					//在Callback的onResponse()方法中,调用response.body()方法将会得到Retrofit 解析后的对象,也就是List<App>类型的数据,最后遍历List,将其中的数据打印出来即可。
					val list = response.body()
					if (list != null) {
						for (app in list) {
							Log.d("MainActivity", "id is ${app.id}") 
							Log.d("MainActivity", "name is ${app.name}") 
							Log.d("MainActivity", "version is ${app.version}")
						} 
					}
				}
				override fun onFailure(call: Call<List<App>>, t: Throwable) {
					t.printStackTrace() 
				}
			}) 
		}
	} 
}
相关推荐
蒜白29 分钟前
网络工程安全从入门到“入魂“教学案
网络·网络工程师·安全架构
the sun341 小时前
NAT、代理服务器、内网穿透和内网打洞
网络·智能路由器
Python破壁人手记1 小时前
《我的Python觉醒之路》之转型Python(十五)——控制流
java·服务器·开发语言·网络·python
独行soc1 小时前
2025年渗透测试面试题总结-某四字大厂面试复盘 一面(题目+回答)
网络·python·科技·面试·职场和发展·红蓝攻防
光路科技3 小时前
从以太网 II 到 VLAN 和 Jumbo Frame:数据帧格式解读
网络
CYRUS_STUDIO4 小时前
使用 Unicorn 还原变异 CRC32 算法
android·算法·逆向
没明白白4 小时前
了解一下HTTP的短连接和长连接
网络·网络协议·http
二流小码农4 小时前
鸿蒙开发:ArkTs语言注释
android·ios·harmonyos
二流小码农4 小时前
鸿蒙开发:权限授权封装
android·ios·harmonyos
CYRUS_STUDIO5 小时前
基于 Unicorn 实现一个轻量级的 ARM64 模拟器
android·逆向·汇编语言