激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - ASP.NET教程 - ASP.NET中FileUpload文件上傳控件應用實例

ASP.NET中FileUpload文件上傳控件應用實例

2020-01-04 15:52seeyou ASP.NET教程

本文主要介紹FileUpload文件上傳控件在實際開發中經常遇到的問題并給出解決方法,希望對大家有所幫助。

使用 FileUpload 控件,可以為用戶提供一種將文件從用戶的計算機發送到服務器的方法。該控件在允許用戶上載圖片、文本文件或其他文件時很有用。要上載的文件將在回發期間作為瀏覽器請求的一部分提交給服務器。在文件上載完畢后,您可以用代碼管理該文件。

大致了解了一下FileUpload,讓我們來看一下FileUpload幾個實際應用中問題的處理方法。

1.一次上傳多個文件

要一次上傳多個文件,我們可以像傳單個文件那樣對每個文件單獨進行處理,除此之外,我們還可以使用HttpFileCollection類捕獲從Request對象發送來的所有文件,然后再單獨對每個文件進行處理,代碼如下:

 

復制代碼 代碼如下:

protected void Button1_Click(object sender, EventArgs e)
{
    string filepath = Server.MapPath("upload") + "\\";
    HttpFileCollection uploadFiles = Request.Files;
    for (int i = 0; i < uploadFiles.Count; i++)
    {
        HttpPostedFile postedFile = uploadFiles[i];
        try
        {
            if (postedFile.ContentLength > 0)
            {
                Label1.Text += "文件 #" + (i + 1) + ":" + System.IO.Path.GetFileName(postedFile.FileName) + "<br/>";
                postedFile.SaveAs(filepath + System.IO.Path.GetFileName(postedFile.FileName));
            }
        }
        catch (Exception Ex)
        {
            Label1.Text += "發生錯誤: " + Ex.Message;
        }
    }
}

 

2.上傳文件類型的驗證

對上傳文件類型的驗證既可以在客戶端進行,也可以在服務器端進行。客戶端可以使用驗證控件來進行,不過我們今天主要說說如何在服務器端進行驗證。上邊cs文件中已經用GetExtension獲取了文件的擴展名,只要稍加判斷即可實現上傳類型的驗證:

 

復制代碼 代碼如下:

protected void Button1_Click(object sender, EventArgs e)
{
    if (FileUpload1.HasFile)
    {
        fileExt = System.IO.Path.GetExtension(FileUpload1.FileName);
        if (fileExt == ".rar" || fileExt == ".zip")
        {
            try
            {
                FileUpload1.SaveAs(Server.MapPath("upload") + "\\" + FileUpload1.FileName);
                Label1.Text = "客戶端路徑:" + FileUpload1.PostedFile.FileName + "<br>" +
                              "文件名:" + System.IO.Path.GetFileName(FileUpload1.FileName) + "<br>" +
                              "文件擴展名:" + System.IO.Path.GetExtension(FileUpload1.FileName) + "<br>" +
                              "文件大小:" + FileUpload1.PostedFile.ContentLength + " KB<br>" +
                              "文件MIME類型:" + FileUpload1.PostedFile.ContentType + "<br>" +
                              "保存路徑:" + Server.MapPath("upload") + "\\" + FileUpload1.FileName;
            }
            catch (Exception ex)
            {
                Label1.Text = "發生錯誤:" + ex.Message.ToString();
            }
        }
        else
        {
            Label1.Text = "只允許上傳rar、zip文件!";
        }
    }
    else
    {
        Label1.Text = "沒有選擇要上傳的文件!";
    }
}

 

需要注意的是,我們不能過分依賴于客戶端驗證控件和服務器端上述方法的驗證,因為用戶只需將文件擴展名更改為允許的類型就可以避開上邊的驗證,這對用戶來說并不是件困難的事情。

3.解決文件大小限制

在ASP.NET 2.0中FileUpload默認上傳文件最大為4M,不過我們可以在web.cofig中修改相關節點來更改這個默認值,相關節點如下:

 

復制代碼 代碼如下:

<system.web>
    <httpRuntime maxRequestLength="40690" executionTimeout="6000" />
</system.web>

 

