热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

OkHttp网络请求框架入门(一)

一、android网络请求进化史。二、okHttp的简介(OKHttp的项目地址:https:github.comsquareokhttp)Android为我们提供了两种H

一、android网络请求进化史。

这里写图片描述

二、okHttp的简介(OKHttp的项目地址:https://github.com/square/okhttp )
Android为我们提供了两种HTTP交互的方式: HttpURLConnection 和 Apache HTTP Client,虽然两者都支持HTTPS,流的上传和下载,配置超时,IPv6和连接池,已足够满足我们各种HTTP请求的需求。但更高效的使用HTTP可以让您的应用运行更快、更节省流量。而OkHttp库就是为此而生。
三、okHttp特点。
1、OkHttp是一个高效的HTTP库:

  • 支持 SPDY ,共享同一个Socket来处理同一个服务器的所有请求
  • 如果SPDY不可用,则通过连接池来减少请求延时
  • 无缝的支持GZIP来减少数据流量
  • 缓存响应数据来减少重复的网络请求
  • 一般的get请求
  • 一般的post请求
  • 基于Http的文件上传
  • 文件下载
  • 加载图片
  • 支持请求回调,直接返回对象、对象集合
  • 支持session的保持

2、OkHttp会从很多常用的连接问题中自动恢复。如果您的服务器配置了多个IP地址,当第一个IP连接失败的时候,会自动尝试下一个IP。OkHttp还处理了代理服务器问题和SSL握手失败问题。(并发)

3、使用 OkHttp 无需重写您程序中的网络代码。OkHttp实现了几乎和java.net.HttpURLConnection一样的API。如果您用了 Apache HttpClient,则OkHttp也提供了一个对应的okhttp-apache 模块。

4、从上面的简单介绍中可以知道,虽然在编程上面并不会简洁很多,但是OKHttp内部的一些功能能够帮助我们自动完成一些很复杂的操作,笔者个人认为最大的卖点就是大大节省用户的流量。

三、OkHttp简单使用。
1、在Gradle中引入CardView的依赖库。

compile 'com.squareup.okhttp3:okhttp:3.8.0'

2、OKHttp在使用之前,首先要了解下面几个比较核心的类以及它的功能。

  • OkHttpClient 客户端对象
  • Request是OkHttp中访问的请求,Post请求中需要包含RequestBody
  • Builder是辅助类,用于生产对象
  • Response即OkHttp中的响应,响应中可以得到返回是否成功,返回数据
  • MediaType 数据类型,用来表明是JSON等一系列格式
  • RequestBody 请求数据,在Post请求中用到
  • client.newCall(request).execute()是同步的请求方法
  • client.newCall(request).enqueue(Callback callBack)是异步的请求方法,但是Callback里面的代码是执行在子线程的,因此不能更新UI。

3、OKHttp的基本使用步骤(以POST方式从服务器取JSON数据为例)

  • 创建OkHttpClient对象,官方文档要求我们最好使用单例模式,在后文对OKHttp进行封装的时候会提到。
  • 如果是post请求的话,需要通过FormEncodingBuilder创建RequestBody对象,指定需要post传进去的参数。get请求则不用。
  • 创建Request对象,这个对象是请求对象,需要指定URL。post请求的时候需要指定RequestBody对象,get请求则不用。
  • 调用OkHttpClient的newCall方法,把Request对象传进去,然后执行execute或者enqueue方法,两者的区别在上文已提到。在CallBack中的onResponse方法就可以做你需要做的事。onResponse回调的参数是response,一般情况下,比如我们希望获得返回的字符串,可以通过response.body().string()获取;如果希望获得返回的二进制字节数组,则调用response.body().bytes();如果你想拿到返回的inputStream,则调用response.body().byteStream()看到这,你可能会奇怪,竟然还能拿到返回的inputStream,看到这个最起码能意识到一点,这里支持大文件下载,有inputStream我们就可以通过IO的方式写文件。不过也说明一个问题,这个onResponse执行的线程并不是UI线程。的确是的,如果你希望操作控件,还是需要使用handler等。

类型一:Http Get

OkHttpClient client=new OkHttpClient();

String run(String url) throws IOException{
Request request=new Request.Builder()
.url(url)
.build();

Response repOnse=client.newCall(request).execure();
return response.body().string():
}
OkHttpClient client=new OkHttpClient();

String run(String url) throws IOException{
Request request=new Request.Builder()
.url(url)
.build();

client.newCall(request).enqueue(new Callback() {
@Override
public void onFailure(Call call, IOException e) {
//请求失败。
}
@Override
public void onResponse(@NonNull Call call, @NonNull Response response) throws IOException {
if (response.isSuccessful()) {
//请求成功。
} else {

}
}
});

类型二:Http POST(JSON)
MediaType 数据类型。
RequestBody 请求数据。

public static final MediaType JSON=MediaType.parse("application/json; charset=utf-8");

OkHttpClient client=new OkHttpClient();
String post(String url,String json) throws IOException{
RequestBody body=RequestBody.create(JSON,json);
Request request=new Request.Builder()
.url(url)
.post(body)
.build();
Response response=client.newCall(request).execute();
return response.body().string();

}

类型三、Http POST(FormData)

OkHttpClient client=new OkHttpClient();
String post(String url, String json) throws IOException{

//okhttp1.0
RequestBody formBody=new FormEncodingBuilder()
.add("platform","android")
.add("name","bug")
.add("subject","")
.build();

//okhttp2.0
FormBody.Builder formBody= new FormBody.Builder();
.add("platform","android")
.add("name","bug")
.add("subject","")
.build();

Request request=new Request.Builder()
.url(url)
.post(body)
.bulid();
Response respOnse=client.newCall(request).execute();
}

鸿洋大神okHttp讲解:http://blog.csdn.net/lmj623565791/article/details/47911083。


推荐阅读
author-avatar
平凡咸伟
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有