HowTo: Fileupload with ASP.NET MVC

 

imageIn this HowTo I´m going to give you a short invitation how to implement a fileupload with ASP.NET MVC.

The Controller

On the controller-side we create an ActionMethod named “FileUpload”:

        [AcceptVerbs(HttpVerbs.Post)]
        public ActionResult FileUpload(HttpPostedFileBase file)
        {
            ViewData["Message"] = file.FileName + " - " + file.ContentLength.ToString();
            return View("Index");
        }

HttpPostedFileBase is an abstract basic-class and has the same characteristics like HttpPostedFile. That´s because you are able to make this with a UnitTest as well and create your own deductions from the abstract basic-class.

With “file” I´m able to reach several characteristics with this method and if I want to I can save the file:

image

Now the Frontend:

The View

In the “index” view I create a formulary with the HTML Helper.

Important: The fileupload only works when enctype=”multipart/form-data” is activated!

        <%using(Html.BeginForm("FileUpload",
                               "Home",
                               FormMethod.Post,
                               new {enctype = "multipart/form-data"})) {%>
        <input type="file" name="file" id="file" />
        <input type="submit" name="submit" value="Submit" />
        <% } %>

Simple and fast Smiley 

File size:

Usually you won´t be able to upload files with more than 4MB. But you can change this in the web.config: maxRequestSize

More Information´s

Scott Hanselman has written a fantastic Blogpost about this subject. It also includes how Unit-Tests could look like in such a case.

[Download Democode]

If you enjoyed this post, please consider leaving a comment or subscribing to the RSS feed to have future articles delivered to your feed reader.

About the author

Written by Code Inside Team

Learn more about our team.

One Response

Comment on this post

Recent Posts

  • Automated Security Analyser for ASP.NET websites

    Evil Hackers are lurking everywhere and many Web-applications are delicately and share “too much” with the attacker. A quick (first!) overview offers the Tool “ASafaWeb”. All the website does is making a few requests and writing an Analyses including problem solving’s. There are no permanent disadvantages (bad requests/ DoS attacks and so on). Example: KnowYourStack.com ...

  • image1489-570x194.png
    „Sign in with Twitter“ for your own ASP.NET WebApp

      “Sign in with Twitter” is a popular practice to authenticate the users on your website. One advantage compared to an own registration is the lower inhibition for the user. But on the other hand Twitter doesn’t fess up with all the information’s and you will get into a kind of addiction. At the end ...

  • image1485-570x194_thumb.png
    CodePlex is going to be updated

      CodePlex the Microsoft Open Source Project Hosting Plattform hasn’t changed that much in the last few years and for a few times I thought Microsoft stopped the whole developing process. But now I found out that there is still life in the project. Maybe it is because of the success of GitHub or because ...

  • image1474_thumb.png
    What does Adobe in the flash-free web? Magazine-Style Layouts with CSS Regions!

      Adobe is well known for Photoshop and Flash but of course there is a lot more. According to the “Future Post” from Google Adobe declared one of their big subjects on a Blogpost. I’m talking about the W3C Working Draft to CSS Regions. Adobe cooperates with the WebKit Team and W3C on this. What ...

  • image1471-523x194.png
    HTML 5 Games, Tooling & 3D

      Game Developing is an interesting subject for all kind of software developer. But as a web developer without any Flash-skills there aren’t that much starting points. With HTML5 and the combination between Javascript, CSS3 and fast browsers there are the first “robust” HTML5 games. HTML5 games? Is this real? Neowin created a “Top 10” ...

Support us