本文介绍: 最后我们也完全不用关心网络通信细节,只需要接口文件声明系列方法返回值然后通过注解方式指定方法对应哪个服务器接口,以及需要提供哪些参数。事实上,Retrofit 就是Square 公司在OkHttp 的基础上进一步开发出来的应用网络通信库,使得我们可以用更加面向对象思维进行网络操作。Retrofit和OkHttp定位完全不同:OkHttp 侧重的是底层通信实现,而Retrofit 侧重的是上层接口封装。另外,Retrofit 允许我们服务器接口进行归类。

https://github.com/square/retrofit

Retrofit和OkHttp定位完全不同:OkHttp 侧重的是底层通信实现,而Retrofit 侧重的是上层接口的封装
事实上,Retrofit 就是Square 公司在OkHttp 的基础上进一步开发出来的应用网络通信库,使得我们可以用更加面向对象思维进行网络操作

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

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

interface AppService {
	//GET http://example.com/get_data.json
	@GET("get_data.json")
	fun getAppData(): Call<List<App&gt;&gt;

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

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

	...
}
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() 
				}
			}) 
		}
	} 
}

原文地址:https://blog.csdn.net/m0_60641871/article/details/134734713

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任

如若转载,请注明出处:http://www.7code.cn/show_28562.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱suwngjj01@126.com进行投诉反馈,一经查实,立即删除

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注