欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

asp.net fileupload控件上傳文件與多文件上傳

 更新時(shí)間:2014年11月27日 15:16:26   投稿:mdxy-dxy  
這篇文章主要介紹了asp.net fileupload控件上傳文件的方法,fileupload控件多文件上傳,以及fileupload上傳時(shí)實(shí)現(xiàn)文件驗(yàn)證的方法,需要的朋友可以參考下

1、前臺文件 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>asp.net fileupload控件上傳文件_www.dbjr.com.cn</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>

2、后端代碼 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");
}
 }
}
 

去掉綠色部分就可上傳任何文件,它是用一個(gè)正則表達(dá)式來驗(yàn)證上傳文件的類型

在ASP.NET 2.0中使用FileUpload服務(wù)器控件很容易的就能將文件上傳到服務(wù)器。

1、aspx文件代碼

<%@ Page Language="C#" AutoEventWireup="true" CodeFile="fileupload.aspx.cs" Inherits="fileupload" %>
<!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>FileUpload上傳文件示例-jb51.net</title>
</head>
<body>
 <form id="form1" runat="server">
 <div>
<asp:FileUpload ID="FileUpload1" runat="server" />
<asp:Button ID="Button1" runat="server" _disibledevent="Button1_Click" Text="上傳文件" /><br />
<asp:Label ID="Label1" runat="server" Height="269px" Text="Label" Width="360px"></asp:Label></div>
 </form>
</body>
</html>

2、后端代碼 aspx.cs:

protected void Button1_Click(object sender, EventArgs e)
{
 if (FileUpload1.HasFile)
 {
try
{
FileUpload1.SaveAs(Server.MapPath("upload") + "\\" + FileUpload1.FileName);
Label1.Text = "客戶端路徑:" + FileUpload1.PostedFile.FileName + "<br>" +
"文件名:" + System.IO.Path.GetFileName(FileUpload1.FileName) + "<br>" +
"文件擴(kuò)展名:" + 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 = "發(fā)生錯(cuò)誤:" + ex.Message.ToString();
}
 }
 else
 {
Label1.Text = "沒有選擇要上傳的文件!";
 }
}

1、asp.net fileupload多文件上傳的例子

使用fileupload實(shí)現(xiàn)多文件上傳,可以像傳單個(gè)文件那樣對每個(gè)文件單獨(dú)進(jìn)行處理,除此之外,還可以使用HttpFileCollection類捕獲從Request對象發(fā)送來的所有文件,然后再單獨(dú)對每個(gè)文件進(jìn)行處理。

后端代碼 aspx.cs:

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

2、上傳文件類型的驗(yàn)證
對上傳文件類型的驗(yàn)證既可以在客戶端進(jìn)行,也可以在服務(wù)器端進(jìn)行。
客戶端可以使用驗(yàn)證控件來進(jìn)行,這里重點(diǎn)介紹如何在服務(wù)器端進(jìn)行驗(yàn)證。

以上cs文件中已用GetExtension獲取了文件的擴(kuò)展名,只要稍加判斷即可實(shí)現(xiàn)上傳類型驗(yàn)證:
aspx.cs:

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>" +
"文件擴(kuò)展名:" + 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 = "發(fā)生錯(cuò)誤:" + ex.Message.ToString();
}
}
else
{
Label1.Text = "只允許上傳rar、zip文件!";
}
 }
 else
 {
Label1.Text = "沒有選擇要上傳的文件!";
 }
}

注意,不能過分依賴于客戶端驗(yàn)證控件和服務(wù)器端上述方法的驗(yàn)證,因?yàn)橛脩糁恍鑼⑽募U(kuò)展名更改為允許的類型就可以避開上邊的驗(yàn)證,這對用戶來說并不是件困難的事情。

3、解決文件大小限制
在ASP.NET 2.0中FileUpload默認(rèn)上傳文件最大為4M,不過可以在web.cofig中修改相關(guān)節(jié)點(diǎn)來更改這個(gè)默認(rèn)值,相關(guān)節(jié)點(diǎn)如下:

復(fù)制代碼 代碼如下:

<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中已不存在了:

aspx.cs:

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

相關(guān)文章

最新評論