Android网络请求(终) 网络请求框架Retrofit
Android网络请求(终) 网络请求框架Retrofit
Retrofit底层是由OkHttp封装的,Retrofit对于注解的使用十分频繁,所以不了解注解的同学们可以去查查资料什么的。
这里有一个小细节,要使用Retrofit至少需要jdk1.8以上和Android API 21以上
Android架构中的MVVM所普遍使用的网络请求框架就是Retrofit。
我们说了,注解的使用很平凡,那么我们来看看Retrofit的注解有哪些吧。
注解
| 注解 | 含义 |
|---|---|
| @GET | 通过GET方式请求 |
| @POST | 通过POST方式请求 |
| @DELETE | 通过DELETE方式请求 |
| @PUT | 通过PUT方式请求 |
| @HEAD | 通过HEAD方式请求 |
| @OPTIONS | 通过OPTIONS方式请求 |
| @PATCH | 通过PATCH方式请求 |
以上的都是请求方式。这里就知道了我们并不是只能有四种请求方式的。
还有一些对这个请求进行标注的注解。
| 注解 | 含义 |
|---|---|
| @Headers | 给请求添加请求头 |
| @Path | 用于restful风格的请求替换其中的路径 |
| @Query | 用于标注请求的参数,一般get请求 |
| @FormUrlEncoded | 表示这个请求以表单的方式提交 |
| @Field | 用于标注请求的参数,一般post请求 |
| @Body | 用于标注请求的参数,一般是一个请求体,可以上传文件或者是一个类 |
上面的就是Retrofit常用注解了。
Retrofit的使用
导入依赖
这里要导入两个依赖包,分别是retrofit2和gson的。因为retrofit2支持直接将获取到的数据转换成实体类对象,方便我们使用。
在项目文件下build.gradle(app)的dependencies中导入所需要的库
implementation group: 'com.squareup.retrofit2', name: 'retrofit', version: '2.6.3'
implementation group: 'com.google.code.gson', name: 'gson', version: '2.8.0'
网络请求
我们先新建一个网络请求类,在其中实例化retrofit。
// 请求地址
public static String IP = "http://www.baidu.com";
// 实例化Retrofit
private static Retrofit retrofit = new Retrofit.Builder()
// 设置Retrofit的基础网络地址
.baseUrl(IP)
// 添加gson实例化工厂
.addConverterFactory(GsonConverterFactory.create())
.build();
设置了baseUrl(IP),之后通过该对象发起的网络请求中默认在你的请求连接地址前加上IP。
新建一个接口,用于存放网络请求的各个地址
public interface Link {
@GET("/s?wd=坚定不移推动构建亚太命运共同体")
Call<String> getBaiDu();
}
在我们的网络请求类中创建一个可以访问到该接口的方法。
public static Link getLink(){
return retrofit.create(Link.class);
}
这里使用的都是公开静态方法和变量,是为了在其他类中更加方便的使用网络请求类。
在MainActivity中去调用它
Net.getLink().getBaiDu().enqueue(new Callback<String>() {
@Override
public void onResponse(Call<String> call, Response<String> response) {
String body = response.body();
System.out.println(body);
}
@Override
public void onFailure(Call<String> call, Throwable throwable) {
}
});
这短代码中只需要你通过网络请求类Net访问Link结构getLink(),调用请求方法getBaiDu();我们会通过get方法去访问如下地址
http://www.baidu.com/s?wd=坚定不移推动构建亚太命运共同体
这其实就是将baseUrl和@GET中的地址拼接起来了。最基本的使用就是这么简单。
当然了,如果我们想将搜索的值设置为一个由用户输入的变量,我们修改getBaiDu方法
@GET("/s")
Call<String> getBaiDu(@Query("wd") String value);
那么在调用时可以作为一个参数传入到该请求中,如
Net.getLink().getBaiDu("坚定不移推动构建亚太命运共同体").enqueue(new Callback<String>() {
@Override
public void onResponse(Call<String> call, Response<String> response) {
String body = response.body();
System.out.println(body);
}
@Override
public void onFailure(Call<String> call, Throwable throwable) {
}
});
如果我们的参数是restful风格的,那么我们需要修改以下传递的参数,比如/s就是restful风格,我们就这么改
@GET("/{path}")
Call<String> getBaiDu(@Path("path") String path,@Query("wd") String value);
那么我们在调用时只需要全部以参数的形式传递即可
Net.getLink().getBaiDu("s","坚定不移推动构建亚太命运共同体").enqueue(new Callback<String>() {
@Override
public void onResponse(Call<String> call, Response<String> response) {
String body = response.body();
System.out.println(body);
}
@Override
public void onFailure(Call<String> call, Throwable throwable) {
}
});
这些效果都是一样的。
如果你需要传入请求头,那么就多加一个参数,如
@Headers({
"Accept: application/json",
"User-Agent: Retrofit-Sample-App"
})
@GET("/{path}")
Call<String> getBaiDu(@Path("path") String path,@Query("wd") String value);
说明
以上注解都是可以用的,如你想post请求那么使用@POST,效果都是一样的。灵活切换,多尝试。Restful的特点就是对开发者特别友好, 性能好,处理快,使用简单、 使用REST API非常方便、支持NIO(新的IO API,可以替代标准的Java IO API)、 默认使用Gson解析 。
想要了解更多的可以去搜一搜这些注解,使用方式就是这么简单,也没多复杂。
可以和LiveData、ViewModle、Rxjava构建MVVM项目结构
网络请求总结
网络请求就到这里了,基本上这些网络框架就是我们日常开发中的全部了,至于HttpClient,它的使用不比java原生的HttpURLConnection方便到哪里去,我就不讲了,同样感兴趣的可以去自行查阅资料。
Android网络请求(终) 网络请求框架Retrofit的更多相关文章
- Android 网络请求框架Retrofit
Retrofit是Square公司开发的一款针对Android网络请求的框架,Retrofit2底层基于OkHttp实现的,OkHttp现在已经得到Google官方认可,大量的app都采用OkHttp ...
- android -------- OkGo (让网络请求更简单的框架)
项目地址:https://github.com/jeasonlzy 该库是封装了okhttp的网络框架,可以与RxJava完美结合,比Retrofit更简单易用.支持大文件上传下载,上传进度回调,下载 ...
- Android探索之HttpURLConnection网络请求
前言: 最近一直想着学习一下比较好的开源网络框架okhttp,想着学习之前还是先总结一下Android原生提供的网络请求.之前一直在使用HttpClient,但是android 6.0(api 23) ...
- 【Android】Volley做网络请求的几种用法
前言: 最近在将自己写的烂代码重构,以前使用的网络请求全是基于apache的HttpClient,简单使用还好,使用多了发现重复代码太多,而且每次使用都很繁琐,因此在网上找了半天网络请求的相关类库,最 ...
- iOS开发——网络篇——文件下载(NSMutableData、NSFileHandle、NSOutputStream)和上传、压缩和解压(三方框架ZipArchive),请求头和请求体格式,断点续传Range
一.小文件下载 NSURL *url = [NSURL URLWithString:@"http://120.25.226.186:32812/resources/images/minion ...
- Android 网络框架--Retrofit
1.导入Jar包 compile 'com.google.code.gson:gson:2.8.0' compile 'com.squareup.retrofit2:retrofit:2.1.0' c ...
- Android开发之http网络请求返回码问题集合。
HTTP状态码(HTTP Status Code) 一些常见的状态码为: 200 - 服务器成功返回网页 404 - 请求的网页不存在 503 - 服务不可用 一.1xx(临时响应) 表示临时响 ...
- 【读书笔记】iOS网络-同步请求,队列式异步请求,异步请求的区别
一,同步请求的最佳实践. 1,只在后台过程中使用同步请求,除非确定访问的是本地文件资源,否则请不要在主线程上使用. 2,只有在知道返回的数据不会超出应用的内存时才使用同步请求.记住,整个响应体都会位于 ...
- 《Android进阶之光》--网络编程与网络框架
No1: Volley源码分析: Volley.newRequestQueue-> RequestQueue.start()-> CacheDispatcher.start()->C ...
- 多线程与网络之NSURLConnection发送请求
*:first-child { margin-top: 0 !important; } body > *:last-child { margin-bottom: 0 !important; } ...
随机推荐
- 【Vue学习笔记】—— vuex的语法 { }
学习笔记 作者:o_Ming vuex Vuex ++ state ++ (用于存储全局数据) 组件访问 state 中的全局数据的方式1: this.$store.state.全局数据 组件访问 s ...
- python包合集-argparse
一.argparse简介 argparse 是 python 自带的命令行参数解析包,可以用来方便的服务命令行参数,使用之前需要先导入包 import argparse 二.简单案例 简单使用,创建一 ...
- 在 Kubernetes 容器集群,微服务项目最佳实践
转载自:https://mp.weixin.qq.com/s/WYu3gDwKKf06f_FYbO9YRg 本文主要介绍我个人在使用 Kubernetes 的过程中,总结出的一套「Kubernetes ...
- Kubernetes 日志:搭建 EFK 日志系统
Kubernetes 中比较流行的日志收集解决方案是 Elasticsearch.Fluentd 和 Kibana(EFK)技术栈,也是官方现在比较推荐的一种方案. Elasticsearch 是一个 ...
- ES重要配置解析
path.data和path.logs 如果您使用.zip或.tar.gz存档,则data和logs 目录是子文件夹$ES_HOME.如果这些重要文件夹保留在其默认位置,则在将Elasticsearc ...
- Springboot配置文件参数使用docker-compose实现动态配置
文章总结; Springboot配置文件中的一些参数可以写成变量的形式,具体变量的值可以从docker-compose.yml文件中设置来获取 在yml文件中,通过${Envirment_variab ...
- flask中验证用户登录的装饰器
from flask import Flask,render_template,redirect,request,session from functools import wraps app = F ...
- nginx干货文档
文档地址:https://files.cnblogs.com/files/sanduzxcvbnm/跟冰河学习Nginx技术.pdf
- 220501 T1 困难的图论 (tarjan 点双)
求满足题目要求的简单环,做出图中所有的点双,用vector存储点双中的边,如果该点双满足点数=边数,就是我们想要的,求边的异或和即可:如果该点双点数小于边数,说明有不只一个环覆盖,不满足题意. 1 # ...
- AspNetCore中 使用 Grpc 简单Demo
为什么要用Grpc 跨语言进行,调用服务,获取跨服务器调用等 目前我的需要使用 我的抓取端是go 写的 查询端用 Net6 写的 导致很多时候 我需要把一些临时数据写入到 Redis 在两个服务器进行 ...