.NET中 文件上传功能的实现

首先判断,FileUpload控件的HasFile属性是否为true,,如果为true,则表示控件已经确认上传文件存在。。。。调用SaveAs方法实现上传。
有三种访问上传文件的方式,一,FileBytes..二,FileContent..三,PostedFile
其中,通过PostedFile属性,调用这个属性可以获得一个与上传文件相关的HttpPostedFile对象,使用这个对象可以获得上传文件相关的信息。
例如,调用HttpPostedFile对象的ContentLength,可获得文件大小,ContentType可以获得上传文件类型。等等。

示例:

ContractedBlock.gif ExpandedBlockStart.gif 文件上传示例代码
 
   
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)
{
bool fileIsValid = false ;
// 如果确认了上传文件,则判断文件类型是否符合要求
if ( this .FileUpload1.HasFile)
{
// 获取上传文件的后缀
String fileExtension = System.IO.Path.GetExtension( this .FileUpload1.FileName).ToLower();
String[] restrictExtension
= { " .gif " , " .jpg " , " .bmp " , " .png " };
// 判断文件类型是否符合要求
for ( int i = 0 ; i < restrictExtension.Length; i ++ )
{
if (fileExtension == restrictExtension)
{
fileIsValid
= true ;

}

}
// 如果文件类型符合要求,调用SaveAs方法实现上传,并显示相关信息
if (fileIsValid == true )
{
try
{
this .Image1.ImageUrl = " ~/images/ " + FileUpload1.FileName;
this .FileUpload1.SaveAs(Server.MapPath( " ~/images/ " ) + FileUpload1.FileName);
this .Label1.Text = " 文件上传成功 " ;
this .Label1.Text += " <Br/> " ;
this .Label1.Text += " <li> " + " 原文件路径: " + this .FileUpload1.PostedFile.FileName;
this .Label1.Text += " <Br/> " ;
this .Label1.Text += " <li> " + " 文件大小: " + this .FileUpload1.PostedFile.ContentLength + " 字节 " ;
this .Label1.Text += " <Br/> " ;
this .Label1.Text += " <li> " + " 文件类型: " + this .FileUpload1.PostedFile.ContentType;

}
catch
{
this .Label1.Text = " 文件上传不成功! " ;
}
finally
{


}
}
else
{
this .Label1.Text = " 只能够上传后缀为.gif,.jpg,.bmp,.png的文件夹 " ;

}

}
}
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值