Creating MVC Application
Let us implement these in a sample Application. Open Visual Studio. Go to File->New->Project. Give a suitable name to the Application. Click OK.
data:image/s3,"s3://crabby-images/79a63/79a63f28ccd996816beefe9aa7e9e34f14f037fb" alt=""
Select MVC Template. Click OK.
data:image/s3,"s3://crabby-images/ac48e/ac48e67fd493880fe018a0044bfd49f73a22119e" alt=""
Adding Folder
We will add a folder to store the files in the application. Here, I have added a folder in the application.
data:image/s3,"s3://crabby-images/7dc57/7dc5763db1c79a50817257edaadb8c85fc892fe1" alt=""
Adding Controller
Let us add a controller. Right click on the Controller. Add->Controller.
data:image/s3,"s3://crabby-images/b593a/b593a8a95fddce886057d55fc819e11ee171ddc5" alt=""
Select MVC 5 Controller -Empty. Click Add.
data:image/s3,"s3://crabby-images/6a7fb/6a7fb8546e4389cffaa4b461fe6d70e83a05ddc8" alt=""
Give a suitable name to the controller.
data:image/s3,"s3://crabby-images/125dd/125dd35068d37f05b633bc342443ef01c883dce7" alt=""
Write the following code in the controller.
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Web;
using System.Web.Mvc;
namespace FileUpload.Controllers
{
public class UploadController: Controller
{
// GET: Upload
public ActionResult Index()
{
return View();
}
[HttpGet]
public ActionResult UploadFile()
{
return View();
}
[HttpPost]
public ActionResult UploadFile(HttpPostedFileBase file)
{
try
{
if (file.ContentLength > 0)
{
string _FileName = Path.GetFileName(file.FileName);
string _path = Path.Combine(Server.MapPath("~/UploadedFiles"), _FileName);
file.SaveAs(_path);
}
ViewBag.Message = "File Uploaded Successfully!!";
return View();
}
catch
{
ViewBag.Message = "File upload failed!!";
return View();
}
}
}
}
Adding View
Right click on UploadFileActionResult. Go to Add View.
data:image/s3,"s3://crabby-images/8d394/8d394db526318d9edcc5a153e9afed5e625a588d" alt=""
Select the empty template. Click add.
data:image/s3,"s3://crabby-images/eeff5/eeff5989bd787fb879861f124fdcb300fa4fbeac" alt=""
Write the following code in the View.
@{
ViewBag.Title = "UploadFile";
}
<h2>UploadFile</h2>
@using(Html.BeginForm("UploadFile","Upload", FormMethod.Post, new { enctype="multipart/form-data"}))
{
<div>
@Html.TextBox("file", "", new { type= "file"}) <br />
<input type="submit" value="Upload" />
@ViewBag.Message
</div>
}
Browse the Application
Let us now run the Application and check if it is working fine or not. Browse the Application.
data:image/s3,"s3://crabby-images/31763/31763f5bff2bd8571ed659e3a56ee950e1eb1b31" alt=""
Click upload. I have debugged the code to verify that the file gets uploaded successfully.
data:image/s3,"s3://crabby-images/43266/43266109e85813ecbf735042bd8a76b8b8d3bedf" alt=""
The code is working as per the expectations, as it hits the success message. We should get this message on the View, as well.
data:image/s3,"s3://crabby-images/c8d5f/c8d5f7073ed4b4528d4373062796bd9d47876422" alt=""
We will verify the file uploaded, by opening the folder in the Application’s directory.
data:image/s3,"s3://crabby-images/55bd8/55bd819fc78c291480bd76114760b989711383f2" alt=""
Hence, we have just learned how to upload the file in ASP.NET MVC. I hope this post is useful to developers.