热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

二、RESTFUL网路请求框Retrofit

Retrofit是一个高质量高效率的HTTP请求库。Retrofit内部依赖于OkHttp,它将OKHttp底层的代码和细节都封装了起来,功能上做了更多

Retrofit是一个高质量高效率的HTTP请求库。Retrofit内部依赖于OkHttp,它将OKHttp底层的代码和细节都封装了起来,功能上做了更多的扩展,比如返回结果的自动解析数据模型,网络引擎的切换,拦截器…


restFul是符合rest架构风格的网络API接口,完全承认Http是用于标识资源。restFul URL是面向资源的,可以唯一标识和定位资源。 对于该URL标识的资源做何种操作是由Http方法决定的。

rest请求方法有4种,包括get,post,put,delete.分别对应获取资源,添加资源,更新资源及删除资源.

作者:埋着头向前走寻找我自己
链接:https://www.jianshu.com/p/dfe3077ddbcd
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。



1. 注解

retrofit注解驱动型上层网络请求框架,使用注解来简化请求,大体分为以下几类:


  • 用于标注网络请求方式的注解
  • 标记网络请求参数的注解
  • 用于标记网络请求和响应格式的注解

图片和部分文字转自https://www.songyubao.com/book/primary/network/Retrofit.html


retrofit注解


1.1请求方法注解


注解说明
@GETget请求
@POSTpost请求
@PUTput请求
@DELETEdelete请求
@PATCHpatch请求,该请求是对put请求的补充,用于更新局部资源
@HEADhead请求
@OPTIONSoption请求
@HTTP通用注解,可以替换以上所有的注解,其拥有三个属性:method,path,hasBody

1.2 请求头注解

既可以标记在方法上面也可以标记在参数里面


注解说明
@Headers用于添加固定请求头,可以同时添加多个。通过该注解添加的请求头不会相互覆盖,而是共同存在
@Header作为方法的参数传入,用于添加不固定值的Header,该注解会更新已有的请求头

1.3请求参数注解


名称说明
@Body多用于post请求发送非表单数据,比如想要以post方式传递json格式数据
@Filed多用于post请求中表单字段,Filed和FieldMap需要FormUrlEncoded结合使用
@FiledMap和@Filed作用一致,用于不确定表单参数
@Part用于表单字段,Part和PartMap与Multipart注解结合使用,适合文件上传的情况
@PartMap用于表单字段,默认接受的类型是Map,可用于实现多文件上传
@Path用于url中的占位符
@Query用于Get中指定参数
@QueryMap和Query使用类似
@Url指定请求路径

1.4请求和响应格式注解


名称说明
@FormUrlEncoded表示请求发送编码表单数据,每个键值对需要使用@Field注解
@Multipart表示请求发送multipart数据,需要配合使用@Part
@Streaming表示响应用字节流的形式返回.如果没使用该注解,默认会把数据全部载入到内存中.该注解在在下载大文件的特别有用

2 开始使用


step1: 添加依赖

app/build.gradle

implementation 'com.squareup.retrofit2:retrofit:2.3.0'
implementation 'com.squareup.retrofit2:converter-gson:2.3.0' //json转换

step2: 初始化

object FirstRetrofit {//OkHttpClient 对象private val okClient:OkHttpClient &#61; OkHttpClient.Builder() //builder构建者设计模式.connectTimeout(10,TimeUnit.SECONDS) //连接超时时间.readTimeout(10,TimeUnit.SECONDS) //读取超时.writeTimeout(10,TimeUnit.SECONDS) //写超时.addInterceptor(LoggingInterceptor()) //拦截器.build()//初始化private val retrofit:Retrofit &#61; Retrofit.Builder().client(okClient) //配置OkHttp网络请求框架的对象.baseUrl("http://123.56.232.18:8080/serverdemo/") //网络请求的域名.addConverterFactory(GsonConverterFactory.create()) //数据转换适配器.build()//发起网络请求//public T create(final Class service) java类型fun <T> create(clazz: Class<T>):T{return retrofit.create(clazz)}
}//网络请求接口
interface ApiService{//&#64;Query 的 encoded发起网络请求是要不要对接口进行编码(防止中文乱码)//&#64;Query(value &#61; "userId", encoded &#61; true) 是用来修饰 userId:String&#64;GET(value &#61; "user/query")fun queryUser(&#64;Query(value &#61; "userId", encoded &#61; true) userId:String):Call<UserResponse>
}

