文章参考学习自 阳光沙滩 ,是我在B站上发现的宝藏Up主,超级棒!

在前段时间我写了一个java web后台,想做一个安卓端的打卡社区,后来发现请求和解析过于麻烦,就耽搁了。

趁着空闲,研究了一下大部分项目中都采用的MVP+RxJava+Retrofit模式中的Retrofit,发现异常好用,特此记录一下。

环境配置

implementation 'com.squareup.retrofit2:retrofit:2.7.1'

retrofit是基于okhttp的二次封装,在上一次文章中我们介绍了Gson这个强大的工具(点我跳转),这里retrofit也提供了配套的基于Gson的转换器

 implementation 'com.squareup.retrofit2:converter-gson:2.4.0'

都导入进来吧~

另外,由于安卓9.0禁止明文传输,需要单独设置一下:

联网权限

 <uses-permission android:name="android.permission.INTERNET" />

允许明文访问

 android:usesCleartextTraffic="true"

另外,请在build.gradle(app)中开启java 1.8支持

compileOptions {
sourceCompatibility 1.8
targetCompatibility 1.8
}

请求接口设置

retrofit在请求时候是使用注解来说明请求方式的

写法同springboot的controller层相似

都是注解(路径)+方法(传参)

这里主要介绍几个比较常用的

后台使用的是 https://gitee.com/sunofbeaches/SOBAndroidMiniWeb

所有注解都应该写在一个接口类中,这里命名为API.class

Retrofit初始化

 private static Retrofit retrofit=new Retrofit.Builder()
.baseUrl("http://10.0.2.2:9102")
.addConverterFactory(GsonConverterFactory.create())//增加一个转换工厂
.build();

值得一提的是,这里的10.0.2.2是安卓虚拟机访问电脑的ip地址

无参Get请求

这里@get代表get请求,后面是绝对路径

 @GET("/get/text")
Call<JsonResult> getJson();

方法体的返回类型都是Call<T>

这个也不难理解,在okhttp中返回的是一个ResponseBody

然后我们需要使用Gson对这个字符串进行解析再转成对象

而有了Retrofit以后我们可以直接让他自动解析转成相应类型

有参Get请求

@GET("/get/param")
Call<GetWithParamsResult>getWithParams(@Query("keyword")String keyword,
@Query("page")int page,
@Query("order")int order);

参数的格式为:@Query(‘参数名称’)参数类型 变量名称

当然如果参数很多,你可以直接使用Map来传值,即

 @GET("/get/param")
Call<GetWithParamsResult>getWithParams(@QueryMap Map<String,Object> params);

POST请求

@POST("/post/string")
Call<PostWithParamsResult>postWithParams(@Query("string")String content);

同理,这里只需要把注解改成@POST即可。

提一下,我们在设置返回类型的时候,可以使用一个工具:GsonFormat,把返回的json丢进去,会自动分析并生成对应的Bean类,非常方便

如何使用

在设置好接口后,我们就可以实例化接口对象了。

public void postWithParams(View view) {
Retrofit retrofit = RetrofitManager.getRetrofit();//获得一个Retrofit对象
API api = retrofit.create(API.class);//通过接口创建一个API实体
Call<PostWithParamsResult> c = api.postWithParams("hello world");//由接口获取相应的请求方法
c.enqueue(new Callback<PostWithParamsResult>() {
@Override
public void onResponse(Call<PostWithParamsResult> call, Response<PostWithParamsResult> response) {
//我们可以看到,这里的Call的结果已经自动转变成实体对象了
//只需要使用response.body()即可获得
//在获取之前我们可以先判断一下状态
if(response.code()== HttpURLConnection.HTTP_OK){//判断是否请求成功
PostWithParamsResult result=response.body();
//TODO
} } @Override
public void onFailure(Call<PostWithParamsResult> call, Throwable t) { }
});
}

我们可以看出,使用retrofit大大减少了我们配置、解析结果的代码量,非常方便。

同时将请求方法全部写在接口中,方便修改,简洁明了~

