OkGo详解

OkGo详解一 什么是 OkGoOkGo 基于 okhhttp 的封装类 你会发现他真的比 okhttp 简单的多 一个专注于让网络请求更简单的框架 与 RxJava 完美结合 比 Retrofit 更简单易用 二 主要功能 1 基本的 get post put delete head options trace patch 八种请求 2 支持 upString upJson upBytes upFile 等 up 类方法上传特定数据 3 支持一个 key 上传一个文件 也可以一个 key 上传多个文件 也

一.什么是OkGo

OkGo,基于okhhttp的封装类,你会发现他真的比okhttp简单的多,一个专注于让网络请求更简单的框架,与 RxJava 完美结合,比 Retrofit 更简单易用。

二.主要功能

1)基本的 get、post、put、delete、head、options、trace、patch 八种请求;

2) 支持 upString,upJson,upBytes,upFile 等 up 类方法上传特定数据;

3) 支持一个 key 上传一个文件,也可以一个 key 上传多个文件,也可以多文件和多参数一起上传;

4) 大文件下载和下载进度回调;

5) 大文件上传和上传进度回调;

6) 支持 cookie 的自动管理,并可自定义 cookie 管理策略;

7) 支持缓存模式,不仅支持 http 缓存协议,也支持自定义缓存策略;

8) 支持重定向;

9) 支持自定义超时自动重连次数;

10) 支持链式调用;

11) 支持 https 访问,支持双向认证;

12) 支持根据 tag 取消请求,也可全部取消;

13) 支持自定义 Callback,自动解析网络数据;

三.引入

//必须使用 compile 'com.lzy.net:okgo:3.0.4' //以下三个选择添加,okrx和okrx2不能同时使用 compile 'com.lzy.net:okrx:1.0.2' compile 'com.lzy.net:okrx2:2.0.2' compile 'com.lzy.net:okserver:2.0.5' //或者 compile 'com.lzy.net:okgo:+' //版本号使用 + 可以自动引用最新版 compile 'com.lzy.net:okrx:+' //版本号使用 + 可以自动引用最新版 compile 'com.lzy.net:okserver:+' //版本号使用 + 可以自动引用最新版

注意事项

使用该网络框架时,必须要在 Application 中做初始化,详细的初始化办法点击这里 

okgo使用的okhttp的版本是最新的3.8.0版本,OkGo详细文档点击这里 

okrx是基于RxJava的扩展项目,OkRx详细文档点击这里 

okrx2是基于RxJava2的扩展项目,OkRx2详细文档点击这里 

okserver是对okgo的扩展,包含两个核心入口类:

OkDownload是统一的下载管理,支持断点续传功能,OkDownload详细文档点击这里 

OkUpload是统一的上传管理,OkUpload详细文档点击这里

四.配置初始化

在baseApplication初始化okgo的配置,具体配置及说明如下:

 private void initOkGo() { OkHttpClient.Builder builder = new OkHttpClient.Builder(); //log相关 HttpLoggingInterceptor loggingInterceptor = new HttpLoggingInterceptor("OkGo"); //log打印级别,决定了log显示的详细程度 loggingInterceptor.setPrintLevel(HttpLoggingInterceptor.Level.BODY); //log颜色级别,决定了log在控制台显示的颜色 loggingInterceptor.setColorLevel(Level.INFO); //设置请求头,token值 HttpHeaders headers = new HttpHeaders(); headers.put("X-Access-Token", SPUtils.get(SpKey.TOKEN, "")+""); // LogUtils.v("X-Access-Token:" + SPUtils.get(SpKey.TOKEN, "")); builder.addInterceptor(loggingInterceptor); //自动管理cookie(或者叫session的保持),以下几种任选其一就行 //使用sp保持cookie,如果cookie不过期,则一直有效 //builder.cookieJar(new CookieJarImpl(new SPCookieStore(this))); //使用数据库保持cookie,如果cookie不过期,则一直有效 builder.cookieJar(new CookieJarImpl(new DBCookieStore(this))); //使用内存保持cookie,app退出后,cookie消失 //builder.cookieJar(new CookieJarImpl(new MemoryCookieStore())); //超时时间设置,默认60秒 //全局的读取超时时间 builder.readTimeout(OkGo.DEFAULT_MILLISECONDS, TimeUnit.MILLISECONDS); //全局的写入超时时间 builder.writeTimeout(OkGo.DEFAULT_MILLISECONDS, TimeUnit.MILLISECONDS); //全局的连接超时时间 builder.connectTimeout(OkGo.DEFAULT_MILLISECONDS, TimeUnit.MILLISECONDS); OkGo.getInstance().init(this) .setOkHttpClient(builder.build()) //全局统一缓存模式,默认不使用缓存,可以不传 .setCacheMode(CacheMode.NO_CACHE) //全局统一缓存时间,默认永不过期,可以不传 .setCacheTime(CacheEntity.CACHE_NEVER_EXPIRE) //设置公共请求头 .addCommonHeaders(headers) //全局统一超时重连次数,默认为三次,那么最差的情况会请求4次(一次原始请求,三次重连请求),不需要可以设置为0; .setRetryCount(0); }

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/233242.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 视频标清、高清、全高清的分类分辨率码率帧率参考(附图)

    视频标清、高清、全高清的分类分辨率码率帧率参考(附图)视频标清、高清、全高清的分类分辨率码率帧率参考(附图)视频标清、高清、全高清的分类分辨率码率帧率参考(附图)

    2022年5月6日
    176
  • 如何编写符合rest架构风格的restful?_php restful api 框架

    如何编写符合rest架构风格的restful?_php restful api 框架RESTful架构&简单使用Django rest framework

    2022年4月21日
    37
  • NFV介绍_NFV技术

    NFV介绍_NFV技术转发自:https://zhuanlan.zhihu.com/p/26259440NFV全称是NetworkFunctionVirtualization。这又是一个与网络相关的故事。先来看看NFV的前世今生吧。在NFV之前,NF(NetworkFunction)是一直存在的,网络中,NF可以看成一个个独立的网元,实现着各自的功能。NF以固定的方式连接起来,统一提供的网络功能和服务。随便在网…

    2025年10月16日
    4
  • 安捷伦示波器使用说明书_安捷伦labview采集

    安捷伦示波器使用说明书_安捷伦labview采集Step1:配置VISA协议。VISA协议是AgilentIOLibraries的一部分,主要包含一个虚拟仪器软件架构VISA(一个比较通用的工业仪器软件架构)和标准控制库SICL.我理解前者相当一个底层架构,后者相当于一个指令集.先配置好VISA,然后通过SICL指令集发命令。直接上例子,简单明了。agilent示波器可以直接用VISA,所以只要在C++项目里进行配置。首先在C++里配…

    2022年10月12日
    0
  • DVWA安装以及模块使用教程(一)

    DVWA安装以及模块使用教程(一)一 DVWA 介绍 DVWA DamnVulnerab 是 randomstorm 的一个开源项目 一个用来进行安全脆弱性鉴定的 PHP MySQLWeb 应用 旨在为安全专业人员测试自己的专业技能和工具提供合法的环境 帮助 web 开发者更好的理解 web 应用安全防范的过程 DVWA 共有十个模块 分别是 1 BruteForce 密码激活成功教程 2 CommandInjec 命令行注入 3 CSRF 跨站请求伪造 4 FileInclusio 文件包含 5 F

    2025年8月9日
    4
  • realm数据库使用

    realm数据库使用

    2022年3月12日
    41

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号