step3:调用

异步用enqueue()&#xff0c;同步用execute()

val apiService &#61; FirstRetrofit.create(ApiService::class.java)apiService.queryUser("1600933269").enqueue(object :Callback<UserResponse>{override fun onResponse(call: Call<UserResponse>, response: Response<UserResponse>) {Log.e("Retrofit",response.body()?.toString()?:"response is null")}override fun onFailure(call: Call<UserResponse>, t: Throwable) {Log.e("Retrofit",t.message?:"unknown reason")}})

Tips:


onResponse 和 onFailure 的回调都是在主线程里面
可以直接操控UI控件



请求方法定义

//网络请求接口
interface ApiService{//&#64;Query 的 encoded发起网络请求是要不要对接口进行编码(防止中文乱码)//&#64;Query(value &#61; "userId", encoded &#61; true) 是用来修饰 userId:String&#64;GET(value &#61; "user/query")fun queryUser(&#64;Query(value &#61; "userId", encoded &#61; true) userId:String):Call<UserResponse>//使用&#64;Headers添加多个请求头&#64;Headers("User-Agent:android", "apikey:123456789")&#64;GET(value &#61; "user/query")fun queryUser1(&#64;Query(value &#61; "userId" , encoded &#61; true) userId: String):Call<UserResponse>//多个参数的情况下可以使用&#64;QueryMap&#xff0c;但只能用在GET请求上&#64;GET(value &#61; "user/query")fun queryUser2(&#64;QueryMap(encoded &#61; true) queryMap: Map<String?, String?>):Call<UserResponse>/*** 很多情况下&#xff0c;我们需要上传json格式的数据。当我们注册新用户的时候&#xff0c;因为用户注册时的数据相对较多* 并可能以后会变化&#xff0c;这时候&#xff0c;服务端可能要求我们上传json格式的数据。此时就要&#64;Body注解来实现。* 直接传入实体,它会自行转化成Json, &#64;Body只能用在POST请求上** 字符串提交*/&#64;POST("user/update")fun userUpdate(&#64;Body post: User):Call<UserResponse>/*** 表单提交&#xff08;键值对提交&#xff09;* 多用于post请求中表单字段,Filed和FieldMap需要FormUrlEncoded结合使用*/&#64;POST()&#64;FormUrlEncodedfun executePost(&#64;FieldMap map:Map<String , User>):Call<UserResponse>/*** 表单上传文件&#xff08;键值对提交、同时上传文件&#xff09;*/&#64;Multipart&#64;FormUrlEncoded&#64;POST("upload/upload")fun register(&#64;Field("openId") openId:String,&#64;PartMap map:Map<String? , MultipartBody.Part>):Call<UserResponse>}

推荐阅读
  • 本文介绍了在mac环境下使用nginx配置nodejs代理服务器的步骤,包括安装nginx、创建目录和文件、配置代理的域名和日志记录等。 ... [详细]
  • 解决nginx启动报错epoll_wait() reported that client prematurely closed connection的方法
    本文介绍了解决nginx启动报错epoll_wait() reported that client prematurely closed connection的方法,包括检查location配置是否正确、pass_proxy是否需要加“/”等。同时,还介绍了修改nginx的error.log日志级别为debug,以便查看详细日志信息。 ... [详细]
  • .NetCoreWebApi生成Swagger接口文档的使用方法
    本文介绍了使用.NetCoreWebApi生成Swagger接口文档的方法,并详细说明了Swagger的定义和功能。通过使用Swagger,可以实现接口和服务的可视化,方便测试人员进行接口测试。同时,还提供了Github链接和具体的步骤,包括创建WebApi工程、引入swagger的包、配置XML文档文件和跨域处理。通过本文,读者可以了解到如何使用Swagger生成接口文档,并加深对Swagger的理解。 ... [详细]
  • 本文介绍了NetCore WebAPI开发的探索过程,包括新建项目、运行接口获取数据、跨平台部署等。同时还提供了客户端访问代码示例,包括Post函数、服务器post地址、api参数等。详细讲解了部署模式选择、框架依赖和独立部署的区别,以及在Windows和Linux平台上的部署方法。 ... [详细]
  • 本文介绍了在rhel5.5操作系统下搭建网关+LAMP+postfix+dhcp的步骤和配置方法。通过配置dhcp自动分配ip、实现外网访问公司网站、内网收发邮件、内网上网以及SNAT转换等功能。详细介绍了安装dhcp和配置相关文件的步骤,并提供了相关的命令和配置示例。 ... [详细]
  • Nginx使用(server参数配置)
    本文介绍了Nginx的使用,重点讲解了server参数配置,包括端口号、主机名、根目录等内容。同时,还介绍了Nginx的反向代理功能。 ... [详细]
  • Linux重启网络命令实例及关机和重启示例教程
    本文介绍了Linux系统中重启网络命令的实例,以及使用不同方式关机和重启系统的示例教程。包括使用图形界面和控制台访问系统的方法,以及使用shutdown命令进行系统关机和重启的句法和用法。 ... [详细]
  • CSS3选择器的使用方法详解,提高Web开发效率和精准度
    本文详细介绍了CSS3新增的选择器方法,包括属性选择器的使用。通过CSS3选择器,可以提高Web开发的效率和精准度,使得查找元素更加方便和快捷。同时,本文还对属性选择器的各种用法进行了详细解释,并给出了相应的代码示例。通过学习本文,读者可以更好地掌握CSS3选择器的使用方法,提升自己的Web开发能力。 ... [详细]
  • 本文介绍了Java工具类库Hutool,该工具包封装了对文件、流、加密解密、转码、正则、线程、XML等JDK方法的封装,并提供了各种Util工具类。同时,还介绍了Hutool的组件,包括动态代理、布隆过滤、缓存、定时任务等功能。该工具包可以简化Java代码,提高开发效率。 ... [详细]
  • 开发笔记:计网局域网:NAT 是如何工作的?
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了计网-局域网:NAT是如何工作的?相关的知识,希望对你有一定的参考价值。 ... [详细]
  • Python瓦片图下载、合并、绘图、标记的代码示例
    本文提供了Python瓦片图下载、合并、绘图、标记的代码示例,包括下载代码、多线程下载、图像处理等功能。通过参考geoserver,使用PIL、cv2、numpy、gdal、osr等库实现了瓦片图的下载、合并、绘图和标记功能。代码示例详细介绍了各个功能的实现方法,供读者参考使用。 ... [详细]
  • 闭包一直是Java社区中争论不断的话题,很多语言都支持闭包这个语言特性,闭包定义了一个依赖于外部环境的自由变量的函数,这个函数能够访问外部环境的变量。本文以JavaScript的一个闭包为例,介绍了闭包的定义和特性。 ... [详细]
  • Java学习笔记之面向对象编程(OOP)
    本文介绍了Java学习笔记中的面向对象编程(OOP)内容,包括OOP的三大特性(封装、继承、多态)和五大原则(单一职责原则、开放封闭原则、里式替换原则、依赖倒置原则)。通过学习OOP,可以提高代码复用性、拓展性和安全性。 ... [详细]
  • Go Cobra命令行工具入门教程
    本文介绍了Go语言实现的命令行工具Cobra的基本概念、安装方法和入门实践。Cobra被广泛应用于各种项目中,如Kubernetes、Hugo和Github CLI等。通过使用Cobra,我们可以快速创建命令行工具,适用于写测试脚本和各种服务的Admin CLI。文章还通过一个简单的demo演示了Cobra的使用方法。 ... [详细]
  • 本文介绍了RxJava在Android开发中的广泛应用以及其在事件总线(Event Bus)实现中的使用方法。RxJava是一种基于观察者模式的异步java库,可以提高开发效率、降低维护成本。通过RxJava,开发者可以实现事件的异步处理和链式操作。对于已经具备RxJava基础的开发者来说,本文将详细介绍如何利用RxJava实现事件总线,并提供了使用建议。 ... [详细]
author-avatar
续2502915941
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有