Webform(文件上传)

文件上传:

  所用控件:FileUpload

  使用时的思路:

  1、判断用户是否选中了文件

    FileUpload.FileName获取选中的文件名,判断长度,如果长度大于零就代表已经选择了文件

    JS端:通过ID获取控件,然后控件的value获取选中的文件名

  2、将文件保存到服务器上

    FileUpload.SaveAs("绝对路径");

  3、获得绝对路径

    先编写相对路径:比如"UpLoads/abc.txt"

    再把路径映射成绝对路径:Server.MapPath("UpLoads/abc.txt");

  4、保留原文件的类型和文件名

    相对路径改为"UpLoads/" + FileUpload1.FileName;

  5、防止文件重名覆盖的问题

    "UpLoads/" + Request.Cookies["user"].Value + DateTime.Now.ToString("yyyyMMddhhmmssms") + FileUpload1.FileName;

    也就是在文件名前面拼接上登陆的用户名以及操作的时间,精确到毫秒

  6、限制用户可选的文件类型

    给控件添加属性accept=".jpg,.png,.jpeg,.txt"

    但在打开的对话框中,仍然可以选择全部文件,只能通过JS端来限制:  

复制代码
document.getElementById("Button1").onclick = function () {
        var fileName = document.getElementById("FileUpload1").value;
        
        var name = fileName.substr(fileName.length - 4, 4);
        var name1 = fileName.substr(fileName.length - 5, 5);
        if (name != ".jpg" && name != ".png" && name != ".txt" && name1 != ".jpeg")
        {
            alert("请选择正确的文件!你要找事儿啊??");
            return false;
        } 
    };
复制代码

  7、控制上传文件的大小

    扩容(系统默认文件最大4MB):    

      webconfig配置文件中写入

      <system.web>

      <compilation debug="false" targetFramework="4.0" />

      <httpRuntime maxRequestLength="40000" />

      </system.web>

      注:不要扩的太多,这样上传会占用服务器内存,如果同时上传人数过多会导致服务器内存溢出

    限制大小:

      C#端限制:

    if (FileUpload1.PostedFile.ContentLength>(4*1024*1024))
        {
            Label1.Text = "文件长度过长!!!";
            return;
        }

       JS端限制:

    var f = document.getElementById("FileUpload1");

        if (f.files[0].size > (4 * 1024 * 1024)) {
            alert("文件过大!!!");
            return false;
        }

断点续传:

复制代码
 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 } 
原文地址:https://www.cnblogs.com/1030351096zzz/p/6262638.html