asp.net多文件上传实例讲解
2020-02-23 16:00:17来源:爱站网 阅读 ()
asp.net在WEB开发中也是经常会使用的,然而使用文件上传也是很普遍的情况,开发过程中我们也是会遇到一些困难的,程序员需要花费很久的时间进行开发,下面爱站技术频道小编就给大家带来asp.net多文件上传实例讲解。
文件上传简单实现是非常容易的,但是想要更高的要求,比如通过ajax上传文件、一次上传多个文件、文件比较大等等,这里面的坑就不是很容易填(对于新手来说)。因此在这里我准备通过ajax实现多文件上传。在开始贴代码之前,要注意几点:
1.<input type="file" />是必须要加name的,不知道为什么不加name属性,后台获取不到文件数据(有办法的大神可以在评论区提醒我),然后是multiple属性,当multiple="multiple"时,file控件是可以多选需要上传的文件的(<input type="file" multiple="multiple"? name="myFile" />)。
2.form要设enctype为multiple/form-data,multipart/form-data表示:不对字符编码,在使用包含文件上传控件的表单时,必须使用该值。关于enctype的详细讲解可以查看http://www.jb51.net/web/165444.html
3.重点来了,ajax的参数设置里面有大坑(很多人都没注意ajax的众多参数),contentType和processData需要设为false,contentType明明被要求为string类型,但是这里要设为false(我也不知道为什么),网上关于contentType的说明大多是"contentType:要求为String类型的参数,当发送信息至服务器时,内容编码类型默认为"application/x-www-form-urlencoded"。该默认值适合大多数应用场合",还有个data要设为new FormData($(' ')[0]),想了解其他参数的可看这个http://www.jb51.net/article/95425.htm?。
下面就是简单的前台代码:
<form id="uploadForm" enctype="multipart/form-data" action="/Login/uploadFile" method="post"> <input type="file" multiple="multiple" id="PersonFile" name="MyFile" /> <button type="button" id="submitFile" onclick="uploadFile()">提交</button> </form>
//上传文件 function uploadFile() { debugger $.ajax({ url: '/Login/uploadFile', type: 'POST', cache: false, data: new FormData($('#uploadForm')[0]), processData: false, // 关键点 contentType: false, // 关键点 success: function (result) { if (result.Check) { alert("成功"); } else { alert("失败"); } var file = $("#PersonFile") file.after(file.clone().val("")); file.remove(); } }); }
现在轮到后台了,我这边后台是通过System.Web.HttpContext.Current.Request.Files获取文件数据集的,之后的代码我将以图片为例。
[HttpPost] public ActionResult uploadFile() { Result<string> check = new Result<string>(); try { HttpFileCollection files = System.Web.HttpContext.Current.Request.Files; int number = 0; for (int i = 0; i < files.Count; i++) { System.Text.StringBuilder fileName = new System.Text.StringBuilder(); fileName.Append(@"D:\"); fileName.Append(DateTime.Now.ToString("yyMMdd")); fileName.Append(@"\"); if (!System.IO.Directory.Exists(fileName.ToString())) { System.IO.Directory.CreateDirectory(fileName.ToString()); } fileName.Append(System.IO.Path.GetFileNameWithoutExtension(files[i].FileName)); fileName.Append(DateTime.Now.ToString("yyMMddHHmmss")); fileName.Append(System.IO.Path.GetExtension(files[i].FileName)); System.IO.Stream sm = files[i].InputStream; if (System.IO.File.Exists(@"D:\水印log.jpg")) { ImageHelper.ZoomAuto(sm, fileName.ToString(), 400, 300, "", @"D:\水印log.jpg"); } else { ImageHelper.ZoomAuto(sm, fileName.ToString(), 400, 300, "水印LOG", ""); } bool ok = System.IO.File.Exists(fileName.ToString()); if (ok) { number++; } } if (number.Equals(files.Count)) { check.Message = "上传成功!"; check.Check = true; } else { check.Message = "失败!"; check.Check = false; } return Json(check); } catch(Exception ex) { check.Message = ex.ToString(); check.Check = false; return Json(check); } }
/// <summary> /// 返回值 /// </summary> public class Result<T> { public string Message { get; set; } public bool Check { get; set; } public IList<T> ResultList { get; set; } }
其中用到了ImageHelper.ZoomAuto(),这个是吴剑大哥写的图片处理类,地址http://www.cnblogs.com/wu-jian/archive/2011/02/21/1959382.html。最后还有一个坑,就是asp.net对一次上传数据的大小是有限制的,要解除限制才能10个20个文件同时上传。如何解除限制?在web.config里面配置一下就OK了。代码如下:
<system.web> <authentication mode="None" /> <compilation debug="true" targetFramework="4.5" /> <!--<httpRuntime targetFramework="4.5" />--> <httpRuntime executionTimeout="500" maxRequestLength="409600" useFullyQualifiedRedirectUrl="false" minFreeThreads="8" minLocalRequestFreeThreads="4" appRequestQueueLimit="100" /> </system.web>
把<httpRuntime >放<system.web>节点下。
以上是爱站技术频道小编带给大家的asp.net多文件上传实例讲解,希望对诸多学习能有所帮助,我们在开发过程中希望给诸多学者带来更好的体验。
原文链接:https://js.aizhan.com/develop/aspnet/11698.html
如有疑问请与原作者联系
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
- asp.net源程序编译为dll文件并调用的实现过程 2020-03-29
- Asp.net MVC SignalR来做实时Web聊天实例代码 2020-03-29
- ASP.NET MVC中jQuery与angularjs混合应用传参并绑定数据 2020-03-29
- Asp.Net中WebForm的生命周期 2020-03-29
- ASP.NET使用Ajax返回Json对象的方法 2020-03-23
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash