【Android】Retrofi的基础使用教程
文章参考学习自 阳光沙滩 ,是我在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的基础使用教程的更多相关文章
- Android基础新手教程——1.10 反编译APK获代替码&资源
Android基础新手教程--1.10 反编译APK获代替码&资源 标签(空格分隔): Android基础新手教程 本节引言: "反编译Apk".看上去好像好像非常高端的样 ...
- Android基础新手教程——1.6 .9(九妹)图片怎么玩
Android基础新手教程--1.6 .9(九妹)图片怎么玩 标签(空格分隔): Android基础新手教程 1.本节引言: 可能有的一些疑问: 1.什么是.9图片? 答:图片后缀名前有.9的图片,如 ...
- Android基础新手教程——3.1 基于监听的事件处理机制
Android基础新手教程--3.1.1 基于监听的事件处理机制 标签(空格分隔): Android基础新手教程 本节引言: 第二章我们学习的是Android的UI控件,我们能够利用这些控件构成一个精 ...
- Android基础新手教程——4.1.3 Activity登堂入室
Android基础新手教程--4.1.3 Activity登堂入室 标签(空格分隔): Android基础新手教程 本节引言: 好的,在学习了两节的Activity后相信大家已经知道怎样去使用Acti ...
- Android基础新手教程——4.1.2 Activity初窥门径
Android基础新手教程--4.1.2 Activity初窥门径 标签(空格分隔): Android基础新手教程 本节引言: 上一节中我们对Activity一些主要的概念进行了了解,什么是Activ ...
- Android基础新手教程——4.4.1 ContentProvider初探
Android基础新手教程--4.4.1 ContentProvider初探 标签(空格分隔): Android基础新手教程 本节引言: 本节给大家带来的是Android四大组件中的最后一个--Con ...
- Android基础新手教程——3.7 AnsyncTask异步任务
Android基础新手教程--3.7 AnsyncTask异步任务 标签(空格分隔): Android基础新手教程 本节引言: 本节给大家带来的是Android给我们提供的一个轻量级的用于处理异步任务 ...
- Android基础新手教程——4.3.1 BroadcastReceiver牛刀小试
Android基础新手教程--4.3.1 BroadcastReceiver牛刀小试 标签(空格分隔): Android基础新手教程 本节引言 本节我们将来学习Android四大组件中的第三个:Bro ...
- Android基础新手教程——4.1.1 Activity初学乍练
Android基础新手教程--4.1.1 Activity初学乍练 标签(空格分隔): Android基础新手教程 本节引言: 本节開始解说Android的四大组件之中的一个的Activity(活动) ...
随机推荐
- FLASK 三剑客 request jinjia2
Flask Web 框架Django 15 优势 : 组件全 - admin - Model ORM - Forms 教科书式 劣势 : 加载所有组件 - 占用资源较高 重型框架 Flask 3 优势 ...
- SQLException:The server time zone
报错信息如下: java.sql.SQLException: The server time zone value 'Öйú±ê׼ʱ¼ä' is unrecognized or represen ...
- IDEA启动报错Plugin Error Problems found loading plugins的解决办法
错误描述 今天启动项目时发现IDEA控制台出错,tomcat的标志变成问号,启动不了服务器 Problems found loading plugins: Plugin "Persisten ...
- 人生需要Plan B
天有不测风云,人有祸兮旦福.2020年,刚打开就是地狱模式! 武汉加油,中国加油! 新冠状肺炎的强传播性,让人们不得不乖乖待在家,工地开不了工,白领不能上班,农村封村,城市封小区.人们每天在一个小范围 ...
- Windows玩转Kubernetes系列3-Centos安装K8S
以往文章参考: Windows玩转Kubernetes系列1-VirtualBox安装Centos Windows玩转Kubernetes系列2-Centos安装Docker 安装K8S yum in ...
- 快乐编程大本营【java语言训练班】第5课: java的数组编程
快乐编程大本营[java语言训练班]第5课: java的数组编程 第1节. 声明数组变量 第2节. 创建数组对象 第3节. 访问数组元素 第4节. 修改数组元素 第5节. 多维数组 学习地址如下:ht ...
- 场景6:具有OpenvSwitch的提供商网络
此场景描述了使用带有Open vSwitch(OVS)的ML2插件的OpenStack网络服务的提供者网络实现. 在OpenStack网络引入分布式虚拟路由器之前,所有网络通信都通过一个或多个专门的网 ...
- JsonCpp中文unicode编码问题
用JsonCpp解析C++中文unicode编码,转换问题,今天找打了一种解决办法 这个问题画了不少时间,贴出来供大家参考 在json_reader.cpp中找到codePointToUTF8函数,添 ...
- 痞子衡嵌入式:Ethos-U55,ARM首款面向Cortex-M的microNPU
大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是ARM Ethos-U55. ARM 前几天刚发布了 Cortex-M 家族最新一款内核 - Cortex-M55 以及首款面向 Cor ...
- python学习(5)写一个二分算法的程序
把之前学习的做一个小结.之前看二分查找法,只能是似而非地看懂大概.现在用这么多天的知识积累已经可以自己写了. 而且在算法书的基础上,把需要找的数字做一个人机互动操作. 另外,初步接触到了 __name ...