Firefox浏览器JavaScript大文件上传及进度显示

0 下载量 182 浏览量 更新于2024-09-01 收藏 85KB PDF 举报
"Firefox浏览器使用JavaScript上传大文件的示例" 在本文中,我们将探讨如何利用Firefox 3.x 版本的浏览器特性,通过JavaScript实现大文件的上传,并且在上传过程中显示实时的进度信息。这种方法的核心是利用HTML中的`<input type="file">`元素(file-input节点)以及XMLHttpRequest对象(xmlHTTPRequest)来实现文件的分块上传。这样的技术对于处理大文件特别有用,因为它允许我们逐步发送文件,而不是一次性加载整个文件到内存。 首先,我们需要创建一个`<input type="file">`元素让用户选择要上传的文件。当用户选择文件后,我们可以通过JavaScript访问这个文件,然后将其分割成较小的数据块。这样做的好处是可以避免一次性加载大文件导致的内存压力和性能问题。 在JavaScript代码中,我们可以监听文件输入元素的`change`事件,获取选中的文件对象。然后,使用`FileReader` API读取文件内容,通过`readAsArrayBuffer()`方法将文件转换为ArrayBuffer,以便进一步处理。接着,使用`onprogress`事件监听上传进度,更新用户界面。 XMLHttpRequest对象则用于实际的文件上传。我们创建一个新的XMLHttpRequest实例,设置适当的请求头(如Content-Type),并开启一个持续的HTTP POST请求。在每次上传数据块时,使用`send()`方法发送ArrayBuffer数据。为了实现断点续传,服务器端需要记录已接收的数据位置,以便在下次上传时能正确接续。 需要注意的是,Firefox浏览器对文件大小可能有限制,虽然具体的临界点未知,但建议不要尝试上传超过100MB的文件,以防止可能出现的问题。同时,这个方法仅在Firefox 3.x 版本中得到支持,其他浏览器可能需要使用不同的技术,如Flash或Silverlight来实现类似的功能。 以下是一个简化的JavaScript代码片段,展示了文件选择、读取、分块和上传的基本流程: ```javascript function FireFoxFileSender(config) { // 初始化配置、错误处理等 ... // 监听文件选择事件 document.getElementById('fileInput').addEventListener('change', function(e) { var file = e.target.files[0]; // 分块处理文件并上传 chunkFile(file); }); function chunkFile(file) { var reader = new FileReader(); reader.onload = function(e) { var arrayBuffer = e.target.result; // 分割并上传文件 sendChunk(arrayBuffer); }; reader.readAsArrayBuffer(file); } function sendChunk(chunk) { // 创建XMLHttpRequest实例并设置请求参数 ... // 发送数据块 xhr.send(chunk); } } ``` 以上代码是一个简化版的FireFoxFileSender函数,它演示了如何处理文件选择、读取和分块上传的基本步骤。实际项目中,你还需要添加错误处理、进度更新和服务器端的配合代码,以确保上传过程的完整性和可靠性。 Firefox浏览器的文件API为我们提供了一种在JavaScript中处理大文件上传的有效方式,通过分块读取和发送,可以实现大文件的动态上传和进度显示,甚至扩展到断点续传功能。然而,这种技术在不同浏览器中的兼容性各异,需要根据目标用户的浏览器环境进行适配。
2012-09-16 上传
HttpUploader4全面升级了文件IO组件。新的IO组件在处理磁盘中的文件时,将不必再对文件执行I/O操作,这意味着在对文件进行处理时将不必再为文件申请并分配缓存,所有的文件缓存操作均由系统直接管理,由于取消了将文件数据加载到内存、数据从内存到文件的回写以及释放内存块等步骤,使得HttpUploader4在处理TB级数据时能够拥有闪电般的速度。 新的IO组件赋予了HttpUploader4更强的大数据处理能力。现在HttpUploader4在对GB级文件进行MD5校验时速度提高了4倍。同时CPU占用率更低。 HttpUploader4更加注重对硬盘的保护,在HttpUploader4中不再直接对文件进行I/O操作,而是在内存中对文件进行操作,所以不仅极大的减少了对硬盘的读写次数,同时速度却变的更快了。 借助于HttpUploader4企业能够帮助用户更加轻松的处理工作中的文件,让用户与用户之间的沟通更加的高效。从根本上提高企业竞争力。 考虑到不同的企业使用的开发平台不同,我们已经为企业开发人员提供了完整的与数据库相结合的示例(ASP.NET,JSP,PHP)。开发人员能够非常容易的在自已的系统中实现断点续传功能。 产品特点如下: 1. 为TB级文件提供稳定传输功能。 2. 优化MD5组件,文件扫描速度提升70%。 3. 保护磁盘,上传超大文件时,磁盘IO次数降低50%。 4. 采用全新设计IO组件,上传任意文件大小时始终占用128KB内存。 5. 支持文件及文件夹拖拽上传功能。 6. 支持文件批量上传。 7. 支持文件夹上传。 8. 基于标准HTTP协议。 9. 免费提供JavaScript SDK包,方便您将插件快速集成到已有网站中。 支持语言:PHP,JSP,ASP,ASP.NET(C#),ASP.NET(VB),C++,VC,VC.NET,VB,VB.NET,C#,C#.NET,Delphi,C++Builder 支持平台:Visual Studio 6.0/2002/2003/2005/2008/2010,C++ Builder 6.0/2009/2010,Delphi 7/2009,Visual Basic 6.0/2008,MyEclipse8.x 支持脚本:JavaScript,VBScript 支持服务器:Windows NT,Windows 2003,Windows XP,Windows Vista,Windows 7,Linux,Unix 支持浏览器:IE6,IE7,IE8,360安全浏览器,QQ浏览器,搜狐浏览器,Maxthon(遨游)浏览器1.X,Maxthon(傲游)浏览器2.x 支持文件大小:2G~8EB(1EB=102PB,1PB=1024TB,1TB=1024GB) 支持文件类型:任意类型 版权所有 2009-2012 武汉命运科技有限公司 保留所有权利 官方网站:http://www.ncmem.com/ 产品首页:http://www.ncmem.com/webplug/http-uploader3/index.aspx 在线演示:http://www.ncmem.com/products/http-uploader3/demo/index.html 产品介绍:http://www.cnblogs.com/xproer/archive/2012/05/29/2523757.html 开发文档-ASP:http://www.cnblogs.com/xproer/archive/2012/02/17/2355458.html 开发文档-PHP:http://www.cnblogs.com/xproer/archive/2012/02/17/2355467.html 开发文档-JSP:http://www.cnblogs.com/xproer/archive/2012/02/17/2355462.html 开发文档-ASP.NET:http://www.cnblogs.com/xproer/archive/2012/02/17/2355469.html 升级日志:http://www.cnblogs.com/xproer/archive/2012/02/17/2355449.html 资源下载:cab安装包,开发文档, 示例下载(ASP.NET):ASP.NET-ACCESS示例 示例下载(JSP):JSP-ACCESS示例(GB2312),JSP-ACCESS示例(UTF-8),JSP-Sql2005示例(UTF-8),JSP-MySQL示例(UTF-8) 示例下载(PHP):MySQL示例(UTF-8) 问题反馈:http://www.ncmem.com/bbs/showforum-4.aspx VC运行库:http://www.microsoft.com/download/en/details.aspx?displaylang=en&id=29 联系信箱:1085617561@qq.com 联系QQ:1085617561