日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
ASP.NET多附件上傳和附件編輯的實現(xiàn)

在寫這篇文章之前我也在Google上找到了很多有關(guān)多附件上傳的文章,有用ASP.NET實現(xiàn)的,也有用JSP、PHP等其它技術(shù)實現(xiàn)的,但基本前提都是事先通過js腳本來動態(tài)創(chuàng)建DOM,然后上傳的時候在服務(wù)端做一下處理,有點類似于163的郵件系統(tǒng)。文件上傳需要通過頁面的POST方法進行提交,這個我在一次MOSS開發(fā)中iFrame表單提交的古怪問題解決一問中已經(jīng)闡述過,其中包括了如何使用頁面隱藏的iFrame來提交表單從而避免整個頁面提交到服務(wù)器而導(dǎo)致頁面的刷新。多附件上傳的原理與之類似,只不過需要事先通過腳本在頁面上動態(tài)創(chuàng)建多個input type='file'的標(biāo)簽,當(dāng)然,如果要想功能更加***,你可能還需要通過腳本動態(tài)添加一些按鈕事件以讓用戶可以刪除他所添加的文件。下面是一個應(yīng)用效果的截圖。

其中紅色方框內(nèi)的內(nèi)容是通過腳本在頁面上動態(tài)創(chuàng)建的,將用戶在客戶端所選文件的文件名動態(tài)添加到一個div里,同時在這個div中放一個隱藏的input type=’file’的標(biāo)簽,它的value為用戶所選文件的路徑,然后在div中放置一個img,添加onmouseover和onmouseout事件為圖片增加了一些鼠標(biāo)滑動時的效果,onclick事件用來響應(yīng)用戶點擊img時刪除對應(yīng)的文件??匆幌麓a中的具體實現(xiàn)。

