上个项目中用到了上传视频,本来打算用百度的webuploader做的,但是webuploader可能有个毛病就是不能上传太大的东西。

于是乎,只能换个方法做了啊,看了半天最终决定用传统的uploaderfile来做。顺便吐槽下uploaderfile真的是,和webuploader相比完全是有点复杂啊

OK回到正题,这个uploaderfile最为重要的个人感觉就是引用--一般情况下要注意引用的顺序,要先引用jq.min而且是只能引用一次,不然就会报错,笔者之前用的模板就有一个引用,然后又引用了一次也是非常的吃瘪啊。

要想成功的使用webuploaderfile需要引用4个东西算上jq需要有5个

引用成功后到下一步就是网页的布局问题--需要一些布局

<tr id="aa1">
<td>
上传视频
</td>
<td>
<div style="margin-top:20px;text-align:left;">
<span>请上传:</span>
<span style='color:blue;'>(只支持,'mp4')</span>
</div>
<div style="margin-top:10px;">
<form action="" name="" enctype="multipart/form-data">
<input id="upload" type="file" name="files" class="upinput" param1="xxx" />
</form>
</div>
<div id="progress" style="width:200px;margin-bottom:10px;">
进度条:<div class="bar" style="width: 0%;"></div>
</div>
<!-- 预览框: -->
<div class="preview"></div> </td> </tr>

由于这个项目笔者没有怎么用心,所以命名什么都比较随意了一些
OK接下来就是在Js中实例化代码了

<script type="text/javascript">
$("#upload").fileupload({
autoUpload: true, type: 'post', url: "@Url.Action("UploadVideo")",//文件上传地址,当然也可以直接写在input的data-url属性内 dataType: "json", //如果不指定json类型,则传来的json字符串就需要解析jQuery.parseJSON(data.result); progressall: function (e, data) {
var progress = parseInt(data.loaded / data.total * 100, 10);
$('#progress .bar').css(
'width',
progress + '%'
);
}, done: function (e, data) {
//done方法就是上传完毕的回调函数,其他回调函数可以自行查看api
//注意data要和jquery的ajax的data参数区分,这个对象包含了整个请求信息
//返回的数据在data.result中,这里dataType中设置的返回的数据类型为json
if (data.result.sta) {
// 上传成功:
$(".preview").html("<video width='640' id='video111' height='360' src=" + data.result.previewSrc +
" id='player1'controls='controls' preload='none'></video> ");
} else {
// 上传失败:
alert(data.result.msg);
} }
});
</script>

这里面我做了一些限制和后来上传成功后能够成功的插入一段新的视屏代码

再次顺便提一下笔者的视屏控件属于html5自带的video控件,笔者完成项目的时候老师要求的是使用flash插件来使用,对于此笔者表示不解和无趣。flash播放视频的时候笔者认为很快就会结束了,于是直接使用了html5的方式

完成前台的这些设计后就是后台控制器中的判断上传视频的问题了

   [HttpPost]
public ActionResult UploadVideo(HttpPostedFileBase files=null)
{
if (files != null && files.ContentLength > )
{
string folderpath = "/UploadFile/Video/";
if (!Directory.Exists(folderpath))
{
Directory.CreateDirectory(Server.MapPath(folderpath));
}
string ext1 = Path.GetExtension(files.FileName);
if (ext1 != ".mp4" && ext1 != ".wmv" && ext1 != ".mpeg" && ext1 != ".avi" && ext1 != ".mp3" && ext1 != ".wav" && ext1 != ".wma" && ext1 != ".rmvb")
{
return Json(new { sta = false, msg = "文件格式不正确!" });
}
else
{
string name = DateTime.Now.ToString("yyyyMMddHHmmssff");
string ext = Path.GetExtension(files.FileName);
string downpath = folderpath + name + ext;
string filepath = Server.MapPath(folderpath) + name + ext;
files.SaveAs(filepath);
return Json(new { sta = true, previewSrc = downpath, id = name });
}
}
else
{
return Json(new { sta = false, msg = "请上传文件!" });
}
}

和上一个笔者写的上传图片一样视频存的文件夹在上传图片里面的一个子文件夹

不过笔者这儿偷懒了,判断格式的时候没怎么写。这大概是我当初对这个项目不怎么上心的缘故吧

功能自此已经完全实现了,接下来我会放出效果图

上面是样式我们先来一个其他格式的文件

会直接报错显示格式不正确
接下来上传一个正常的视频文件

上传成功样式直接出来

视频也能正常播放

OK基本上到这儿就全部结束了

