欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品

主頁 > 知識庫 > asp.net 文件上傳實例匯總

asp.net 文件上傳實例匯總

熱門標簽:電銷機器人 數據 福州人工智能電銷機器人加盟 宿遷智能外呼系統排名 云狐人工智能電話機器人 怎樣給陜西地圖標注顏色 地圖標注多少錢一張 ai電銷機器人對貸款有幫助嗎 廣州銷售外呼系統定制 400電話辦理信任翰諾科技

ASP.NET依托.net framework類庫,封裝了大量的功能,使得上傳文件非常簡單,主要有以下三種基本方法。

方法一:用Web控件FileUpload,上傳到網站根目錄。

Test.aspx關鍵代碼:

復制代碼 代碼如下:

     form id="form1" runat="server">
     asp:FileUpload ID="FileUpload1" runat="server" />
     asp:Button ID="Button1" runat="server" Text="上傳" OnClick="Button1_Click" />
     asp:Label ID="Label1" runat="server" Text="" Style="color: Red">/asp:Label>
     /form>

Test.aspx.cs關鍵代碼:

復制代碼 代碼如下:

     protected void Button1_Click(object sender, EventArgs e)
     {
         if (FileUpload1.HasFile)
         {
              FileUpload1.SaveAs(Server.MapPath("~/") + FileUpload1.FileName);
              Label1.Text = "上傳成功!";
         }
     }

方法二:用Html控件HtmlInputFile,上傳到網站根目錄。

Test.aspx關鍵代碼:

復制代碼 代碼如下:

     form id="form1" runat="server">
     input type="file" id="file1" runat="server" />
     asp:Button ID="Button1" runat="server" Text="上傳" OnClick="Button1_Click" />
     asp:Label ID="Label1" runat="server" Text="" Style="color: Red">/asp:Label>
     /form>

Test.aspx.cs關鍵代碼:

復制代碼 代碼如下:

     protected void Button1_Click(object sender, EventArgs e)
     {
         if (file1.PostedFile.ContentLength > 0)
         {
              file1.PostedFile.SaveAs(Server.MapPath("~/") + Path.GetFileName(file1.PostedFile.FileName));
              Label1.Text = "上傳成功!";
         }
     }

方法三:用Html元素input type="file" …/>,通過Request.Files上傳到網站根目錄。

Test.aspx關鍵代碼:

復制代碼 代碼如下:

     form id="form1" runat="server" enctype="multipart/form-data">
     input type="file" name="file" />
     asp:Button ID="Button1" runat="server" Text="上傳" OnClick="Button1_Click" />
     asp:Label ID="Label1" runat="server" Text="" Style="color: Red">/asp:Label>
     /form>

Test.aspx.cs關鍵代碼:

復制代碼 代碼如下:

     protected void Button1_Click(object sender, EventArgs e)
     {
         if (Request.Files["file"].ContentLength > 0)
         {
              Request.Files["file"].SaveAs(Server.MapPath("~/") + Path.GetFileName(Request.Files["file"].FileName));
              Label1.Text = "上傳成功!";
         }
     }

注意兩個區別:

一:FileUpload.FileName獲取客戶端上傳文件名(不帶路徑),而file1.PostedFile.FileName 和Request.Files["file"].FileName在不同瀏覽器下情況不同:IE8下獲得的是客戶端上傳文件的完全限定名(帶路徑),谷歌、蘋果等瀏覽器下則仍為文件名(不帶路徑)。

二:FileUpload控件有HasFile屬性,用于判斷用戶是否選擇了上傳文件,而后面兩種方法則需要通過判斷上傳文件大小ContentLength屬性,當用戶沒有選擇上傳文件時,該屬性值為0。

可以看出FileUpload封裝程度更高,但靈活性也稍差。

例,Asp.net 文件上傳類(取得文件后綴名,保存文件,加入文字水印)

復制代碼 代碼如下:

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;
using System.Drawing;
using System.IO;
using System.Drawing.Imaging;

