BootStrap Progressbar 实现大文件上传的进度条的实例代码


Posted in Javascript onJune 27, 2016

1.首先实现大文件上传,如果是几兆或者几十兆的文件就用基本的上传方式就可以了,但是如果是大文件上传的话最好是用分片上传的方式。我这里主要是使用在客户端进行分片读取到服务器段,然后保存,到了服务器段读取完了之后将分片数据进行组合。

2.前端代码如下:

<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="UploadTest2.aspx.cs" Inherits="Html5UploadTest.UploadTest2" %>
<html lang="zh-CN">
<head>
<meta charset="utf-8">
<title>HTML5大文件分片上传示例</title>
<script src="Scripts/jquery-1.8.2.js"></script>
<link href="bootstrap-progressbar/bootstrap-progressbar-3.3.4.css" rel="stylesheet" />
<script src="bootstrap-progressbar/bootstrap-progressbar.js"></script>
<%--<link href="JqueryUI/jquery-ui.css" rel="stylesheet" />
<script src="JqueryUI/jquery-ui.js"></script>--%>
<script>
function uploadFile() {
$("#upload").attr("disabled", "disabled");
var file = $("#file")[0].files[0], //文件对象
fileNum = $("#file")[0].files[0].length,
name = file.name, //文件名
size = file.size, //总大小
succeed = 0;
var shardSize = 2 * 1024 * 1024, //以2MB为一个分片
shardCount = Math.ceil(size / shardSize); //总片数
$('.progress .progress-bar').attr('data-transitiongoal', 0).progressbar({ display_text: 'fill' });
for (var i = 0; i < shardCount; ++i) {
//计算每一片的起始与结束位置
var start = i * shardSize,
end = Math.min(size, start + shardSize);
//构造一个表单,FormData是HTML5新增的
var form = new FormData();
form.append("data", file.slice(start, end)); //slice方法用于切出文件的一部分
form.append("name", name);
form.append("total", shardCount); //总片数
form.append("index", i + 1); //当前是第几片
//Ajax提交
$.ajax({
url: "Upload.ashx",
type: "POST",
data: form,
async: true, //异步
processData: false, //很重要,告诉jquery不要对form进行处理
contentType: false, //很重要,指定为false才能形成正确的Content-Type
success: function () {
++succeed;
$("#output").text(succeed + " / " + shardCount);
var percent = ((succeed / shardCount).toFixed(2)) * 100;
updateProgress(percent);
if (succeed == shardCount) {
$("#upload").removeAttr("disabled");
}
}
});
}
}
function progress(percent, $element) {
var progressBarWidth = percent * $element.width() / 100;
$element.find('div').animate({ width: progressBarWidth }, 500).html(percent + "% ");
}
//$(document).ready(function () {
// $('.progress .progress-bar').progressbar({ display_text: 'fill' });
//});
function updateProgress(percentage) {
$('.progress .progress-bar').attr('data-transitiongoal', percentage).progressbar({ display_text: 'fill' });
}
</script>
</head>
<body>
<input type="file" id="file" />
<button id="upload" onclick="uploadFile();">上传</button>
<span id="output" style="font-size: 12px">等待</span>
<div class="progress">
<div id="progressBar" class="progress-bar" role="progressbar" data-transitiongoal=""></div>
</div>
</body>
</html>

3. 后台一般处理程序如下:

using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Web;
namespace Html5UploadTest
{
/// <summary>
/// Summary description for Upload
/// </summary>
public class Upload : IHttpHandler
{
public void ProcessRequest(HttpContext context)
{
context.Response.ContentType = "text/plain";
try
{
//从Request中取参数,注意上传的文件在Requst.Files中
string name = context.Request["name"];
int total = Convert.ToInt32(context.Request["total"]);
int index = Convert.ToInt32(context.Request["index"]);
var data = context.Request.Files["data"];
//保存一个分片到磁盘上
string dir = context.Request.MapPath("~/temp");
string file = Path.Combine(dir, name + "_" + index);
data.SaveAs(file);
//如果已经是最后一个分片,组合
//当然你也可以用其它方法比如接收每个分片时直接写到最终文件的相应位置上,但要控制好并发防止文件锁冲突
if (index == total)
{
file = Path.Combine(dir, name);
//byte[] bytes = null;
using (FileStream fs = new FileStream(file, FileMode.OpenOrCreate))
{
for (int i = 1; i <= total; ++i)
{
string part = Path.Combine(dir, name + "_" + i);
//bytes = System.IO.File.ReadAllBytes(part);
//fs.Write(bytes, 0, bytes.Length);
//bytes = null;
System.IO.File.Delete(part);
fs.Close();
}
}
}
}
catch (Exception)
{
throw;
}
//返回是否成功,此处做了简化处理
//return Json(new { Error = 0 });
}
public bool IsReusable
{
get
{
return false;
}
}
}
}