mvc实现上传视频预览的更多相关文章

  1. ASP.NET MVC图片上传前预览

    回老家过春节,大半个月,在家的日子里,吃好睡好,人也长了3.5Kg.没有电脑,没有网络,无需写代码,工作上相关的完全放下......开心与父母妻儿过个年,那样的生活令Insus.NET现在还在留恋.. ...

  2. mvc上传图片(上传和预览)webuploader

    笔者看到mvc最近比较流行,而很多使用一些比较旧的的方法上传图片,再次安利一下百度的webuploader控件吧 webuploader第一步要先下载一些插件这点可以在webuploader官网上下载 ...

  3. FileReader与URL.createObjectURL实现图片、视频上传前预览

    之前做图片.视频上传预览常用的方案是先把文件上传到服务器,等服务器返回文件的地址后,再把该地址字符串赋给img或video的src属性,这才实现所谓的文件预览.实际上这只是文件“上传后再预览”,这既浪 ...

  4. input file实现多选,限制文件上传类型,图片上传前预览功能

    限制上传类型 & 多选:① accept 属性只能与 <input type="file" /> 配合使用.它规定能够通过文件上传进行提交的文件类型. ② mu ...

  5. hTML5实现表单内的上传文件框,上传前预览图片,针刷新预览images

    hTML5实现表单内的上传文件框,上传前预览图片,针刷新预览images, 本例子主要是使用HTML5 的File API,建立一個可存取到该file的url, 一个空的img标签,ID为img0,把 ...

  6. html之file标签 --- 图片上传前预览 -- FileReader

    记得以前做网站时,曾经需要实现一个图片上传到服务器前,先预览的功能.当时用html的<input type="file"/>标签一直实现不了,最后舍弃了这个标签,使用了 ...

  7. 【转】HTML5 jQuery图片上传前预览

    hTML5实现表单内的上传文件框,上传前预览图片,针刷新预览images,本例子主要是使用HTML5 的File API,建立一個可存取到该 file的url,一个空的img标签,ID为img0,把选 ...

  8. Jcrop+uploadify+php实现上传头像预览裁剪

    最近由于项目需要,所以做了一个上传头像预览并且可以预览裁剪的功能,大概思路是上传的图片先保存到服务器,然后通过ajax从服务器获取到图片信息,再利用Jcrop插件进行裁剪,之后通过PHP获取到的四个裁 ...

  9. 图片上传本地预览。兼容IE7+

    基于JQUERY扩展,图片上传预览插件 目前兼容浏览器(IE 谷歌 火狐) 不支持safari 预览地址:http://www.jinbanmen.com/test/1.html js代码:/**名称 ...

随机推荐

  1. Windows安装和使用zookeeper

    之前整理过一篇文章<zookeeper 分布式锁服务>,本文介绍的 Zookeeper 是以 3.4.5 这个稳定版本为基础,最新的版本可以通过官网 http://hadoop.apach ...

  2. 一个App完成入门篇(七)- 完成发现页面

    第七章是入门篇的倒数第二篇文章了,明天整个APP将进入收官. 本节教程主要要教会大家使用二维码扫描和用do_WebView组件加在html页面. 导入项目 do_WebView组件 扫描功能 自定义事 ...

  3. Net作业调度(二) -CrystalQuartz远程管理

    Source Code-1.6M 介绍 上篇已经了解Quartz.NET的基本使用方法了.但如果想方便的知道某个作业执行情况,需要暂停,启动等操作行为,这时候就需要个Job管理的界面. 本文介绍Qua ...

  4. upload4j安全、高效、易用的java http文件上传框架

    简介 upload4j是一款轻量级http文件上传框架,使用简单,实现高效,功能专一,摆脱传统http文件上传框架的繁琐. upload4j的诞生并不是为了解决所有上传需求,而是专注于基础通用需求. ...

  5. Stored Procedure 里的 WITH RECOMPILE 到底是干麻的?

    在 SQL Server 创建或修改「存储过程(stored procedure)」时,可加上 WITH RECOMPILE 选项,但多数文档或书籍都写得语焉不详,或只解释为「每次执行此存储过程时,都 ...

  6. 2013 duilib入门简明教程 -- 部分bug 2 (14)

        上一个教程中提到了ActiveX的Bug,即如果主窗口直接用变量生成,则关闭窗口时会产生崩溃            如果用new的方式生成,则不会崩溃,所以给出一个临时的快速解决方案,即主窗口 ...

  7. MongoDB 之C#实践

    官方驱动:https://github.com/mongodb/mongo-csharp-driver/downloads.下载后,还提供了一个酷似msdn的帮助文档. samus驱动:https:/ ...

  8. Uiautomator 2.0之Configrator类学习小记

    1. Configration类介绍 1.1. Configrator用于设置脚本动作的默认延时 1.2  Configrator功能: 1.2.1 可调节两个模拟动作之间的默认间隔 1.2.2 可调 ...

  9. c#利用泛型集合,为自己偷偷懒。

    有人说"越懒"的程序员进步的越快!其实还挺有道理.亲身体验,从刚出来工作到现在,自己变"懒"了许多,但感觉写出来的代码确有了不少提升.刚开始啊,同样的代码,赋值 ...

  10. Design6:选择合适的数据类型

    数据库使用Table来存储海量的数据,细分Table结构,数据最终存储在Table Column中,因此,在设计Table Schema时,必须慎重选择Table Column的Data Type,数 ...