麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > .NET > 正文

ASP.NET中FileUpload文件上傳控件應(yīng)用實例

2024-07-10 13:30:13
字體:
供稿:網(wǎng)友
本文主要介紹FileUpload文件上傳控件在實際開發(fā)中經(jīng)常遇到的問題并給出解決方法,希望對大家有所幫助。
 

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

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

1.一次上傳多個文件

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

 

復制代碼代碼如下:

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 += "發(fā)生錯誤: " + Ex.Message;
        }
    }
}

 

2.上傳文件類型的驗證

對上傳文件類型的驗證既可以在客戶端進行,也可以在服務(wù)器端進行??蛻舳丝梢允褂抿炞C控件來進行,不過我們今天主要說說如何在服務(wù)器端進行驗證。上邊cs文件中已經(jīng)用GetExtension獲取了文件的擴展名,只要稍加判斷即可實現(xiàn)上傳類型的驗證:

 

復制代碼代碼如下:

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>" +
                              "文件大?。?quot; + FileUpload1.PostedFile.ContentLength + " KB<br>" +
                              "文件MIME類型:" + FileUpload1.PostedFile.ContentType + "<br>" +
                              "保存路徑:" + Server.MapPath("upload") + "//" + FileUpload1.FileName;
            }
            catch (Exception ex)
            {
                Label1.Text = "發(fā)生錯誤:" + ex.Message.ToString();
            }
        }
        else
        {
            Label1.Text = "只允許上傳rar、zip文件!";
        }
    }
    else
    {
        Label1.Text = "沒有選擇要上傳的文件!";
    }
}

 

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

3.解決文件大小限制

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

 

復制代碼代碼如下:

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

 

maxRequestLength表示可上傳文件的最大值,executionTimeout表示ASP.NET關(guān)閉前允許發(fā)生的上載秒數(shù)。

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

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

 

復制代碼代碼如下:

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 = "發(fā)生錯誤:" + ex.Message.ToString();
        }
    }
    else
    {
        Label1.Text = "沒有選擇要上傳的文件!";
    }
}

 

應(yīng)用范例

Default.aspx:

<%@ 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:

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");  } }}

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



注:相關(guān)教程知識閱讀請移步到ASP.NET教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 成人做爰高潮片免费视频韩国 | 在线影院av| 精品成人av一区二区在线播放 | 国产成人精品区一区二区不卡 | 成年免费大片黄在线观看岛国 | 国产精品久久99精品毛片三a | 欧美成人影院 | 色戒在线版| 久久久国产精品免费观看 | 日韩视频一区在线 | 视频在线91 | 成品片a免费直接观看 | 在线成人免费观看www | 亚洲第一黄色网 | 国产精品久久久久久久久久久久午夜 | 九九看片 | 男女羞羞在线观看 | 天天干天天透 | 少妇的肉体k8经典 | 国产精品午夜一区 | 久久无| 精品国产91一区二区三区 | 禁漫天堂久久久久久久久久 | 毛片一级免费看 | 亚洲卡通动漫在线观看 | 欧美毛片在线观看 | 久久99精品久久久久久小说 | 免费一级欧美大片视频在线 | 激情视频导航 | 一区二区三区视频在线观看 | av电影网站在线观看 | 免费在线观看午夜视频 | 九一免费版在线观看 | 国内精品久久久久久2021浪潮 | 国产精品久久国产精麻豆96堂 | 欧美日韩亚洲一区二区三区 | 精品国产一区二区三区在线 | 国产亚洲黑人性受xxxx精品 | 在线成人免费观看www | 牛牛a级毛片在线播放 | 欧洲黄视频 |