maxRequestLength表示可上傳文件的最大值,executionTimeout表示ASP.NET關閉前允許發生的上載秒數。

4."multipart/form-data"和Request共存

在ASP程序中一旦使用表單上傳文件(form的enctype屬性值為multipart/form-data),服務器端就不能再用Request.Form來獲取表單的值,這種限制在ASP.NET 2.0中已經不存在了:

 

復制代碼 代碼如下:

protected void Button1_Click(object sender, EventArgs e)
{
    if (FileUpload1.HasFile)
    {
        try
        {
            FileUpload1.SaveAs(Server.MapPath("upload") + "\\" + FileUpload1.FileName);
            Label1.Text = "上傳文件:" + FileUpload1.FileName + "<br>" +
                          "說明:" + Request.Form["TextBox1"];//也可以用"TextBox1.Text"來獲取說明
        }
        catch (Exception ex)
        {
            Label1.Text = "發生錯誤:" + ex.Message.ToString();
        }
    }
    else
    {
        Label1.Text = "沒有選擇要上傳的文件!";
    }
}

 

應用范例

Default.aspx:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs" Inherits="_Default" %>
 
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
 
<html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
 <title>無標題頁</title>
</head>
<body>
 <form id="form1" runat="server">
  <asp:FileUpload ID="FileUpload1" runat="server" />
  <asp:Button ID="Button1" runat="server" OnClick="Button1_Click" Text="Button" />
  <asp:RegularExpressionValidator ID="RegularExpressionValidator1" runat="server" ControlToValidate="FileUpload1"
   ErrorMessage="必須是 jpg或者gif文件" ValidationExpression="^(([a-zA-Z]:)|(\\{2}\W+)\$?)(\\(\W[\W].*))+(.jpg|.Jpg|.gif|.Gif)$"></asp:RegularExpressionValidator>
 </form>
 
</body>
</html>

Default.aspx.cs:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
using System;
using System.Data;
using System.Configuration;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
 
public partial class _Default : System.Web.UI.Page
{
 protected void Page_Load(object sender, EventArgs e)
 {
 
 }
 protected void Button1_Click(object sender, EventArgs e)
 {
  String savePath = @"F:\111\";
  if (FileUpload1.HasFile)
  {
   String filename;
   filename = FileUpload1.FileName;
   savePath +=filename;
   FileUpload1.SaveAs(savePath);
   Page.Response.Write(FileUpload1.PostedFile.ContentType + FileUpload1.PostedFile.ContentLength+"<br>");
   Page.Response.Write("<img src='"+savePath+"'>");
 
  }
  else
  {
   Page.Response.Write("fff");
  }
 }
 
}

該范例應用RegularExpressionValidator控件限制只能上傳jpg、Jpg、gif、Gif格式的文件,當然最好后臺也做一下限制,上面已經講解過具體的操作方法。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 一二区成人影院电影网 | 日本成人在线免费 | 性欧美大战久久久久久久免费观看 | 91在线视频福利 | 毛片免费大全短视频 | 欧美高清视频一区 | 91精品久久香蕉国产线看观看 | 在线免费日本 | 久久国产28| 毛片免费视频播放 | 国产99精品| 中文字幕在线视频日本 | 色爱99| 亚洲国产精品久久久久久久久 | 国产欧美日韩视频在线观看 | 嫩嫩的freehdxxx| 久久大陆 | 黄色片在线免费播放 | 日本欧美在线播放 | 亚洲电影在线观看高清免费 | 国产精品a一| 成人免费在线播放 | 亚洲精久久 | 56av国产精品久久久久久久 | 欧美精品一区二区三区四区 | 国产免费观看一区二区三区 | 久久久三级免费电影 | 日韩黄色片网站 | 久久人操| 久久亚洲春色中文字幕久久 | 日本一区二区免费在线观看 | 久久久久久久久日本理论电影 | 毛片小网站| 久久久中精品2020中文 | japanese xxxxhd | 美女露100%无遮挡 | 欧美成人三级视频 | 成人激情视频网 | 久久久久久久久久网站 | 欧美日韩国产一区二区三区在线观看 | 久久免费视频一区 |