获取发布的文件扩展名asp.net

时间:2013-10-12 11:56:39

标签: c# asp.net file-upload

我一直得到“只允许图片”,我试过“file.PostedFile.FileName”也行不通!!

此代码是在一个单独的类中编写的。

public static String UploadFile(FileUpload file, String type, out String filename)
{
    String ext = System.IO.Path.GetExtension(file.FileName);
    filename = "";
    if (file.PostedFile.ContentLength > 2000000)
    {
        return "File is larger than 2 MB";
    }
    else if (type != "File")
    {
        if (ext.ToLower() != ".jpg" || ext.ToLower() != ".png" || ext.ToLower() != ".gif" || ext.ToLower() != ".jpeg")
        {
            return "Only images are allowed";
        }
        else
        {
            filename = System.IO.Path.GetRandomFileName() + "_" + file.PostedFile.FileName;
            String root = HttpContext.Current.Server.MapPath("~/Images/");
            file.SaveAs(root + type + "/" + filename);
            return "Success";
        }
    }
    else
    {
        filename = System.IO.Path.GetRandomFileName() + "_" + file.PostedFile.FileName;
        String root = HttpContext.Current.Server.MapPath("~/Files/");
        file.SaveAs(root + filename);
        return "Success";
    }
}

3 个答案:

答案 0 :(得分:6)

你的情况有误,应该如下:

if (ext.ToLower() != ".jpg" && ext.ToLower() != ".png" && ext.ToLower() != ".gif" && ext.ToLower() != ".jpeg")
{
return "Only images are allowed";
}
else
{
///statement
}

OR

   if (ext.ToLower() == ".jpg" || ext.ToLower() == ".png" || ext.ToLower() == ".gif" || ext.ToLower() == ".jpeg")
    {

    ///statement
    }
    else
    {
return "Only images are allowed";
    }

答案 1 :(得分:4)

@ volpav的答案将解决您的问题,但是大if并不是解决问题的最简单方法。

更优雅的是定义接受的扩展名列表,并检查列表中是否有ext。这样做的好处是,如果您以后必须更改有效类型,则更容易维护,并且如果需要,您可以使用户可以定义扩展名。

在下面的示例中,我为我的类定义了一个常量(well readonly变量),其中包含一个包含所有异常的数组,并使用Contains()扩展方法来测试是否存在extUploadFile

中验证时
public static readonly string[] VALID_EXTENSIONS = 
    new string[4] { ".png", ".jpg", ".gif", ".jpeg" };

// in UploadFile ...
    if (!VALID_EXTENSIONS.Contains(ext.ToLower())) { 
         return "Only images are allowed";
    }

通过在上面的代码中使其静态,我可以在UI中使用此列表来指示什么是例外扩展,而不是让用户猜测什么是有效的图像类型(毕竟,除了其他图像类型之外你所包括的那些)。

答案 2 :(得分:3)

检查有效扩展名的条件在逻辑上是不正确的(始终评估为true)。它应该是这样的(||&&替换):

if (ext.ToLower() != ".jpg" && ext.ToLower() != ".png" && ext.ToLower() != ".gif" && ext.ToLower() != ".jpeg")
{
    return "Only images are allowed";
}