Android Retrofit的使用详解

 更新时间:2018年01月02日 09:09:06   作者:锯齿流沙  
本文介绍了Android Retrofit的使用详解,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

关于Retrofit的学习,我算是比较晚的了,而现在Retrofit已经是Android非常流行的网络请求框架了。之前,我没有学过Retrofit,但最近公司的新项目使用了Retrofit、Rxjava和OkHttp来进行封装,使用起来非常简便,增加代码的美观程度,也降低了耦合度,这是一个非常棒的框架,特别是这三者一起使用。

简介

Retrofit是Square公司开发的一款针对Android网络请求的框架,现在已经更新到2.3版本了。Retrofit的最大特点是使用运行时注解的方式提供功能。

Retrofit的使用

关于Retrofit的使用,其实还是很简单的,而且逻辑思路也比较清晰,所以开发者是很容易上手的。

添加依赖

build.gradle文件的dependencies下添加以下依赖:

复制代码 代码如下:

compile 'com.squareup.retrofit2:retrofit:2.3.0' compile 'com.squareup.retrofit2:converter-gson:2.3.0'

上面除了添加Retrofit依赖,还添加了gson依赖,来解析请求得到的json数据。

定义使用的数据集合

class Result <T>{
  var status: Int? = -1//请求结果
  lateinit var message: String;
  var content :T?= null
}

这是返回结果的集合,使用了kotlin来写

class Content {
  var name: String?= null
  var mobile :String?= null
  var address :String?= null
}

需要的内容集合类

请求

需要一个接口,并且编写请求的方法

interface HttpService {
  @GET("index.php?m=Api&c=User&a=userInfo")
  fun getUserInfo(): Call<Result<Content>>
}

调用请求

private void request() {
    Retrofit retrofit = new Retrofit.Builder()
        .baseUrl("http://one.sinalwj.cn//")
        .addConverterFactory(GsonConverterFactory.create())
        .build();
    HttpService service = retrofit.create(HttpService.class);
    Call<Result<Content>> call = service.getUserInfo();
    call.enqueue(new Callback<Result<Content>>() {
      @Override
      public void onResponse(Call<Result<Content>> call, Response<Result<Content>> response) {
        Log.i("tag", response.body().getContent().getName());
      }
      @Override
      public void onFailure(Call<Result<Content>> call, Throwable t) {
        Log.i("tag", "失败");
      }
    });

  }

以上就是Retrofit的get请求方式。GET请求需要在请求方法之前添加一个GET注解来标明这是一个GET请求,同样,如果是POST请求需要一个POST注解。

@POST

POST请求,需要添加一个@POST的注解,并且需要还需要使用@FormUrlEncoded 注解来表明,这是一个表单,使用@Field注解,传入表单需要的参数。

@FormUrlEncoded //表单
  @POST("index.php?m=Api&c=User&a=userInfo")
  fun getUserInfo(
      @Field("user_id") user_id: String //参数
  ): Observable<BaseResult<User>> //返回数据类型

@Body

@Body注解是针对POST的请求方式,如传输数据JSON格式

class Content {
  var name: String?= null
  lateinit var sn:SN

  class SN{
    var out :String ?= null
    var errNo :Int ?= -1
  }
}

@GET("ajax.php")
fun getInfo(@Body content: Content): Call<Result<Content>>

@Path

使用@Path可以动态的配置URL地址。

@GET("{path/}{index.php?m=Api&c=User&a=userInfo")
fun getUserInfo(@Path("path")path: String): Call<Result<Content>>

@Query

@Query即动态指定查询条件

@GET("ajax.php")
fun getInfo(@Query("id")id: String): Call<Result<Content>>

@Query是查询单一的条件,但是如果是多个条件的话,就不适用了,那么就需要用到@QueryMap注解。@QueryMap就是动态指定查询条件组。

文件上传

使用@Part注解来表示单个文件上传,而@PartMap注解跟单文件上传是类似的,是不过是使用了Map集合来封装了上传的文件,即多文件上传。

除了以上的注解,还有@Header,即表示加入消息报头,因为在http请求的时候,为了防止攻击、过滤不安全的访问和添加特殊加密的访问来保证安全,需要在消息报头中携带一些特殊的消息处理,而在Retrofix中使用@Header即可实现添加消息报头。

从上面的Retrofix实践和注解的讲解中,我们知道使用Retrofix可以很简单的,而且代码逻辑比较清晰的做http请求,其提供非常多的注解来给开发者使用,简化了代码。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • Android编程之截屏实现方法(包括scrollview与listview)

    Android编程之截屏实现方法(包括scrollview与listview)

    这篇文章主要介绍了Android编程之截屏实现方法,包括截取scrollview与listview屏幕的相关技巧,以及截屏图片的生成与保存技巧,需要的朋友可以参考下
    2015-11-11
  • Android使用CountDownTimer实现倒数定时器效果

    Android使用CountDownTimer实现倒数定时器效果

    这篇文章主要介绍了Android使用CountDownTimer实现倒数定时器效果的资料,这里整理了详细的代码,有需要的小伙伴可以参考下。
    2017-02-02
  • kotlin 注解 @Parcelize 使用示例和步骤详解

    kotlin 注解 @Parcelize 使用示例和步骤详解

    Parcelable 接口是 Android 中用于在组件之间传递对象的一种方式,在 Kotlin 中,@Parcelize 注解用于简化实现 Android Parcelable 接口的过程,本文给大家分享kotlin 注解 @Parcelize 使用示例,感兴趣的朋友一起看看吧
    2024-06-06
  • Kotlin launch原理全面分析

    Kotlin launch原理全面分析

    在Android开发中,launch是我们经常用的,今天来看看它是什么原理,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习吧
    2022-11-11
  • Android线程间通信 Handler使用详解

    Android线程间通信 Handler使用详解

    这篇文章主要为大家介绍了Android线程间通信Handler使用详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-10-10
  • Android 自定义 HorizontalScrollView 打造多图片OOM 的横向滑动效果(实例代码)

    Android 自定义 HorizontalScrollView 打造多图片OOM 的横向滑动效果(实例代码)

    这篇文章主要介绍了Android 自定义 HorizontalScrollView 打造多图片OOM 的横向滑动效果(实例代码),需要的朋友可以参考下
    2017-10-10
  • Android Usb设备的监听(Dev)外设端口的判定以及耳机的插拔

    Android Usb设备的监听(Dev)外设端口的判定以及耳机的插拔

    今天小编就为大家分享一篇关于Android Usb设备的监听(Dev)外设端口的判定以及耳机的插拔,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2018-12-12
  • Android游戏源码分享之2048

    Android游戏源码分享之2048

    本文主要是给大家分享了安卓版的游戏2048的源码,以及制作思路,是篇非常不错的文章,有需要的朋友可以参考下
    2014-10-10
  • 深入解析Android App开发中Context的用法

    深入解析Android App开发中Context的用法

    这篇文章主要介绍了深入解析Android App开发中Context的用法,包括Context的创建场景和Context对资源的访问等内容,需要的朋友可以参考下
    2016-02-02
  • Android自定义View仿支付宝输入六位密码功能

    Android自定义View仿支付宝输入六位密码功能

    跟选择银行卡界面类似,也是用一个PopupWindow,不过输入密码界面是一个自定义view,当输入六位密码完成后用回调在Activity中获取到输入的密码并以Toast显示密码。这篇文章主要介绍了Android自定义View仿支付宝输入六位密码功能的相关资料,需要的朋友可以参考下
    2016-10-10

最新评论