0

0

HTML5如何实现本地缓存上传_HTML5本地缓存上传思路【储备】

雪夜

雪夜

发布时间:2026-01-17 16:41:02

|

936人浏览过

|

来源于php中文网

原创

HTML5本地缓存上传本质是文件上传前持久化存储于IndexedDB以支持断点续传和跨页恢复;localStorage仅适合存分片索引等轻量数据,URL.createObjectURL()适用于单页内临时预览。

html5如何实现本地缓存上传_html5本地缓存上传思路【储备】

HTML5 本地缓存上传的核心其实是“不上传”

所谓“本地缓存上传”,并不是 HTML5 提供了一个叫 cacheUpload() 的新 API。它本质是:在文件真正发到服务器前,先保存在本地(如 localStorageIndexedDB 或临时 Blob URL),供后续读取、预览、断点续传或离线编辑。关键判断点是——你是否需要在页面刷新/关闭后仍能恢复未完成的上传? 如果不需要,用 File 对象 + FormData 直传即可;如果需要,则必须持久化存储原始文件数据。

用 IndexedDB 存原始 File 对象最稳妥

localStorage 只支持字符串,强行 JSON.stringify(file) 会丢失 File 的二进制内容和元信息(如 lastModifiedname)。而 IndexedDB 原生支持存储 FileBlob,是唯一可靠选择。

  • 写入时:监听 input[type="file"]change 事件,拿到 event.target.files[0],直接存入 IDBObjectStore
  • 读取时:用 get() 拿回 File 对象,可构造 FormData 或生成预览 URL:
    const url = URL.createObjectURL(file);
  • 注意:FileBlob 的子类,所以 indexedDB 存储无兼容性问题(Chrome 24+、Firefox 16+、Edge 12+)

上传中断后如何恢复?靠服务端配合 + 客户端分片校验

前端无法“续传”已发出但未完成的 HTTP 请求。所谓“恢复上传”,实际是:把大文件切片,每片单独上传并由服务端返回唯一标识(如 MD5 或分片序号),客户端记录哪些片成功、哪些失败,重试失败片。本地缓存此时只存原始文件和已成功上传的分片索引(例如存在 localStorage 里)。

  • 切片用 file.slice(start, end)(返回 Blob),不要用 ArrayBuffer 手动读取——容易内存溢出
  • 每个分片请求头带上 X-Upload-ID: X-Chunk-Index: 0,服务端据此合并
  • 页面刷新后,从 localStorage 读取 uploadId 和已成功 chunkIndices,跳过重传
  • 错误场景:Network Error504 Gateway Timeout 后,不能直接重发整个文件,必须按片重试

临时预览别用 localStorage,用 URL.createObjectURL()

如果只是想在当前页面内预览用户选中的图片/视频(比如上传前裁剪),URL.createObjectURL(file) 是最快最省内存的方式。它返回一个生命周期绑定到当前文档的 blob: URL,页面关闭即自动释放。

Text-To-Song
Text-To-Song

免费的实时语音转换器和调制器

下载

立即学习前端免费学习笔记(深入)”;

  • 千万别把 file 转成 base64localStorage:10MB 图片 base64 后膨胀至 ~13.3MB,且每次读取都要解码,卡顿明显
  • 也别用 readAsDataURL() + localStorage:同上,且多一次异步读取开销
  • 正确做法:
    const input = document.querySelector('input[type="file"]');
    input.addEventListener('change', e => {
    const file = e.target.files[0];
    const url = URL.createObjectURL(file);
    document.querySelector('#preview').src = url;
    });

真正麻烦的是跨页面恢复——比如用户上传到一半去填表单,回来还要接着传。这时候必须用 IndexedDB 存文件本体,再加一层服务端状态同步逻辑。很多人卡在这一步,不是因为技术做不到,而是低估了服务端分片合并的健壮性要求。

相关专题

更多
504 gateway timeout怎么解决
504 gateway timeout怎么解决

504 gateway timeout的解决办法:1、检查服务器负载;2、优化查询和代码;3、增加超时限制;4、检查代理服务器;5、检查网络连接;6、使用负载均衡;7、监控和日志;8、故障排除;9、增加缓存;10、分析请求。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

567

2023.11.27

default gateway怎么配置
default gateway怎么配置

配置default gateway的步骤:1、了解网络环境;2、获取路由器IP地址;3、登录路由器管理界面;4、找到并配置WAN口设置;5、配置默认网关;6、保存设置并退出;7、检查网络连接是否正常。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

220

2023.12.07

json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

412

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

533

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

309

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

74

2025.09.10

html5动画制作有哪些制作方法
html5动画制作有哪些制作方法

html5动画制作方法有使用CSS3动画、使用JavaScript动画库、使用HTML5 Canvas等。想了解更多html5动画制作方法相关内容,可以阅读本专题下面的文章。

505

2023.10.23

HTML与HTML5的区别
HTML与HTML5的区别

HTML与HTML5的区别:1、html5支持矢量图形,html本身不支持;2、html5中可临时存储数据,html不行;3、html5新增了许多控件;4、html本身不支持音频和视频,html5支持;5、html无法处理不准确的语法,html5能够处理等等。想了解更多HTML与HTML5的相关内容,可以阅读本专题下面的文章。

427

2024.03.06

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

42

2026.01.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
极致CMS零基础建站教学视频
极致CMS零基础建站教学视频

共62课时 | 5.4万人学习

如何进行WebSocket调试
如何进行WebSocket调试

共1课时 | 0.1万人学习

传智播客AJAX视频教程
传智播客AJAX视频教程

共31课时 | 6.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号