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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
WebForm可以通过使用ASP.NET中的GridView控件实现对CSV文件的读取和分类显示。以下是一些基本步骤: 1. 在WebForm上添加GridView控件。可以通过Visual Studio的工具箱将GridView控件拖动到WebForm上。 2. 创建一个数据源,用于从CSV文件中读取数据。可以使用OleDbDataReader或CsvDataReader等类来读取CSV文件。以下是CsvDataReader的一个示例: ```csharp using (var reader = new CsvDataReader(csvFilePath)) { var dt = new DataTable(); dt.Load(reader); GridView1.DataSource = dt; GridView1.DataBind(); } ``` 3. 对数据进行分类。可以使用GridView控件中的排序和筛选功能来对数据进行分类。也可以通过编写自定义代码来实现分类。以下是一个基本的示例,它使用LINQ查询对数据进行分类: ```csharp using (var reader = new CsvDataReader(csvFilePath)) { var dt = new DataTable(); dt.Load(reader); var groupedData = from row in dt.AsEnumerable() group row by row.Field<string>("Category") into grp select new { Category = grp.Key, Count = grp.Count() }; GridView1.DataSource = groupedData; GridView1.DataBind(); } ``` 这个示例将CSV文件中的数据按照“Category”列进行分类,并计算每个分类中的数据行数。然后,它将分类数据绑定到GridView控件上,以显示每个分类的行数。 4. 运行WebForm应用程序并查看结果。在浏览器中打开WebForm应用程序,GridView控件将显示CSV文件中的数据,并根据分类方式进行排序。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值