zoukankan      html  css  js  c++  java
  • 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=" 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 });
            }
  • 相关阅读:
    MAXSCRIPT 连数据库(转)
    Docker安装部署ELK教程 (Elasticsearch+Kibana+Logstash+Filebeat)
    ArrayList知识点
    HashMap知识点
    使用docker 安装nacos
    记录docker 安装sonarqube和安装的一些坑
    sql优化
    Centos7下安装Docker
    使用docker安装gitlab
    docker安装jenkins
  • 原文地址:https://www.cnblogs.com/xinbaba/p/11363678.html
Copyright © 2011-2022 走看看