视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
asp.net fileupload控件上传文件与多文件上传
2020-11-27 22:38:46 责编:小采
文档


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.gxlcms.com</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");
}
 }
}
 

去掉绿色部分就可上传任何文件,它是用一个正则表达式来验证上传文件的类型

在ASP.NET 2.0中使用FileUpload服务器控件很容易的就能将文件上传到服务器。

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>" +
"文件扩展名:" + 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 = "发生错误:" + ex.Message.ToString();
}
 }
 else
 {
Label1.Text = "没有选择要上传的文件!";
 }
}

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

使用fileupload实现多文件上传,可以像传单个文件那样对每个文件单独进行处理,除此之外,还可以使用HttpFileCollection类捕获从Request对象发送来的所有文件,然后再单独对每个文件进行处理。

后端代码 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 += "发生错误: " + Ex.Message;
}
 }
}

2、上传文件类型的验证
对上传文件类型的验证既可以在客户端进行,也可以在服务器端进行。
客户端可以使用验证控件来进行,这里重点介绍如何在服务器端进行验证。

以上cs文件中已用GetExtension获取了文件的扩展名,只要稍加判断即可实现上传类型验证:
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>" +
"文件扩展名:" + 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 = "发生错误:" + ex.Message.ToString();
}
}
else
{
Label1.Text = "只允许上传rar、zip文件!";
}
 }
 else
 {
Label1.Text = "没有选择要上传的文件!";
 }
}

注意,不能过分依赖于客户端验证控件和服务器端上述方法的验证,因为用户只需将文件扩展名更改为允许的类型就可以避开上边的验证,这对用户来说并不是件困难的事情。

3、解决文件大小
在ASP.NET 2.0中FileUpload默认上传文件最大为4M,不过可以在web.cofig中修改相关节点来更改这个默认值,相关节点如下:

代码如下:
<system.web>
 <httpRuntime maxRequestLength="40690" executionTimeout="6000" />
</system.web>

maxRequestLength表示可上传文件的最大值,executionTimeout表示ASP.NET关闭前允许发生的上载秒数。

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

在ASP程序中一旦使用表单上传文件(form的enctype属性值为multipart/form-data),服务器端就不能再用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 = "发生错误:" + ex.Message.ToString();
}
 }
 else
 {
Label1.Text = "没有选择要上传的文件!";
 }
}

下载本文
显示全文
专题