4.当然了后台还需要一些异常处理或者断电续传的工作要做,待续。。。

以上所述是小编给大家介绍的BootStrap Progressbar 实现大文件上传的进度条的实例代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
checkbox全选/取消全选以及checkbox遍历jQuery实现代码
Dec 02 Javascript
js调用iframe实现打印页面内容的方法
Mar 04 Javascript
js实现ctrl+v粘贴上传图片(兼容chrome、firefox、ie11)
Mar 09 Javascript
基于JavaScript FileReader上传图片显示本地链接
May 27 Javascript
使用ES6语法重构React代码详解
May 09 Javascript
vue多种弹框的弹出形式的示例代码
Sep 18 Javascript
vue.js,ajax渲染页面的实例
Feb 11 Javascript
Angular4集成ng2-file-upload的上传组件
Mar 14 Javascript
通过jquery.cookie.js实现记住用户名、密码登录功能
Jun 20 jQuery
跟混乱的页面弹窗说再见
Apr 11 Javascript
基于Vue 撸一个指令实现拖拽功能
Oct 09 Javascript
javascript 代码是如何被压缩的示例代码
May 06 Javascript
JavaScript事件详细讲解
Jun 27 #Javascript
JS原型链怎么理解
Jun 27 #Javascript
js选择器全面解析
Jun 27 #Javascript
通过javascript进行UTF-8编码的实现方法
Jun 27 #Javascript
jQuery实现每隔几条元素增加1条线的方法
Jun 27 #Javascript
jQuery实现查找链接文字替换属性的方法
Jun 27 #Javascript
全面了解javascript三元运算符
Jun 27 #Javascript
You might like
在laravel中实现ORM模型使用第二个数据库设置
2019/10/24 PHP
JavaScript中令你抓狂的魔术变量
2006/11/30 Javascript
js中将字符串转换成json的三种方式
2011/01/12 Javascript
基于JavaScript自定义构造函数的详解说明
2013/04/24 Javascript
ComboBox 和 DateField 在IE下消失的解决方法
2013/08/30 Javascript
js history对象简单实现返回和前进
2013/10/30 Javascript
html5 canvas js(数字时钟)实例代码
2013/12/23 Javascript
js几秒以后倒计时跳转示例
2013/12/26 Javascript
如何书写高质量jQuery代码(使用jquery性能问题)
2014/06/30 Javascript
jQuery制作简单柱状图实例
2015/01/28 Javascript
VUEJS实战之修复错误并且美化时间(2)
2016/06/13 Javascript
JS实现的简单下拉框联动功能示例
2018/05/11 Javascript
微信小程序实现顶部导航特效
2019/01/28 Javascript
详解微信UnionID作用
2019/05/15 Javascript
[02:32]DOTA2亚洲邀请赛 C9战队出场宣传片
2015/02/07 DOTA
[44:50]2018DOTA2亚洲邀请赛 4.1 小组赛 A组 TNC vs VG
2018/04/02 DOTA
python实现定制交互式命令行的方法
2014/07/03 Python
Python中运行并行任务技巧
2015/02/26 Python
Python实现字典的key和values的交换
2015/08/04 Python
如何使用七牛Python SDK写一个同步脚本及使用教程
2015/08/23 Python
Python基于matplotlib实现绘制三维图形功能示例
2018/01/18 Python
Python实现随机漫步功能
2018/07/09 Python
python中将\\uxxxx转换为Unicode字符串的方法
2018/09/06 Python
用python3读取python2的pickle数据方式
2019/12/25 Python
通过python连接Linux命令行代码实例
2020/02/18 Python
浅谈Pytorch中的自动求导函数backward()所需参数的含义
2020/02/29 Python
Python3 中sorted() 函数的用法
2020/03/24 Python
基于Python+QT的gui程序开发实现
2020/07/03 Python
详解Canvas 跨域脱坑实践
2018/11/07 HTML / CSS
美国购买新书和二手书网站:Better World Books
2018/10/31 全球购物
竟聘演讲稿范文
2013/12/31 职场文书
秋季婚礼证婚词
2014/01/11 职场文书
班主任工作年限证明
2014/01/12 职场文书
2015年仓库管理工作总结
2015/05/25 职场文书
2016年优秀党员教师先进事迹材料
2016/02/29 职场文书
Mysql中where与on的区别及何时使用详析
2021/08/04 MySQL