Retrofit2简单使用教程

作者: JimLong | 来源:发表于2016-11-07 16:47 被阅读61次
简介

RetrofitSquare开 发的一个Android和Java的REST客户端库。这个库非常简单并且具有很多特性,相比其他的网络库,更容易让初学者快速掌握。它可以处理GET、 POST、PUT、DELETE...等请求

概述
1429351394587168.png
  • ** POJO或模型实体类 : **从服务器获取的JSON数据将被填充到这种类的实例中。
public class UserModel {
  private int id;
  private String login;
  private String avatar_url;
  private String gravatar_id;
  private String url;
  ...
}
  • **接口 : **我们需要创建一个接口来管理像GET,POST…等请求的URL,这是一个服务类。
public interface ApiService {
    String BASE_API = "https://api.github.com";

    @GET("/users")
    Call<UserModel> getUser();
}
  • **RestAdapter类 : **这是一个REST客户端(RestClient)类,retrofit中默认用的是Gson来解析JSON数据,你也可以设置自己的JSON解析器,比如jackson,Gson等。
  Retrofit retrofit=new Retrofit.Builder()
          .addConverterFactory(GsonConverterFactory.create())
          .baseUrl(ApiService.BASE_API)
          .build();

  ApiService service=retrofit.create(ApiService.class);
  Call<UserModel> call = service.getUser();
  call.enqueue(new Callback<UserModel>() {
      @Override
      public void onResponse(Call<UserModel> call, Response<UserModel> response) {
      }
      @Override
      public void onFailure(Call<UserModel> call, Throwable t) {
      }
  });
Retrofit的使用

首先,在使用Retrofit之前还是老规矩,导包

compile 'com.squareup.retrofit2:retrofit:2.1.0'
//只是使用retrofit不解析数据可以不导下面这个包
compile'com.squareup.retrofit2:converter-gson:2.1.0'
Retrofit支持的基本的HTTP请求

在Retrofit中使用注解的方式来区分请求类型.比如:
@GET("")表示一个GET请求,括号中的内容为请求的地址.

格式 含义
@GET 表示这是一个GET请求
@POST 表示这个一个POST请求
@PUT 表示这是一个PUT请求
@DELETE 表示这是一个DELETE请求
@HEAD 表示这是一个HEAD请求
@OPTIONS 表示这是一个OPTION请求
@PATCH 表示这是一个PAT请求
Retrofit的简单实现
直接请求型

1. 如果是直接请求某一地址:

@GET("/users")
Call<List<UserModel>> getUserList();

2.如果是组合后直接请求:

@GET("/users/{user}")
Call<UserModel> getUser(@Path("user") String user);
带参查询型
//    https://api.github.com/search/users?q=retrofit&page=1&per_page=2
    @GET("/search/users")
    Call<BaseModel> groupList(@Query("q") String query, @Query("page") String page, @Query("per_page") int per_page);
带Header型

比如要更新某个账户信息,其接口地址为/info,需要带的Header有设备信息device,系统版本version,还要带请求参数要更新账户的id,如下:

@POST("/info")
Call<Object> updateInfo(@Header("device") String device, @Header("version") int version, @Field("id") String id);
基础URL

构建Retrofit实例如下:

Retrofit retrofit = new Retrofit.Builder()
        .addConverterFactory(GsonConverterFactory.create())//添加Gson解析数据
        .baseUrl(ApiService.BASE_API)
        .build();
获取Github用户列表
ApiService service=retrofit.create(ApiService.class);
Call<List<UserModel>> call = service.getUserList();
call.enqueue(new Callback<List<UserModel>>() {
    @Override
    public void onResponse(Call<List<UserModel>> call, Response<List<UserModel>> response) {
        if (response.isSuccessful()){//请求解析成功判断
            mTxt.append("\n name:\t"+response.body().get(0).getLogin());
            mTxt.append("\n type:\t"+response.body().get(0).getType());
            mTxt.append("\n admin:\t"+response.body().get(0).isSite_admin());
        }
    }
    @Override
    public void onFailure(Call<List<UserModel>> call, Throwable t) {
        mTxt.setText(t.getMessage());
    }
});

Github的接口基础地址为:https://api.github.com/ ,具体的接口点击链接自行查看。

相关文章

  • Retrofit2简单使用教程

    简介 Retrofit是Square开 发的一个Android和Java的REST客户端库。这个库非常简单并且具有...

  • Retrofit 学习笔记(转载)

    转自 你真的会用Retrofit2吗?Retrofit2完全教程 一、使用步骤 1、在 Gradle加入Retro...

  • Java Retrofit2使用--自定义转换器

    Java Retrofit2使用--自定义转换器 Retrofit2的基础使用请参考Java Retrofit2使...

  • Retrofit2简单使用

    1. Gradle配置 2. 基本的get请求 我们使用GankApi 来进行测试。如: 获取闲读的主分类 ht...

  • Retrofit2简单使用

    以前一直用OkHttp网络框架,最近换Retrofit2,顺便整理笔记 整理分为7步: 1.导入开源库(Retro...

  • retrofit2.0源码分析

    Android 手把手教你使用Retrofit2 Retrofit2源码分析 总结 这里总结下Retrofit2的...

  • 手摸手一步一步来制作BmobJavaSDK(一)

    引用的技术 Retrofit2 RxJava Lombok 目标 使用简单、高效。尽可能让服务和使用者之间不用产生...

  • Retrofit2文件上传与下载

    Retrofit2文件上传与下载通俗易懂教程。 之前在使用retrofit的时候,遇到文件上传和下载的功能,搜索了...

  • Retrofit2

    一、Retrofit2 GitHub:Retrofit2Demo 二、Retrofit2概念 三、使用 四、基本使...

  • Retrofit2.0基本使用

    Android网络编程(九)Retrofit2前篇[基本使用] Android网络编程(十)Retrofit2后篇...

网友评论

    本文标题:Retrofit2简单使用教程

    本文链接:https://www.haomeiwen.com/subject/yfknuttx.html