本文采用的是使用<asp:FileUpload>控件来上传文件,如下在aspx中设置:
<asp:FileUpload ID="fileICON" runat="server" />
<asp:RequiredFieldValidator ID="rfvFile" runat="server" ControlToValidate="fileICON"
ErrorMessage="请选择文件" ForeColor="Red"></asp:RequiredFieldValidator>
后台代码如下:
string savePath = "Page/Silverlight/ICONS/";//指定上传文件的保存路径
//判断是否已经选取文件
if(fileICON.HasFile)
{
string fileNmae = Guid.NewGuid() + Path.GetExtension(fileICON.FileName);//生成一个不易重复的字符串并获取路径的扩展名
savePath = Path.Combine(savePath, fileNmae);//合并路径(准确地合并两个路径而不用去担心那个烦人的“\”字符)
string strExtn = System.IO.Path.GetExtension(fileICON.FileName).ToLower();////取得文件的扩展名,并转换成小写
//只允许上传图像格式的文件
string[] allowExtension = { ".jpg", ".gif", ".png","jpeg"};
//判断数组中是否包含获取到的扩展名
if (allowExtension.Contains(strExtn))
{
//保存总路径
//string savePath = Server.MapPath("~/upload/");//指定上传文件在服务器上的保存路径
//保存路径(fileICON.PostedFile.SaveAs(savepath + fileICON.FileName)或者FileUpload.SaveAs(savePath)也可)(不同的方式不同的写法,最后结果是一样的)
fileICON.SaveAs(Server.MapPath("~/" + savePath));
}
else
{
this.lblMsg.Text = "上传文件格式不正确";//若不是图片格式则提示此信息
}
}
附加:也可以限定文件的大小:
//对上传文件的大小进行检测,限定文件最大不超过1M
if (FileUpload1.PostedFile.ContentLength > 1024000)
{
// 不允许上传
this.lblMsg.Text = "文件大小超出1M";
}else
{
//允许上传
}