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 } 
View Code

 





以上是关于Webform(文件上传)的主要内容,如果未能解决你的问题,请参考以下文章

WebForm文件上传

webform文件的上传

Webform(文件上传)

Webform(文件上传)

2017-05-30WebForm文件上传

webform ajax 上传文件+参数