Android OkHttp 框架超时设置详解

OkHttp 提供了四种不同的超时设置,每种针对网络请求的不同阶段:

1. callTimeout (调用超时)

  • 作用:控制整个调用从开始到结束的总时间,包括所有重定向和重试

  • 默认值:0 (不超时)

  • 场景:当你希望限制整个请求的完成时间,无论中间经过多少次重定向或重试

  • 设置方法

    OkHttpClient client = new OkHttpClient.Builder() .callTimeout(30, TimeUnit.SECONDS) .build(); //这里设置为0,则永不超时

注:在弱网情况下,博主遇到还没下载完就判断为超时,导致下载失败,这时候需要设置callTimeout时间,可以修复问题

2. connectTimeout (连接超时)

  • 作用:控制与目标服务器建立连接的时间

  • 默认值:10秒

  • 场景:当服务器响应慢或网络状况差时,防止长时间等待连接建立

  • 设置方法

    OkHttpClient client = new OkHttpClient.Builder() .connectTimeout(15, TimeUnit.SECONDS) .build();

3. readTimeout (读取超时)

  • 作用:控制从服务器读取数据的间隔时间(两次数据包之间的时间)

  • 默认值:10秒

  • 场景:防止服务器响应慢或传输大文件时连接被长时间占用

  • 设置方法

    OkHttpClient client = new OkHttpClient.Builder() .readTimeout(30, TimeUnit.SECONDS) .build();

4. writeTimeout (写入超时)

  • 作用:控制向服务器发送数据的间隔时间(两次数据包之间的时间)

  • 默认值:10秒

  • 场景:防止上传大文件时由于网络状况差导致长时间占用连接

  • 设置方法

    OkHttpClient client = new OkHttpClient.Builder() .writeTimeout(30, TimeUnit.SECONDS) .build();

超时设置建议

  1. 根据网络环境调整:移动网络下建议设置较长的超时时间

  2. 根据请求类型调整:上传/下载大文件时需要增加读写超时

  3. 优先级关系:callTimeout > connectTimeout + readTimeout + writeTimeout

  4. 特殊需求:对于关键请求可以设置较短的callTimeout,确保快速失败

示例配置

复制代码
OkHttpClient client = new OkHttpClient.Builder()
    .callTimeout(60, TimeUnit.SECONDS)    // 总超时60秒
    .connectTimeout(15, TimeUnit.SECONDS) // 连接超时15秒
    .readTimeout(30, TimeUnit.SECONDS)    // 读取超时30秒
    .writeTimeout(30, TimeUnit.SECONDS)   // 写入超时30秒
    .build();

这些超时设置可以帮助你更好地控制网络请求行为,避免因网络问题导致应用无响应。

相关推荐
一起搞IT吧16 小时前
相机Camera日志实例分析之二十:相机Camx【照片后置4800/5000/6400万拍照】单帧流程日志详解
android·嵌入式硬件·数码相机·智能手机
jinanwuhuaguo17 小时前
(第三十三篇)五月的文明奠基:OpenClaw 2026.5.2版本的文明级解读
android·java·开发语言·人工智能·github·拓扑学·openclaw
千码君201619 小时前
Trae:一些关于flutter和 go前后端开发构建的分享
android·flutter·gradle·android-studio·trae·vibe code
重生之我是Java开发战士1 天前
【MySQL】事务 & 用户与权限管理
android·数据库·mysql
怣疯knight1 天前
Windows不安装 Android Studio如何打包安卓软件
android·windows·android studio
ke_csdn1 天前
从Java演变到Kotlin下的jet pack
android
wenzhangli71 天前
在低代码设计中践行 Harness Engineering
android·低代码·rxjava
xingpanvip1 天前
星盘接口开发文档:组合三限盘接口指南
android·开发语言·前端·python·php·lua
TechMix1 天前
【fkw学习笔记】Android 13 AOSP 源码添加系统预置应用实战指南
android·笔记·学习
云起SAAS1 天前
私域直播系统UniApp源码 多商户商城+直播带货 微信小程序+H5+安卓iOS
android·微信小程序·uni-app·私域直播系统