In this article i will show you how to upload file in MVC 3 by using razor engine. So for this follow the step.
Have a look of my this article for uploading multiple file mvc3
Step 1:
Fist create a new MVC 3 project.
data:image/s3,"s3://crabby-images/1389f/1389f67a03452b9ec49764047d0ef00c0cbf29f5" alt=""
Add the project name and click ok. As you click on ok button a new window will open in this window you will option for project type. Select the internet application and razor click ok button.
public ActionResult Index()
{
ViewBag.Message = "MVC 3 File Upload";
return View();
}
After clicking ok your project will open now got to Home controller and add the view for index method{
ViewBag.Message = "MVC 3 File Upload";
return View();
}
data:image/s3,"s3://crabby-images/bef38/bef38dc0312bc09b04bc5b3d2f139ef2ae353e68" alt=""
Now click Add button to add the view. do not change the view name . bcz each view represent a method.
Now add the following html code in your index page.
@{
ViewBag.Title = "Home Page";
}
@using (Html.BeginForm("Index", "Home", FormMethod.Post, new { enctype = "multipart/form-data" }))
{
Select Image
}
ViewBag.Title = "Home Page";
}
@using (Html.BeginForm("Index", "Home", FormMethod.Post, new { enctype = "multipart/form-data" }))
{
Select Image
}
in above code i have added file upload control and a post button.
@using (Html.BeginForm("Index", "Home", FormMethod.Post, new { enctype = "multipart/form-data" }))
the above line of code is the form tag.now again come to your controller and add a post method for the index. refer the below code.
[HttpPost]
public ActionResult Index(HttpPostedFileBase file)
{
// extract only the fielname
var fileName = Path.GetFileName(file.FileName);
// store the file inside ~/images/User-Image folder
var path = Path.Combine(Server.MapPath("~/images/"), fileName);
// this is the string you have to save in your DB
string filepathToSave = "images/" + fileName;
file.SaveAs(path);
//--------------------------------------------
// Code to save file in DB by passing the file path
//----------------------------------------------
return View();
}
In above code HttpPostedFileBase is help to get the file detail as page will post when we click on upload button.public ActionResult Index(HttpPostedFileBase file)
{
// extract only the fielname
var fileName = Path.GetFileName(file.FileName);
// store the file inside ~/images/User-Image folder
var path = Path.Combine(Server.MapPath("~/images/"), fileName);
// this is the string you have to save in your DB
string filepathToSave = "images/" + fileName;
file.SaveAs(path);
//--------------------------------------------
// Code to save file in DB by passing the file path
//----------------------------------------------
return View();
}
now create a images folder in your root directory . This is the directory where we will save the image.
data:image/s3,"s3://crabby-images/9da6d/9da6df992f41a1b8f6819f8bd749329bb2fbf835" alt=""
Now we have done . Now run your code.
Now i will explain what actually happen at code end
data:image/s3,"s3://crabby-images/cc2be/cc2bed9f96edc2695f2a0d87714e10cb5f05d877" alt=""
Now select the file and click upload button
data:image/s3,"s3://crabby-images/12708/12708421b1e36d4b5f159b64b09ebc75ff475feb" alt=""
As you press upload your break point inedx page will hit
data:image/s3,"s3://crabby-images/c5eae/c5eae417f52f6440175d34ef495dbed7190c9d8b" alt=""
In this when you check the parameter value you will fiund the file detail . Now press F10 for next step.
data:image/s3,"s3://crabby-images/add4c/add4c7fd93936e136cb6f87ec0a5897e326d21b8" alt=""
Here we are getting the uploaded file name.
data:image/s3,"s3://crabby-images/24db4/24db4923bf10c3bcaafe48fdc795e0ee906b4873" alt=""
Here we are getting the file local path.
data:image/s3,"s3://crabby-images/cc861/cc861d8e6e08c7b268a4ca22e92deb8a2871dfb1" alt=""
Here we are saving file in images folder. now finish the process and open your images folder. you will get your image
data:image/s3,"s3://crabby-images/ee72e/ee72e3b50ffdebca735d60e72e1cd84a428f8d75" alt=""
Tags: C#.Net , HTML5 , MVC
No comments:
Post a Comment
Note: only a member of this blog may post a comment.