Click here to Skip to main content
65,938 articles
CodeProject is changing. Read more.
Articles / web / HTML

File Uploader in ASP.NET and ASP.NET MVC

2.60/5 (3 votes)
15 Apr 2009CPOL2 min read 27.4K  
A class to upload files in ASP.NET and ASP.NET MVC

This is a class to upload files in ASP.NET and ASP.NET MVC.

Introduction

Uploading files is a common scenario and an essential part of many web applications. Here, I have created a class which can be used to upload files easily. The uploader class automatically validates all the necessities, i.e., validation of upload directory, file extensions, etc.

Background

There are plenty of resources on uploading a file in ASP.NET. But I have felt the need to have a class which would be easier and customizable as well as can perform validation, add prefix and/or suffix to file, encrypt filename, allow choice to overwrite existing file or not and so on. You have to just set the necessary properties you need. You can use it in your ASP.NET as well as ASP.NET MVC application.

Using this Class

Here, I am giving an example to use this class.

C#
Uploader uploader = new Uploader();

uploader.UploadPath     = Server.MapPath("~\Content\Uploads");
uploader.IsLowerName    = true;
uploader.IsEncryptName  = false;

uploader.Prefix = "Hello_";
uploader.Suffix = "_Boom";

uploader.AllowedExtensions.Add(".jpg");
uploader.AllowedExtensions.Add(".jpeg");
uploader.AllowedExtensions.Add(".gif");
uploader.AllowedExtensions.Add(".png");

bool success = uploader.DoUpload("MyFile");

if (success)
{
    //TODO: Code to handle success
}
else
{
    //TODO: Code to handle failure
}

Here, MyFile is the name of file input type.

HTML
 <!-- In Html -->
<input type="file" name="MyFile" id="MyFile" />
ASP.NET
<%--In tradition ASP.NET --%>
<asp:FileUpload ID="MyFile" runat="server" />

There is an overload of DoUpload() method. You can either pass the name of the file input as above or HttpPostedFile file object as follows:

C#
HttpPostedFile postedFile = HttpContext.Current.Request.Files["MyFile"] as HttpPostedFile;
uploader.DoUpload(postedFile);

There is also a method by which you can get the HttpPostedFile object by supplying the name of the file input.

C#
HttpPostedFile postedFile = uploader.GetHttpPostedFile("MyFile");
uploader.DoUpload(postedFile);

Configuration Settings

General Settings
UploadPathFull path where file should be uploaded exculding the filename (Mandatory)
UploadNameThe name which should be used to save the uploaded file with extension (Optional)
PrefixThe prefix to the filename (Optional)
SuffixThe suffix to the filename (Optional)
 
Conditional Settings
MinSizeThe minimum size of the file in bytes
MaxSizeThe maximum size of the file in bytes
IsOverwriteWhether a file is to overwrite or not
IsEncryptNameWhether a file name is to encrypt or not
IsLowerNameWhether a file name is to lower or not
IsRemoveSpaceWhether space is to be removed from a file name or not
AllowedExtensionsThe allowed file extensions with period
IsRemoveSpaceThe allowed mime types

 

Object Properties
UploadErrorThe object of UploadError class. This class holds error code and error message.
PostedFileThe object of PostedFile class. This class holds different information of posted file.
UploadedFileThe object of UploadedFile class. This class holds different information of uploaded file.

 

Properties of UploadError Class
CodeThe error code
MessageThe error message
 
Properties of PostedFile and UploadedFile Class
FileNameThe file name with extension
RawNameThe file name excluding extension
FileExtensionThe file extension with period
MimeTypeThe file MIME type
FullPathThe absolute path including the file name
FilePathThe absolute path to the file excluding the file name
FileSizeThe size of the file in bytes
IsImageWhether the file is image or not

If your upload is not succeeded, then you can get the error code and message by UploadError property. For example:

C#
string erroCode    = uploader.UploadError.Code;
string errorMessage = uploader.UploadError.Message;

Remember, here error code is not the actual http error number. I have used numbers from 1 to 10 so that the corresponding message can be customized.

On the other hand, if your upload attempt is succeeded, then you can use information related to the posted file as well as uploaded file by PostedFile and UploadedFile. For example:

C#
string previousFilename = uploader.PostedFile.FileName;
string previousFilePath = uploader.PostedFile.FilePath;

string uploadedFilename = uploader.UploadedFile.FileName;
string uploadedFilePath = uploader.UploadedFile.FilePath;

Enjoy this!

License

This article, along with any associated source code and files, is licensed under The Code Project Open License (CPOL)