Webform(文件上传)
Posted fei!
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Webform(文件上传)相关的知识,希望对你有一定的参考价值。
1.html编码:
<input type="file" />
2.控件:FileUpload
它是用来选择要上传的文件,还需要一个按钮来将选中的文件上传到服务器上
string path = "images/" + FileUpload1.FileName;
FileUpload1.SaveAs(Server.MapPath(path));
优化1:文件保留原有名称和后缀
string path = "images/" + FileUpload1.FileName;
优化2:防止重名,或是同一时间多个人同时上传同一名称文件
string path = "images/" + DateTime.Now.ToString("yyyyMMddhhssmmms") + Request.Cookies["ures"].Value + FileUpload1.FileName;
优化3:可以上传大文件,默认是4MB,4096KB
方法:扩容
在Web.config中的system.web标记中添加下面一句:
<httpRuntime maxRequestLength="扩容大小" />
注意:不要扩的太大,因为如果多人同时上传大文件,可能会造成服务器内存溢出,导致服务器崩溃。
优化4:超过上传要求的大小,阻止上传并提示文件过大
C#端解决:
if( FileUpload1.PostedFile.ContentLength>(1024*1024*10)) { Labei1.Text="文件超过10M,不要上传这么大的!"; return; }
C#端不好用,因为如果文件超过了最大长度,C#端是限制不住的,会直接将程序崩溃
JS端:
document.getElementById("Button1").onclick = function () { //取出上传元素 var fi1 = document.getElementById("FileUpload1"); //判断是否有选中的文件 if (fi1.value.length <= 0) { alert(‘请选择要上传的文件!‘); return false; } else { //验证选中的文件长度是否满足条件 if (fi1.files[0].size > (1024 * 1024 * 10)) { alert(‘文件过大,不允许上传!‘); return false; } } };
优化5:限制可以选择的文件类型
在Fileupload属性里加 accept=".jpg,.jpeg,.png"
断点续传:
1 using System; 2 using System.Data; 3 using System.Configuration; 4 using System.Collections; 5 using System.Web; 6 using System.Web.Security; 7 using System.Web.UI; 8 using System.Web.UI.WebControls; 9 using System.Web.UI.WebControls.WebParts; 10 using System.Web.UI.HtmlControls; 11 using System.IO; 12 public partial class DFile : System.Web.UI.Page 13 { 14 protected void Page_Load(object sender, EventArgs e) 15 { 16 } 17 protected void LinBtnDFile_Click(object sender, EventArgs e) 18 { 19 // 创建一比特数组 20 byte[] buffer = new Byte[10240]; 21 // 指定要下载文件的路径. 22 string filePath = @"D:\爱智旮旯.rar"; 23 // 或取文件名包括扩展名 24 string fileName = Path.GetFileName(filePath); 25 Stream fileStream = null; 26 try 27 { 28 // 打开文件 29 fileStream = new FileStream(filePath, FileMode.Open, FileAccess.Read, FileShare.Read); 30 Response.Clear(); 31 // 获取文件的大小 32 long fileSize = fileStream.Length; 33 long sum = 0; 34 if (Request.Headers["Range"] != null) 35 { 36 Response.StatusCode = 206; // 表示返回到客户端的 HTTP 输出状态的整数。默认值为 200。 37 sum = long.Parse(Request.Headers["Range"].Replace("bytes=", "").Replace("-", "")); 38 } 39 if (sum != 0) 40 { 41 Response.AddHeader("Content-Range", "bytes " + sum.ToString() + "-" + ((long)(fileSize)).ToString() + "/" + fileSize.ToString()); 42 } 43 // 获取部分http头信息 44 Response.AddHeader("Content-Length", ((long)(fileSize - sum)).ToString()); 45 Response.ContentType = "application/octet-stream"; 46 //获取文件来源 47 Response.AddHeader("Content-Disposition", "attachment; filename=" + HttpUtility.UrlEncode(Request.ContentEncoding.GetBytes(fileName))); 48 // Response.Flush(); 49 fileStream.Position = sum; //设置当前流位置 50 fileSize = fileSize - sum; 51 // 当文件大小大于0是进入循环 52 while (fileSize > 0) 53 { 54 // 判断客户端是否仍连接在服务器 55 if (Response.IsClientConnected) 56 { 57 // 获取缓冲区中的总字节数. 58 int length = fileStream.Read(buffer, 0, 10240); 59 // 写入数据 60 Response.OutputStream.Write(buffer, 0, length); 61 // 将缓冲区的输出发送到客户端 62 Response.Flush(); 63 buffer = new Byte[10240]; 64 fileSize = fileSize - length; 65 } 66 else 67 { 68 //当用户断开后退出循环 69 fileSize = -1; 70 } 71 } 72 } 73 catch (Exception ex) 74 { 75 Response.Write("Error : " + ex.Message); 76 } 77 finally 78 { 79 if (fileStream != null) 80 { 81 //关闭文件 82 fileStream.Close(); 83 } 84 Response.End(); 85 } 86 } 87 }
以上是关于Webform(文件上传)的主要内容,如果未能解决你的问题,请参考以下文章