【Android】Retrofi的基础使用教程的更多相关文章

  1. Android基础新手教程——1.10 反编译APK获代替码&amp;资源

    Android基础新手教程--1.10 反编译APK获代替码&资源 标签(空格分隔): Android基础新手教程 本节引言: "反编译Apk".看上去好像好像非常高端的样 ...

  2. Android基础新手教程——1.6 .9(九妹)图片怎么玩

    Android基础新手教程--1.6 .9(九妹)图片怎么玩 标签(空格分隔): Android基础新手教程 1.本节引言: 可能有的一些疑问: 1.什么是.9图片? 答:图片后缀名前有.9的图片,如 ...

  3. Android基础新手教程——3.1 基于监听的事件处理机制

    Android基础新手教程--3.1.1 基于监听的事件处理机制 标签(空格分隔): Android基础新手教程 本节引言: 第二章我们学习的是Android的UI控件,我们能够利用这些控件构成一个精 ...

  4. Android基础新手教程——4.1.3 Activity登堂入室

    Android基础新手教程--4.1.3 Activity登堂入室 标签(空格分隔): Android基础新手教程 本节引言: 好的,在学习了两节的Activity后相信大家已经知道怎样去使用Acti ...

  5. Android基础新手教程——4.1.2 Activity初窥门径

    Android基础新手教程--4.1.2 Activity初窥门径 标签(空格分隔): Android基础新手教程 本节引言: 上一节中我们对Activity一些主要的概念进行了了解,什么是Activ ...

  6. Android基础新手教程——4.4.1 ContentProvider初探

    Android基础新手教程--4.4.1 ContentProvider初探 标签(空格分隔): Android基础新手教程 本节引言: 本节给大家带来的是Android四大组件中的最后一个--Con ...

  7. Android基础新手教程——3.7 AnsyncTask异步任务

    Android基础新手教程--3.7 AnsyncTask异步任务 标签(空格分隔): Android基础新手教程 本节引言: 本节给大家带来的是Android给我们提供的一个轻量级的用于处理异步任务 ...

  8. Android基础新手教程——4.3.1 BroadcastReceiver牛刀小试

    Android基础新手教程--4.3.1 BroadcastReceiver牛刀小试 标签(空格分隔): Android基础新手教程 本节引言 本节我们将来学习Android四大组件中的第三个:Bro ...

  9. Android基础新手教程——4.1.1 Activity初学乍练

    Android基础新手教程--4.1.1 Activity初学乍练 标签(空格分隔): Android基础新手教程 本节引言: 本节開始解说Android的四大组件之中的一个的Activity(活动) ...

随机推荐

  1. FLASK 三剑客 request jinjia2

    Flask Web 框架Django 15 优势 : 组件全 - admin - Model ORM - Forms 教科书式 劣势 : 加载所有组件 - 占用资源较高 重型框架 Flask 3 优势 ...

  2. SQLException:The server time zone

    报错信息如下: java.sql.SQLException: The server time zone value 'Öйú±ê׼ʱ¼ä' is unrecognized or represen ...

  3. IDEA启动报错Plugin Error Problems found loading plugins的解决办法

    错误描述 今天启动项目时发现IDEA控制台出错,tomcat的标志变成问号,启动不了服务器 Problems found loading plugins: Plugin "Persisten ...

  4. 人生需要Plan B

    天有不测风云,人有祸兮旦福.2020年,刚打开就是地狱模式! 武汉加油,中国加油! 新冠状肺炎的强传播性,让人们不得不乖乖待在家,工地开不了工,白领不能上班,农村封村,城市封小区.人们每天在一个小范围 ...

  5. Windows玩转Kubernetes系列3-Centos安装K8S

    以往文章参考: Windows玩转Kubernetes系列1-VirtualBox安装Centos Windows玩转Kubernetes系列2-Centos安装Docker 安装K8S yum in ...

  6. 快乐编程大本营【java语言训练班】第5课: java的数组编程

    快乐编程大本营[java语言训练班]第5课: java的数组编程 第1节. 声明数组变量 第2节. 创建数组对象 第3节. 访问数组元素 第4节. 修改数组元素 第5节. 多维数组 学习地址如下:ht ...

  7. 场景6:具有OpenvSwitch的提供商网络

    此场景描述了使用带有Open vSwitch(OVS)的ML2插件的OpenStack网络服务的提供者网络实现. 在OpenStack网络引入分布式虚拟路由器之前,所有网络通信都通过一个或多个专门的网 ...

  8. JsonCpp中文unicode编码问题

    用JsonCpp解析C++中文unicode编码,转换问题,今天找打了一种解决办法 这个问题画了不少时间,贴出来供大家参考 在json_reader.cpp中找到codePointToUTF8函数,添 ...

  9. 痞子衡嵌入式:Ethos-U55,ARM首款面向Cortex-M的microNPU

    大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是ARM Ethos-U55. ARM 前几天刚发布了 Cortex-M 家族最新一款内核 - Cortex-M55 以及首款面向 Cor ...

  10. python学习(5)写一个二分算法的程序

    把之前学习的做一个小结.之前看二分查找法,只能是似而非地看懂大概.现在用这么多天的知识积累已经可以自己写了. 而且在算法书的基础上,把需要找的数字做一个人机互动操作. 另外,初步接触到了 __name ...