[C# / ASP.NET]FileUpload控制項「批次上傳 / 多檔案同時上傳」的範例(C#語法)

FileUpload控制項「批次上傳 / 多檔案同時上傳」的範例 (VB語法)

上面這個範例已經發表一段時日,還滿多人看的,隨著我把程式改成 C#版,
這些已經公開分享的範例,我也盡量把C#版程式補上。





 

 

[ASP.NET] FileUpload控制項「批次上傳 / 多檔案同時上傳」的範例 (VB語法)

http://www.dotblogs.com.tw/mis2000lab/archive/2008/05/14/3986.aspx

 

上面這個範例已經發表一段時日,還滿多人看的,隨著我把程式改成 C#版,

這些已經公開分享的範例,我也盡量把C#版程式補上。

     

 

HTML畫面的原始檔(.aspx檔案)   

如果您要看圖片解說,請連到上面那篇VB語法的 FileUpload文章

這裡只提供 C#程式。

<form id="form1" runat="server">
    <div>
    大量檔案,批次上傳  /  FileUpload for C#<hr />
        1.        <asp:FileUpload ID="FileUpload1" runat="server" />
        <br />
        2.        <asp:FileUpload ID="FileUpload2" runat="server" />
        <br />
        3.        <asp:FileUpload ID="FileUpload3" runat="server" />
        <br />
        4.        <asp:FileUpload ID="FileUpload4" runat="server" />
        <br />
        5.        <asp:FileUpload ID="FileUpload5" runat="server" />
        <hr />&nbsp;&nbsp;

        <asp:Button ID="Button1" runat="server" Text="大量檔案,批次上傳!" onclick="Button1_Click" />

    </div>
    <p>
        <asp:Label ID="Label1" runat="server" ForeColor="#FF3300"></asp:Label>  <br />

        <asp:Label ID="Label2" runat="server" ForeColor="blue"></asp:Label>
    </p>
</form>

 

 

後置程式碼(Code Behind for C#)

    protected void Button1_Click(object sender, EventArgs e)
    {
        //--註解:網站上的目錄路徑。所以不寫磁碟名稱(不寫 “實體”路徑)。
        string saveDir = "c:\\上傳的目錄路徑\\";
        string appPath = Request.PhysicalApplicationPath;

        string tempfileName = "";
        System.Text.StringBuilder myLabel = new System.Text.StringBuilder();
        //如果事先宣告 using System.Text;
        //便可改寫成 StringBuilder myLabel = new StringBuilder();

        for(int i = 1; i <= Request.Files.Count; i++)
        {
            FileUpload myFL = new FileUpload();
            myFL = (FileUpload)
Page.FindControl("FileUpload" + i);

            if (myFL.HasFile) {
                string fileName = myFL.FileName;
                string pathToCheck = appPath + saveDir + fileName;

                //===========================================(Start)

          if (System.IO.File.Exists(pathToCheck))

          {
                    int my_counter  = 2;
                    while (System.IO.File.Exists(pathToCheck))
                    {
                        //--檔名相同的話,目前上傳的檔名(改成 tempfileName),
                        //  前面會用數字來代替。

                        tempfileName = my_counter.ToString() + "_" + fileName;
                        pathToCheck = appPath + saveDir + tempfileName;
                        my_counter = my_counter + 1;
                    }

                    fileName = tempfileName;
                    Label1.Text += "<br>抱歉,您上傳的檔名發生衝突,檔名修改如下---- " + fileName;

          }

                //===========================================(End)                

                //-- 完成檔案上傳的動作。
                string savePath = appPath + saveDir + fileName;
                myFL.SaveAs(savePath);

   myLabel.Append("<hr>檔名---- " + fileName);

            }
        }

        Label2.Text = "上傳成功" + myLabel.ToString();
    }
 

 紅字的部份,是小弟稍稍改寫過的地方。

 [置頂]ASP.NET專題實務(C#版),2009 二月推出(售價650元/文魁/書號P09027)

 

...................................................................................................................................

如果不使用上面的兩種技巧,初學者也可以乖乖地用五個 if判別式來作

(一個 FileUpload控制項,就作一次,    程式碼不斷COPY 修改即可)。

只要程式能順利執行,而且您又是剛剛入門的初學者......沒人敢說這樣做不好。以下是範例:

if (FileUpload1.HasFile)
{
          string fileName = FileUpload1.FileName;

          //……內容與上面範例相同,在此省略…… 

          FileUpload1.SaveAs(savePath);               
          myLabel.Append("<br>檔名---- " + fileName);
 }

if (FileUpload2.HasFile)
{
          string fileName = FileUpload2.FileName;
          //……省  略……
          FileUpload2.SaveAs(savePath) ;     
}

if (FileUpload3.HasFile)
{
          string fileName = FileUpload3.FileName;
          //……省  略……
          FileUpload3.SaveAs(savePath) ;     
}

//……以此類推……  這種Copy / Paste的作法很累吧~

 

學生(初學者)還在學習中,所以寫出上面的程式,我不會責怪他,畢竟能正確執行更重要。

但如果進入業界,還用這種 Copy / Paste的方法來寫程式,可能會被前輩「唸」一頓

 

補充範例:上面的技巧,我在這裡另外解說

 

 

 FileUpload上傳檔案還有其他的變化,例如:

  • 限制某些檔案才能上傳(鎖定副檔名,例如:gif or jpg檔才能上傳)
  • 限制檔案大小(例如:500KB以下的檔案才能上傳)
  • 上傳檔名如果重複,會自動修改檔名
  • 限制上傳的目錄&路徑

都是很實用的例子。這些例子很多都是參考微軟MSDN文件,搜尋「FileUpload類別」關鍵字就能找到。

 

如果您看不懂程式碼、或是網路資源寫得不夠細緻,想要有專人解說程式碼的話, 

廣告一下!!  這些範例在我的書本 (上集)第十八章,都有很詳細的說明。

 

 

 

2010/12/1 補充一個更多人想問的範例:

[習題]FileUpload 批次上傳 / 多檔案同時上傳,上傳成功後展示圖片 (VB語法)

 

2012/9/5補充:另外一種作法,請參閱  http://www.allenkuo.com/userfiles/share/2012q3/2012-8-28_08-28-10.png

 

...................................................................................................................................................................... 

 關於本文提到的程式,有一個 .FindControl() 的用法,請讀者看看這篇文章,也有相關說明 ----

      [習題]GridView裡面,樣版(Template)內的控制項,怎麼抓取?使用FindControl就對啦~

 

 

 

 

  •  

 

 

 
 

我將思想傳授他人, 他人之所得,亦無損於我之所有;

猶如一人以我的燭火點燭,光亮與他同在,我卻不因此身處黑暗。----Thomas Jefferson

寫信給我--  mis2000lab (at) yahoo.com.台灣  或是  school (at) mis2000lab.net

................   facebook社團   https://www.facebook.com/mis2000lab   ......................

................   Google+   https://plus.google.com/100202398389206570368/posts ........

................  YouTube (ASP.NET) 線上教學影片  http://goo.gl/rGLocQ

*********************************************************************************************

*** 第一天 的 ASP.NET MVC線上課程 免費看(5.5小時)*** 

************************************************************(歡迎索取,免費申請)*****

 

ASP.NET遠距教學、線上課程(Web Form + MVC)第二門 課程「四折」-- 以MVC課程作為優惠。

第一天完整課程,提供 "完整" 試聽。  如不滿意 全額退費!

 

 

Blog文章 "附的範例" 無法下載,請看 這裡 ...... https://dotblogs.com.tw/mis2000lab/2016/03/14/2008_2015_mis2000lab_sample_download

請看我們的「售後服務」範圍(嚴格認定)

......................................................................................................................................................

...................................................................................................................................................... 

[遠距教學、教學影片] ASP.NET (Web Form) 課程 上線了!MIS2000Lab.主講

事先錄製好的影片,並非上課時側錄!   觀看影片時,有如我「一對一」跟您面對面講課

 

    MIS2000 Lab.  線上教學影片(YouTube) **免費觀賞**