C# 视频上传之 HTML+JS实现视频上传显示进度条
原文地址:https://www.cnblogs.com/zhangyongl/p/8312881.html
原文博主的后台是PHP写的,本片将使用C#实现后台代码,html+js和原文基本一致。
css样式代码
<style> #userscore_import_style li { padding-bottom: 10px; } #content { border: 1px solid saddlebrown; padding: 16px; border-radius: 2px } .list { top: 15px; width: 140px; height: 40px; border: 1px solid #0082E6; display: inline-block; border-radius: 2px; position: relative; line-height: 40px; } #file { position: absolute; opacity: 0; color: white; width: 100%; height: 100%; z-index: 100; } #fileedi { position: absolute; opacity: 0; color: white; width: 100%; height: 100%; z-index: 100; } .list span { display: inline-block; text-align: center; width: 100%; line-height: 40px; position: absolute; color: #0082E6; } video { margin-top: 8px; border-radius: 4px; } ._p { margin: 14px; } ._p input { display: inline-block; width: 70%; margin-left: 6px; } ._p span { font-size: 15px; } </style>
html代码
<div class="video_add" id="video_add_style" style="display:none;margin:20px;"> <p class="_p"><span>视频标题</span>:<input id="title" type="text" class="form-control" placeholder="请输入视频名称"></p> <p class="_p"> <span>选择视频: </span> <!--文件选择按钮--> <a class="list" href="javascript:;"> <input id="file" type="file" name="myfile" onchange="UpladFile();" /><span>选择视频</span> </a> <!--上传速度显示--> <span id="time"></span> </p> <!--显示消失--> <ul class="el-upload-list el-upload-list--text" style="display: none;"> <li tabindex="0" class="el-upload-list__item is-success"> <a class="el-upload-list__item-name"> <i class="el-icon-document"></i><span id="videoName">food.jpeg</span> </a> <label class="el-upload-list__item-status-label"> <i class="el-icon-upload-success el-icon-circle-check"></i> </label> <i class="fa fa-remove" onclick="del();" style="cursor:pointer">取消</i> <i class="el-icon-close-tip"></i> </li> </ul> <!--进度条--> <div class="el-progress el-progress--line" style="display: none;"> <div class="el-progress-bar"> <div class="el-progress-bar__outer" style="height: 6px;"> <div class="el-progress-bar__inner" style="width: 0%; height:5px;background-color:#0082E6"> </div> </div> </div> <div class="el-progress__text" style="font-size: 14.4px;">0%</div> </div> <p class="_p"><span>上传视频</span>:<button class="btn btn-primary" type="button" onclick="sub();">上传</button></p> <!--预览框--> <div class="preview"> </div> </div>
js代码
<script type="text/javascript"> var xhr;//异步请求对象 var ot; //时间 var oloaded;//大小 //上传文件方法 function UpladFile() { var fileObj = document.getElementById("file").files[0]; // js 获取文件对象 if (fileObj.name) { $(".el-upload-list").css("display", "block"); $(".el-upload-list li").css("border", "1px solid #20a0ff"); $("#videoName").text(fileObj.name); } else { alert("请选择文件"); } } /*点击取消*/ function del() { $("#file").val(''); $("#videoNameEdit").val(''); $(".el-upload-list").css("display", "none"); } /*点击提交*/ function sub() { var fileObj = document.getElementById("file").files[0]; // js 获取文件对象 if (fileObj == undefined || fileObj == "") { alert("请选择文件"); return false; }; var title = $.trim($("#title").val()); if (title == '') { alert("请填写视频标题"); return false; } var url = "/Home/UploadVideo"; // 接收上传文件的后台地址 var form = new FormData(); // FormData 对象 form.append("mf", fileObj); // 文件对象 form.append("title", title); // 标题 xhr = new XMLHttpRequest(); // XMLHttpRequest 对象 xhr.open("post", url, true); //post方式,url为服务器请求地址,true 该参数规定请求是否异步处理。 xhr.onload = uploadComplete; //请求完成 xhr.onerror = uploadFailed; //请求失败 xhr.upload.onprogress = progressFunction; //【上传进度调用方法实现】 xhr.upload.onloadstart = function () { //上传开始执行方法 ot = new Date().getTime(); //设置上传开始时间 oloaded = 0; //设置上传开始时,以上传的文件大小为0 }; xhr.send(form); //开始上传,发送form数据 } //上传进度实现方法,上传过程中会频繁调用该方法 function progressFunction(evt) { // event.total是需要传输的总字节,event.loaded是已经传输的字节。如果event.lengthComputable不为真,则event.total等于0 if (evt.lengthComputable) { $(".el-progress--line").css("display", "block"); /*进度条显示进度*/ $(".el-progress-bar__inner").css("width", Math.round(evt.loaded / evt.total * 100) + "%"); $(".el-progress__text").html(Math.round(evt.loaded / evt.total * 100) + "%"); } var time = document.getElementById("time"); var nt = new Date().getTime(); //获取当前时间 var pertime = (nt - ot) / 1000; //计算出上次调用该方法时到现在的时间差,单位为s ot = new Date().getTime(); //重新赋值时间,用于下次计算 var perload = evt.loaded - oloaded; //计算该分段上传的文件大小,单位b oloaded = evt.loaded; //重新赋值已上传文件大小,用以下次计算 //上传速度计算 var speed = perload / pertime; //单位b/s var bspeed = speed; var units = 'b/s'; //单位名称 if (speed / 1024 > 1) { speed = speed / 1024; units = 'k/s'; } if (speed / 1024 > 1) { speed = speed / 1024; units = 'M/s'; } speed = speed.toFixed(1); //剩余时间 var resttime = ((evt.total - evt.loaded) / bspeed).toFixed(1); time.innerHTML = '上传速度:' + speed + units + ',剩余时间:' + resttime + 's'; if (bspeed == 0) time.innerHTML = '上传已取消'; } //上传成功响应 function uploadComplete(evt) { var data = jQuery.parseJSON(evt.target.responseText); //服务断接收完文件返回的结果 注意返回的字符串要去掉双引号 if (data.code > 0) { //var str = evt.target.responseText; alert("上传成功!"); parent.location.reload(); } else { alert(data.message); } } //上传失败 function uploadFailed(evt) { alert("上传失败!"); } </script>
后台在MVC中以C#实现
[HttpPost] public ActionResult UploadVideo() { var httpRequest = HttpContext.Request; var vName = httpRequest.Form["title"]; var vfile = httpRequest.Files.Get(0); string src = ""; string gb_img_scr = ""; int resultCode = 0; //判断文件是否为空 if (vfile != null) { var nowDta = DateTime.Now.ToString("yyyy-MM-dd"); //获取文件类型 string fileExtension = System.IO.Path.GetExtension(vfile.FileName); var fullname = System.IO.Path.GetFileNameWithoutExtension(vfile.FileName); //自定义文件名(文件名称+唯一标识符+后缀) string fileName = fullname + Guid.NewGuid().ToString("N") + fileExtension; //判断是否存在需要的目录,不存在则创建 var SavePath = "/upload/video/" + nowDta; if (!Directory.Exists(Server.MapPath(SavePath))) { Directory.CreateDirectory(Server.MapPath(SavePath)); } //拼接保存文件的详细路径 string filePath = Server.MapPath(SavePath + "//") + fileName; //若扩展名不为空则判断文件是否是指定视频类型 if (fileExtension != null) { if ("(.mp4)|(.avi)|(.flv)|(.rmvb)|(.wmv)".Contains(fileExtension)) { //保存文件 vfile.SaveAs(filePath); //拼接返回的Img标签 src = SavePath + "/" + fileName; //获取视频第一帧当做视频背景图: gb_img_scr = PicFromVideo.GetPicFromVideo(src, "160*240", "1"); resultCode = 1; } else { src = "不是视频格式!"; resultCode = -1; } } else { src = "上传失败!"; resultCode = -2; } } else { src = "没有找到该文件!"; resultCode = -3; } if (resultCode == 1) { resultCode = adultvideoBll.add(vName, src, gb_img_scr);//向数据库中添加一条数据 } return Json(new { code = resultCode, message = src }); }