namespace EC
{
/// summary>
/// 上傳類
/// /summary>
public class UploadObj
{

public UploadObj()
{
//
// TODO: 在此處添加構造函數邏輯
//
}
/// summary>
/// 允許文件上傳的類型枚舉
/// /summary>
public enum FileType
{
jpg,gif,bmp,png
}

#region 取得文件后綴
/// summary>
/// 取得文件后綴
/// /summary>
/// param name="filename">文件名稱/param>
/// returns>/returns>
public static string GetFileExtends(string filename)
{
string ext = null;
if (filename.IndexOf('.') > 0)
{
string[] fs = filename.Split('.');
ext = fs[fs.Length - 1];
}
return ext;
}
#endregion

#region 檢測文件是否合法
/// summary>
/// 檢測上傳文件是否合法
/// /summary>
/// param name="fileExtends">文件后綴名/param>
/// returns>/returns>
public static bool CheckFileExtends(string fileExtends)
{
bool status = false;
fileExtends = fileExtends.ToLower();
string[] fe = Enum.GetNames(typeof(FileType));
for (int i = 0; i fe.Length; i++)
{
if (fe[i].ToLower() == fileExtends)
{
status = true;
break;
}
}
return status;
}
#endregion

#region 保存文件
/// summary>
/// 保存文件
/// /summary>
/// param name="fpath">全路徑,Server.MapPath()/param>
/// param name="myFileUpload">上傳控件/param>
/// returns>/returns>
public static string PhotoSave(string fpath,FileUpload myFileUpload)
{
string s = "";
string fileExtends = "";
string fileName = myFileUpload.FileName;
if (fileName != "")
{
//取得文件后綴
fileExtends = EC.UploadObj.GetFileExtends(fileName);
if (!EC.UploadObj.CheckFileExtends(fileExtends))
{
EC.MessageObject.ShowPre("上傳文件類型不合法");
}
Random rd = new Random();
s = EC.RandomObject.DateRndName(rd) + "." + fileExtends;
string file = fpath + "\" + s;
try
{
myFileUpload.SaveAs(file);
}
catch (Exception ee)
{
throw new Exception(ee.ToString());
}
}
return s;
}

#endregion

#region 加入文字水印

/// summary>
/// 加入文字水印
/// /summary>
/// param name="fileName">文件名稱路徑(全路徑)/param>
/// param name="text">文件/param>
public void AddTextToImg(string fileName, string text)
{
if (!File.Exists(fileName))
{
throw new FileNotFoundException("文件不存在");
}
if (text == string.Empty)
{
return;
}
//判斷文件類型是否為圖像類型

System.Drawing.Image image = System.Drawing.Image.FromFile(fileName);
Bitmap bitmap = new Bitmap(image, image.Width, image.Height);
Graphics g = Graphics.FromImage(bitmap);
float fontSize = 12.0f;//字體大小
float textWidth = text.Length * fontSize;//文本的長度
//下面定義一個矩形區域,以后在這個矩形里面畫上白底黑字
float rectX = 0;
float rectY = 0;
float rectWidth = text.Length * (fontSize + 8);
float rectHeight = fontSize + 8;
//聲明矩形域
RectangleF textArea = new RectangleF(rectX, rectY, rectWidth, rectHeight);
Font font = new Font("宋體", fontSize);//定義字體
Brush whiteBrush = new SolidBrush(Color.White);//白筆刷,畫文字用
Brush blackBrush = new SolidBrush(Color.Black);//黑筆刷,畫背景用
g.FillRectangle(blackBrush, rectX, rectY, rectWidth, rectHeight);
g.DrawString(text, font, whiteBrush, textArea);
MemoryStream ms = new MemoryStream();
bitmap.Save(ms, ImageFormat.Jpeg);
//輸出處理后的圖像,這里為了演示方便,我將圖片顯示在頁面中了
//Response.Clear();
//Response.ContentType = "image/jpeg";
//Response.BinaryWrite(ms.ToArray());
g.Dispose();
bitmap.Dispose();
image.Dispose();
}
#endregion
}
}

ASP.NET的弊端

ASP.NET處理文件上傳的最大的問題在于內存占用太高,由于將整個文件載入內存進行處理,導致如果用戶上傳文件太大,或者同時上傳的用戶太多,會造成服務器端內存耗盡。這個觀點其實是片面的,對于早期ASP.NET 1.X,為了供程序處理,會將用戶上傳的內容完全載入內存,這的確會帶來問題,但在ASP.NET 2.0中就已經會在用戶上傳數據超過一定數量之后將其存在硬盤中的臨時文件中,而這點對于開發人員完全透明,也就是說,開發人員可以像以前一樣進行數據流的處理,這個也在httpRuntime里通過
requestLengthDiskThreshold屬性來設置閾值(threshold),其默認值為256,即一個請求內容超過256KB時就會啟用硬盤作為緩存,這個閾值和客戶端是否是在上傳內容無關,只關心客戶端發來的請求大于這個值。因此,在ASP.NET 2.0中服務器的內存不會因為客戶端的異常請求而耗盡。另外一個弊端就是當請求超過maxRequestLength(默認4M)之后,ASP.NET處理程序將不會處理該請求。這和ASP.NET拋出一個異常完全不同,這就是為什么如果用戶上傳文件太大,看到的并不是ASP.NET應用程序中指定的錯誤頁面(或者默認的),因為ASP.NET還沒有對這個請求進行處理。