代碼建立在Ajax.net基礎(chǔ)之上,環(huán)境是Visual Studio 2008 + Windows 2003,測試通過!

 
 
 
 
  1. <%@ Page Language="C#" AutoEventWireup="true" CodeBehind="Default.aspx.cs" Inherits="WebApplication1._Default" %> 
  2.  
  3.  xmlns="http://www.w3.org/1999/xhtml"> 
  4.  runat="server"> 
  5.  
  6.  
  7.  
  8.  
  9.  
  10.  
  11.  id="form1" runat="server"> 
  12.  ID="ScriptManager1" runat="server"> 
  13.  
  14.  
  15.  
  16. Description:  
  17.  ID="tbDescription" MaxLength="2000" runat="server" TextMode="MultiLine"> 
 
  •  
  • Location:  
  •  ID="ddlLocation" runat="server"> 
  •  
  •  
  •  
  • Display Posted By User:  
  •  ID="chkPostedByUser" Checked="true" runat="server" /> 
  •  
  •  
  • Notify Shout out User:  
  •  ID="chkNotifyUser" runat="server" /> 
  •  
  •  
  • Notify Shout out to Email:  
  •  ID="tbShoutoutToEmail" MaxLength="25" runat="server"> 
  •  
  •  
  • Images:  
  •  id="saveshoutoutimgs" runat="server"> 
  •  
  •  id="btAddImage" type="button" onclick="$get('saveshoutoutaddimgs').style.display='block';this.disabled=true;" 
  • value="Click here to Add Image" /> 
  •  
  •  id="saveshoutoutdetailshowimg"> 
  •  id="saveshoutoutaddimgs" style="display: none;"> 
  •  
  • Add Image:
  •  
  •  id="browseimg"> 
  •  type="file" /> 
  •  
  •  
  • Size limit of the images is 100kb. Hieght and Width of the images should not exceed  
  • 200px.
  •  
  •  
  •  id="chkAgree" type="checkbox" onclick="$get('btAdd').disabled=!this.checked;" />I  
  • agree.legal signoff text to be defined.  
  •  
  •  
  •  id="btAdd" disabled="disabled" type="button" value="Add" runat="server" /> 
  •  
  •  
  •  
  •  
  •  ID="tbImgs" runat="server" Text="|" Style="display: none;"> 
  •  ID="tbOldImgs" runat="server" Text="|" Style="display: none;"> 
  •  
  •  
  •  
  • protected void Page_Load(object sender, EventArgs e)  
  • {  
  • string script = string.Format("addImg($get('{0}'), $get('{1}'), $get('{2}'));",  
  • this.saveshoutoutimgs.ClientID,  
  • this.tbImgs.ClientID,  
  • this.tbOldImgs.ClientID);  
  • this.btAdd.Attributes.Add("onclick", script);  
  • 簡單做一下說明:

    1.

    用來存放動態(tài)添加的文件相關(guān)標(biāo)簽。

    2. btAddImage被點擊后自身將被disabled掉,然后顯示saveshoutoutaddimgs整個div。

    3. 在saveshoutoutaddimgs中用戶可以完成文件的選取和確認操作,chkAgree用來enable btAdd按鈕。

    4. 當(dāng)用戶點擊btAdd時,觸發(fā)onclick事件,該事件在code-behind的Page_Load方法中注冊,因為腳本中涉及到使用服務(wù)端控件的ClientID屬性,這樣寫比較方便。

    5. 客戶端函數(shù)addImg用來完成動態(tài)DOM的添加操作,它接收三個參數(shù),***個參數(shù)targetElement表示存放動態(tài)DOM的宿主DIV,第二個參數(shù)savestatsElement表示用于保存已添加文件信息的隱藏文本框,第三個參數(shù)oldimgElement表示用于保存在編輯狀態(tài)下用戶上一次上傳的文件信息隱藏文本框?;舅悸肥菑?fù)制browseimg下的input type="file"標(biāo)簽,然后將動態(tài)生成的DOM添加到saveshoutoutimgs下,并同時附加了一些事件。

    6. tbImgs隱藏文本框用來保存用戶已選文件的信息,以"|文件名1|文件名2|文件名3|..."的格式存放;tbOldImgs隱藏文本框中的值在編輯狀態(tài)下才會得到,其中保存了用戶上一次所上傳文件的信息,存儲格式與tbImgs相同。

    7. 在編輯狀態(tài)下,在服務(wù)端向saveshoutoutimgs標(biāo)簽添加與addImg腳本函數(shù)所生成的動態(tài)DOM相同的標(biāo)簽,并同時往tbOldImgs隱藏文本框中寫入文件信息。我在這里寫了一個示例,讀者可以自己完善代碼用以驗證。在顯示文件時我在文件的名稱上添加了一個鏈接,這個鏈接所指向的頁面用于輸出圖片,如通過得到的圖片ID在數(shù)據(jù)庫中檢索圖片的二進制數(shù)據(jù)然后Write到頁面上。ImageEntity為自定義Image對象的實體類,用以存儲圖片文件的相關(guān)信息。

     
     
     
     
    1. public void SetImages(List images)  
    2. {  
    3. if (images.Count > 0)  
    4. {  
    5. this.tbOldImgs.Text = "|";  
    6. foreach (ImageEntity image in images)  
    7. {  
    8. HtmlGenericControl imgDiv = new HtmlGenericControl("Div");  
    9.  
    10. HtmlAnchor imgAnchor = new HtmlAnchor();  
    11. imgAnchor.HRef = string.Format("Thumbnail.aspx?isthumbnail=false&basecommentid={0}&imagetitle={1}",  
    12. image.ID.ToString(), image.Title);  
    13. imgAnchor.Target = "_blank";  
    14. imgAnchor.Title = image.Title;  
    15. imgAnchor.InnerHtml = image.Title + "  ";  
    16.  
    17. HtmlImage imgButton = new HtmlImage();  
    18. imgButton.Src = "ShoutOut_Close.gif";  
    19. imgButton.Alt = "Delete";  
    20. imgButton.Attributes["onclick"] = string.Format("this.parentNode.parentNode.removeChild(this.parentNode);$get('{0}').value = updatehiddenimgs('{1}',$get('{0}').value);",  
    21. this.tbOldImgs.ClientID, image.Title);  
    22. imgButton.Attributes["onmouseover"] = "this.src='ShoutOut_Close_rollover.gif'";  
    23. imgButton.Attributes["onmouseout"] = "this.src='ShoutOut_Close.gif'";  
    24.  
    25. imgDiv.Controls.Add(imgAnchor);  
    26. imgDiv.Controls.Add(imgButton);  
    27. this.saveshoutoutimgs.Controls.Add(imgDiv);  
    28. this.tbOldImgs.Text += image.Title + "|";  
    29. }  
    30. }  
    31. }  
    32.    
    33.  
    34. public class ImageEntity  
    35. {  
    36. public ImageEntity()  
    37. {  
    38. }  
    39.  
    40. public ImageEntity(int id, string title, Byte[] imageBlob, string type)  
    41. {  
    42. ID = id;  
    43. Title = title;  
    44. ImageBlob = imageBlob;  
    45. Type = type;  
    46. }  
    47.  
    48. public int ID { get; set; }  
    49. public string Title { get; set; }  
    50. public string Type { get; set; }  
    51. public Byte[] ImageBlob { get; set; }  

    有一個問題需要注意,當(dāng)保存編輯狀態(tài)下的數(shù)據(jù)時,在服務(wù)端需要重新刪除原有圖片然后再重新添加圖片,對于用戶未在客戶端修改的圖片,則需要在保存數(shù)據(jù)前通過tbOldImgs隱藏域中的相關(guān)信息重新檢索得到圖片數(shù)據(jù),然后重新保存圖片。例如編輯狀態(tài)下得到A、B、C三張圖片,用戶刪除了圖片C,添加了圖片D,則保存時在服務(wù)端這樣操作:先通過tbOldImgs隱藏域得到剩余的舊圖片信息(即圖片A和圖片B),從數(shù)據(jù)庫中檢索出這些圖片的數(shù)據(jù),保存前先刪除與該條數(shù)據(jù)相關(guān)的所有已上傳圖片,然后與得到的新圖片(即圖片D)一并存入數(shù)據(jù)庫中。

    還有一點就是,如果想要實現(xiàn)上傳圖片前判斷圖片文件的大小,必須通過C#代碼來實現(xiàn),這個不能簡單地通過js腳本來實現(xiàn),因為涉及到瀏覽器對客戶端文件訪問權(quán)限的限制。也就是說,需要將頁面預(yù)先提交到服務(wù)器,判斷完成后通知客戶端接下來的行為,為了避免頁面提交時客戶端原有的狀態(tài)丟失,可以采用隱藏iFrame的方式提交頁面,這個在文章的一開始我已經(jīng)提到過了。

    總之,在Web中實現(xiàn)多附件上傳必須借助于javascript來動態(tài)創(chuàng)建DOM,編輯狀態(tài)下可以在服務(wù)端將事先處理好的DOM添加到頁面上,并同時附件腳本事件,在服務(wù)端代碼和客戶端代碼之間注意保存各個控件的狀態(tài)。


    當(dāng)前題目:ASP.NET多附件上傳和附件編輯的實現(xiàn)
    標(biāo)題路徑:http://www.dlmjj.cn/article/cdjcjpj.html