ASPX文件上传限制类型实例源码asp.net
小菜分享下自己的思路,不知道各位有木有更好的方法
aspx 文件上传限制格式源码:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
public partial class _Default : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
//www.yizuotu.net/
}
protected void Button1_Click(object sender, EventArgs e)
{
#region 文件类型判断
//得到上传文件名
string FileName = FileUpload1.FileName;
//判断文件名中有木有.
if (!(FileName.Contains(".")))
{
Response.Write("该文件类型不允许上传!");
return;
}
//取到.的下标
int index = FileName.LastIndexOf('.');
char[] c = FileName.ToCharArray();
string File_hz = "";
//循环得到后缀名
for (int i = 0; i < FileName.Length - index; i++)
{
File_hz += c[index + i];
}
//允许上传的文件名
string[] FileType = { ".jpg", ".gif", ".bmp", ".jpeg" };
bool bl = false;
//循环遍历上传的文件扩展名是否在允许的扩展名中
foreach (string str in FileType)
{
if (str == File_hz)
{
bl = true;
}
}
if (bl == false)
{
Response.Write("该文件类型不允许上传!");
return;
}
#endregion
//获取时间戳给文件命名,这样写感觉有点复杂,不知道各位有木有好的方法获取时间戳
DateTime starttime = TimeZone.CurrentTimeZone.ToLocalTime(new System.DateTime(1970, 1, 1, 0, 0, 0, 0));
DateTime newtime = DateTime.Now;
long utime = (long)Math.Round((newtime - starttime).TotalMilliseconds, MidpointRounding.AwayFromZero);
FileName = utime.ToString() + File_hz;
//获取文件字节数
string FileLenght = FileUpload1.PostedFile.ContentLength.ToString();
string FilePath = Server.MapPath("img/" + FileName);
//上传
FileUpload1.SaveAs(FilePath);
Response.Write("上传成功
文件大小:" + FileLenght + "
路径:img/" + FileName);
}
}
如何上传文件并限定文件格式
本文采用的是使用<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/zzzyk.com/";//指定上传文件的保存路径
//判断是否已经选取文件
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 = "上传文件格式不正确";//若不是图片格式则提示此信息
}
}
aspx 文件上传限制格式附加:也可以限定文件的大小:
//对上传文件的大小进行检测,限定文件最大不超过1M
if (FileUpload1.PostedFile.ContentLength > 1024000)
{
// 不允许上传
this.lblMsg.Text = "文件大小超出1M";
}else {
//允许上传
}
补充:Web开发 , ASP.Net ,