還有一個問題就是處理ASP.NET大文件上傳的超時。這個其實可以通過在運行時讀取web.config中的httpRuntime節,并轉化為HttpRuntimeSection對象或者重寫Page.OnError()來檢測HTTP Code(相應代碼)是否為400來處理,這里不再贅述


代碼如下:

復制代碼 代碼如下:

    System.Configuration.Configuration  
    config = WebConfigurationManager. 
    OpenWebConfiguration("~"); 
    HttpRuntimeSection section = config.GetSection 
    ("system.web/httpRuntime") as HttpRuntimeSection; 
    double maxFileSize = Math.Round 
    (section.MaxRequestLength / 1024.0, 1); 
    string errorString = string.Format("Make sure  
    your file is under {0:0.#} MB.", maxFileSize);

    protected override void OnError(EventArgs e) 
    { 
    HttpContext ctx = HttpContext.Current; 
    Exception exception = ctx.Server.GetLastError (); 

    string errorString =  
     "
    Offending URL: " + ctx.Request.Url.ToString () + 
     "
    Source: " + exception.Source +  
     "
    Message: " + exception.Message + 
     "
    Stack trace: " + exception.StackTrace; 

    ctx.Response.Write (errorString); 

    ctx.Server.ClearError (); 

    base.OnError (e); 
    }

對于文件上傳的功能需要較為特別的需求——例如進度條提示,ASP.NET封裝的控件〈asp:FileUpload /〉就無能為力了。

好的解決方案

Robert Bazinet建議,最好的解決方案是使用RIA,大多數情況下,建議用Silverlight或Flash的上傳組件來替代傳統的FileUpload組件,這類組件不只是提供了更好的上傳體驗,也比〈input type="file"〉標簽在頁面上的文本框、按鈕漂亮,這個〈input type="file"〉標簽并不能夠通過CSS添加樣式,不過也有人嘗試去解決了。至今為止并沒有什么商業上傳組件使用了Silverlight,不過這里有演示了用Silverlight進行多文件上傳的示例程序。當然使用Silverlight就可以很輕松的實現多線程上傳,斷點續傳這種功能了,這些都不是我要詳細討論的內容,如果有需要可以自己去看下。

可選擇的解決方案

使用〈input type="file" /〉標簽所能提供的支持非常有限,一些特殊需求我們不能實現——或者說是無法輕易地、直接地實現。所以為了實現這樣的功能我們每次都要繞一個大大的彎。為了避免每次實現相同功能時都要費神費時地走一遍彎路,市面上或者開源界出現了各種上傳組件,上傳組件提供了封裝好的功能,使得我們在實現文件上傳功能時變得輕松了很多。例如幾乎所有的上傳組件都直接或間接地提供了進度提示的功能,有的提供了當前的百分比數值,有的則直接提供了一套UI;有的組件只提供了簡單的UI,有的卻提供了一整套上傳、刪除的管理界面。此外,有的組件還提供了防止客戶端惡意上傳的能力。

我覺得最好的辦法是在HttpModule里分塊讀取文件并且保持頁面激活的狀態,這樣就不會超時,同時也可以跟蹤進度或者取消上傳,或者通過HttpHandler實現,在通過進度條給用戶充分提示的同時,也讓開發人員能夠更好地控制文件大小以及上傳過程中可能出現的異常。上傳組件都是用這些辦法的,我們的選擇有:

復制代碼 代碼如下:

    FileUploader.NET (MediaChase公司,$310以上)  
    RadUpload (Telerik公司,$249)  
    NeatUpload (免費,遵守LGPL協議)

    ······

NeatUpload是在ASP.NET Pipeline的BeginRequest事件中截獲當前的HttpWorkerRequest對象,然后直接調用其ReadEntityBody等方法獲取客戶端傳遞過來的數據流,并加以分析和處理。并通過使用新的請求進行輪詢來獲取當前上傳的狀態。關于NeatUpload和其他開源組件的介紹可以參看JeffreyZhao的在ASP.NET應用程序中上傳文件,當然他還說了Memba Velodoc XP Edition和swfupload,寫的非常棒!

HttpWorkerRequest實現介紹

利用隱含的HttpWorkerRequest,用它的GetPreloadedEntityBody和ReadEntityBody方法從IIS為ASP.NET建立的pipe里分塊讀取數據可以實現文件上傳。實現方法如下:

復制代碼 代碼如下:

    IServiceProvider provider=(IServiceProvider) 
    HttpContext.Current; 
    HttpWorkerRequest wr=(HttpWorkerRequest) 
    provider.GetService(typeof(HttpWorkerRequest)); 
    byte[] bs=wr.GetPreloadedEntityBody(); 
    if(!wr.IsEntireEntityBodyIsPreloaded()) 
    { 
    int n=1024; 
    byte[] bs2=new byte[n]; 
    while(wr.ReadEntityBody(bs2,n) 〉0) 
    { 
    } 
    }

您可能感興趣的文章:
  • asp.net下文件上傳和文件刪除的代碼
  • asp.net web大文件上傳帶進度條實例代碼
  • Asp.net 文件上傳類(取得文件后綴名,保存文件,加入文字水印)
  • asp.net neatUpload 支持大文件上傳組件
  • asp.net 模擬提交有文件上傳的表單(通過http模擬上傳文件)
  • asp.net 多文件上傳,兼容IE6/7/8,提供完整代碼下載
  • asp.net(c#)開發中的文件上傳組件uploadify的使用方法(帶進度條)
  • Asp.Net 無刷新文件上傳并顯示進度條的實現方法及思路
  • asp.net fileupload控件上傳文件與多文件上傳
  • asp.net core實現文件上傳功能

標簽:曲靖 黃南 宜春 大興安嶺 新疆 延安 綿陽 焦作

巨人網絡通訊聲明:本文標題《asp.net 文件上傳實例匯總》,本文關鍵詞  asp.net,文件,上傳,實例,匯總,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《asp.net 文件上傳實例匯總》相關的同類信息!
  • 本頁收集關于asp.net 文件上傳實例匯總的相關信息資訊供網民參考!
  • 推薦文章
    欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品
  • <rt id="w000q"><acronym id="w000q"></acronym></rt>
  • <abbr id="w000q"></abbr>
    <rt id="w000q"></rt>
    亚洲免费av网站| www.亚洲免费av| 亚洲av无码一区二区三区网址| 日本韩国欧美国产| 国产精品久久国产精麻豆99网站| 国产黄人亚洲片| 黄大色黄女片18免费| xfplay精品久久| 精品一区二区三区在线播放视频| 中文字幕狠狠干| 日韩丝袜情趣美女图片| 免费看日韩精品| 日韩av无码一区二区三区不卡| 欧美日本高清视频在线观看| 亚洲香肠在线观看| 亚洲一区和二区| 3atv在线一区二区三区| 日韩福利电影在线| 亚洲成人网在线播放| 精品欧美一区二区在线观看 | 懂色av一区二区夜夜嗨| 亚洲综合图片一区| 亚洲国产精品激情在线观看| 高清国产一区二区三区| 农村妇女精品一区二区| 亚洲色图制服诱惑| 男人女人拔萝卜视频| 5566中文字幕一区二区电影| 日本不卡在线视频| 亚洲无人区码一码二码三码的含义| 精品福利一二区| 国产乱人伦偷精品视频免下载| 亚洲色图27p| 国产精品成人网| 9191在线视频| 日韩精品专区在线影院重磅| 国产在线视频一区二区| 欧美三级日本三级| 亚洲成人一区在线| 亚洲AV无码国产成人久久| 国产视频在线观看一区二区三区 | 精品一区二区三区影院在线午夜| 国产又粗又长又硬| 亚洲人成网站色在线观看| 国产精品果冻传媒| 久久综合色8888| av成人免费在线观看| 欧美精品第1页| 国产综合色产在线精品| 色欧美片视频在线观看在线视频| 午夜欧美视频在线观看| 一级二级黄色片| 尤物在线观看一区| 亚洲第一香蕉网| 成人欧美一区二区三区视频网页 | 国产欧美日产一区| wwwxxxx在线观看| 久久综合久久99| 99re热视频这里只精品| 欧美一卡二卡在线| 成人网在线免费视频| 欧美一区二区在线视频| 国产成人av一区二区三区在线| 欧美日韩欧美一区二区| 国产精品综合久久| 欧美高清一级片在线| 国产精品1区2区| 欧美丰满少妇xxxbbb| 国产一区二区三区久久悠悠色av | 午夜激情综合网| 特黄一区二区三区| 午夜伦理一区二区| 尤物在线免费视频| 人人精品人人爱| 色妹子一区二区| 精品影视av免费| 欧美日韩一区二区三区四区五区| 国产一区二区在线看| 欧美日韩国产首页在线观看| 国产精品香蕉一区二区三区| 91麻豆精品国产91久久久资源速度| 国产精品1区2区| 日韩美女一区二区三区四区| 91网站最新网址| 欧美经典一区二区三区| 亚洲成人av免费在线观看| 亚洲日本va午夜在线电影| 无码国产69精品久久久久同性| 亚洲免费观看在线视频| gv天堂gv无码男同在线观看| 午夜激情一区二区| 在线观看亚洲a| 国产精品亚洲第一区在线暖暖韩国| 欧美一级夜夜爽| 亚洲天堂小视频| 国产精品久久久久久久久果冻传媒| 最近中文字幕免费视频| 午夜精品免费在线| 91成人在线免费观看| 岛国精品在线观看| 久久理论电影网| 中文字幕5566| 亚洲成人中文在线| 欧美视频在线观看一区| 成人福利视频在线看| 国产日本欧美一区二区| 强伦人妻一区二区三区| 偷拍与自拍一区| 欧美日韩一区在线| 91看片淫黄大片一级| 成人欧美一区二区三区1314| 免费黄色激情视频| 国产一区二区调教| 久久综合色婷婷| 非洲一级黄色片| 久久精品国产亚洲5555| 欧美一级黄色录像| 亚洲av无码一区二区三区网址| 亚洲成av人片在线观看无码| 欧美日韩免费一区二区三区视频| 99久久伊人网影院| 综合色中文字幕| 成年人av电影| caoporn国产精品| 亚洲欧美日韩一区二区| 色婷婷综合激情| av电影在线观看一区| 亚洲免费av观看| 欧美少妇一区二区| 午夜诱惑痒痒网| 亚洲国产日韩在线一区模特| 欧美日韩亚洲综合在线 欧美亚洲特黄一级 | 亚洲欧美日韩一区| 欧美亚洲一区二区在线| 中文字幕av一区二区三区人妻少妇 | 制服丝袜日韩国产| 朝桐光av一区二区三区| 免费观看在线色综合| 久久综合狠狠综合| 亚洲女同二女同志奶水| 国产 日韩 欧美大片| 亚洲日本韩国一区| 欧美日韩美女一区二区| 国产精品久久AV无码| 久久精品久久99精品久久| 久久精品夜色噜噜亚洲a∨| 福利视频第一页| 成人a免费在线看| 一区二区三区日韩在线观看| 欧美日韩国产在线播放网站| 无套内谢大学处破女www小说| 激情伊人五月天久久综合| 国产蜜臀97一区二区三区 | 国产三级aaa| 99综合影院在线| 亚洲成av人片在www色猫咪| 欧美成人一区二区| 精品国产大片大片大片| 91捆绑美女网站| 秋霞电影网一区二区| 国产婷婷色一区二区三区四区 | 国产传媒在线看| 成人精品免费视频| 亚洲风情在线资源站| 精品国产一区二区三区不卡| 国产成人在线网址| av在线免费观看不卡| 美国十次综合导航| 国产精品素人视频| 欧美人xxxx| 国产7777777| 欧美体内she精高潮| 男人的天堂亚洲一区| 国产精品美女视频| 在线91免费看| 任我爽在线视频| 少妇熟女视频一区二区三区| 久久爱另类一区二区小说| 国产精品对白交换视频| 3d成人h动漫网站入口| 黄色录像免费观看| 中文视频在线观看| 国产成人在线电影| 亚洲成人动漫在线免费观看| 国产日韩影视精品| 欧美日韩精品免费观看视频| 欧美成人另类视频| 黑人玩弄人妻一区二区三区| 韩国毛片一区二区三区| 亚洲综合网站在线观看| 久久久午夜电影| 欧美美女直播网站| 欧美特黄一级片| 欧美做受喷浆在线观看| av在线这里只有精品| 久久爱www久久做| 亚洲va国产天堂va久久en| 中文字幕不卡一区| 日韩欧美成人一区二区| 一本色道综合亚洲|