4 Ways To Get Form Data In ASP.NET MVC 5
C#
6 February 2024

4 Ways To Get Form Data In ASP.NET MVC 5

By

In this tutorial you will learn:
1. How to collect from value in Class in ASP.NET MVC 5 Project?
2. What are the different ways to Retrieve Form Values?
3. What is FormCollection Object, ModelBinder Class and UpdateModel Class?

In this article, I am going to explain 4 different ways to Collect Form Data in Controller class in ASP.NET MVC 5. It is a very basic job for any application is to collect form data and process them with programming logic and save to the database. There are various ways to gather form value in class and I have added 4 most popular and suitable ways to do it.

1. Create New ASP.NET MVC 5 Project and Add Controller, Models and Views.
1. Create New MVC ProjectSaveFormData in Visual Studio 2013,2015 or 2017. Go to FileNewProject. Select Web in left pane and then select ASP.NET Web Application (.Net Framework) in middle panel. A Template window will be opened. Select Empty Template and Check MVC CheckBox and click OK.

2. Create Model: Create a Model class StudentModel.cs. Right click on Models Folder AddClass.

Add Model Class

Paste following code in StudentModel.cs

  1. namespace SaveFormData.Models
  2. {
  3. public class StudentModel
  4. {
  5. public int Id { get; set; }
  6. public string Name { get; set; }
  7. public string City { get; set; }
  8. public string Address { get; set; }
  9. }
  10. }

3. Create Controller: Create a Controller HomeController.csRight click on Controllers Folder > Add > Controller. Select MVC 5 Controller with read/write actions.

Add Controller
Add Controller

4. Delete Unnecessary code and your HomeController.cs should look like this. However, it is not mandatory and you can use your own way to implement code.

  1. using System.Web.Mvc;
  2.  
  3. namespace SaveFormData.Controllers
  4. {
  5. public class HomeController : Controller
  6. {
  7. // GET: Home
  8. public ActionResult Index()
  9. {
  10. return View();
  11. }
  12.  
  13. // GET: Home/Create
  14. public ActionResult Create()
  15. {
  16. return View();
  17. }
  18.  
  19. // POST: Home/Create
  20. [HttpPost]
  21. public ActionResult Create(FormCollection collection)
  22. {
  23. try
  24. {
  25. return View(“Index”);
  26. }
  27. catch
  28. {
  29. return View();
  30. }
  31. }
  32. }
  33. }

5. Create Views:Right click on Create() Action Method in HomeController class and select Add View. Give View Name Create and then choose Create Template from dropdown list. Select StudentModel from Model Class dropdown list. Check Use a layout page and click Add.

Add View with Model

Create.cshtml View Page

  1. @model SaveFormData.Models.StudentModel
  2.  
  3. @{
  4. ViewBag.Title = “Create”;
  5. }
  6.  
  7. <h2>Create</h2>
  8.  
  9.  
  10. @using (Html.BeginForm())
  11. {
  12. @Html.AntiForgeryToken()
  13. <div class=”form-horizontal”>
  14. <h4>StudentModel</h4>
  15. <hr />
  16. @Html.ValidationSummary(true, “”, new { @class = “text-danger” })
  17. <div class=”form-group”>
  18. @Html.LabelFor(model => model.Name, htmlAttributes: new { @class = “control-label col-md-2” })
  19. <div class=”col-md-10″>
  20. @Html.EditorFor(model => model.Name, new { htmlAttributes = new { @class = “form-control” } })
  21. @Html.ValidationMessageFor(model => model.Name, “”, new { @class = “text-danger” })
  22. </div>
  23. </div>
  24.  
  25. <div class=”form-group”>
  26. @Html.LabelFor(model => model.City, htmlAttributes: new { @class = “control-label col-md-2” })
  27. <div class=”col-md-10″>
  28. @Html.EditorFor(model => model.City, new { htmlAttributes = new { @class = “form-control” } })
  29. @Html.ValidationMessageFor(model => model.City, “”, new { @class = “text-danger” })
  30. </div>
  31. </div>
  32.  
  33. <div class=”form-group”>
  34. @Html.LabelFor(model => model.Address, htmlAttributes: new { @class = “control-label col-md-2” })
  35. <div class=”col-md-10″>
  36. @Html.EditorFor(model => model.Address, new { htmlAttributes = new { @class = “form-control” } })
  37. @Html.ValidationMessageFor(model => model.Address, “”, new { @class = “text-danger” })
  38. </div>
  39. </div>
  40.  
  41. <div class=”form-group”>
  42. <div class=”col-md-offset-2 col-md-10″>
  43. <input type=”submit” value=”Create” class=”btn btn-default” />
  44. </div>
  45. </div>
  46. </div>
  47. }
  48.  
  49. <div>
  50. @Html.ActionLink(“Back to List”, “Index”)
  51. </div>
  52.  
  53. <script src=”~/Scripts/jquery-1.10.2.min.js”></script>
  54. <script src=”~/Scripts/jquery.validate.min.js”></script>
  55. <script src=”~/Scripts/jquery.validate.unobtrusive.min.js”></script>

6. Using same process create Index view Page. Right click on Index Action Method in HomeController class and click Add View. Give View Name: Index, Choose Template: Empty (Without Model), tick on Use a Layout Page and click on Add button.

Add View from Model

Index.cshtml View Page

  1. @{
  2. ViewBag.Title = “Index Page”;
  3. }
  4.  
  5. <h2>View Details</h2>
  6.  
  7. <strong>Name</strong> : @ViewData[“Name”]<br />
  8. <strong>City</strong> : @ViewData[“City”]<br />
  9. <strong>Address</strong> : @ViewData[“Address”]<br />

Now, your project is ready with a form Create. You can navigate it like this

Create page

In this article, I will fill some data in Create Form and when click Create Button, it will display Index View Page with Filled data.


 

Method 1. Retrieve Form Data using FormCollection Object.

FormCollection object is used for accessing Form Data in controller class. The FormCollection Object automatically receives the posted form data. In the following example I am going to explain how to use FormCollection Object to retrieve form data into controller class.

  1. using System.Web.Mvc;
  2.  
  3. namespace SaveFormData.Controllers
  4. {
  5. public class HomeController : Controller
  6. {
  7. // GET: Home
  8. public ActionResult Index()
  9. {
  10. return View();
  11. }
  12.  
  13. // GET: Home/Create
  14. public ActionResult Create()
  15. {
  16. return View();
  17. }
  18.  
  19. // POST: Home/Create
  20. [HttpPost]
  21. public ActionResult Create(FormCollection collection)
  22. {
  23. try
  24. {
  25. //Method 1: Using Component Name
  26. /*ViewData[“Name”] = collection[“Name”];
  27. ViewData[“City”] = collection[“City”];
  28. ViewData[“Address”] = collection[“Address”];*/
  29.  
  30. //Method 2: Using Component Index Position
  31. ViewData[“Name”] = collection[1];
  32. ViewData[“City”] = collection[2];
  33. ViewData[“Address”] = collection[3];
  34. return View(“Index”);
  35. }
  36. catch
  37. {
  38. return View();
  39. }
  40. }
  41. }
  42. }

Output

Output
Output

 

Method 2. Retrieve Form Data using Model Binder – Using Parameter Type.

  1. using System.Web.Mvc;
  2.  
  3. namespace SaveFormData.Controllers
  4. {
  5. public class HomeController : Controller
  6. {
  7. // GET: Home
  8. public ActionResult Index()
  9. {
  10. return View();
  11. }
  12.  
  13. // GET: Home/Create
  14. public ActionResult Create()
  15. {
  16. return View();
  17. }
  18.  
  19. // POST: Home/Create
  20. [HttpPost]
  21. public ActionResult Create(string name, string city, string address)
  22. {
  23. try
  24. {
  25. ViewData[“Name”] = name;
  26. ViewData[“City”] = city;
  27. ViewData[“Address”] = address;
  28. return View(“Index”);
  29. }
  30. catch
  31. {
  32. return View();
  33. }
  34. }
  35. }
  36. }

https://googleads.g.doubleclick.net/pagead/ads?gdpr=0&us_privacy=1—&gpp_sid=-1&client=ca-pub-2586160620136296&output=html&h=200&slotname=3653952594&adk=3083015738&adf=1523998013&pi=t.ma~as.3653952594&w=1021&fwrn=4&lmt=1707222333&rafmt=11&format=1021×200&url=https%3A%2F%2Fwww.completecsharptutorial.com%2Fmvc-articles%2F4-ways-to-collect-form-data-in-controller-class-in-asp-net-mvc-5.php&wgl=1&uach=WyJXaW5kb3dzIiwiMTAuMC4wIiwieDg2IiwiIiwiMTIxLjAuMjI3Ny45OCIsbnVsbCwwLG51bGwsIjY0IixbWyJOb3QgQShCcmFuZCIsIjk5LjAuMC4wIl0sWyJNaWNyb3NvZnQgRWRnZSIsIjEyMS4wLjIyNzcuOTgiXSxbIkNocm9taXVtIiwiMTIxLjAuNjE2Ny4xMzkiXV0sMF0.&dt=1707222313190&bpp=1&bdt=704&idt=334&shv=r20240201&mjsv=m202401300101&ptt=9&saldr=aa&abxe=1&cookie=ID%3Dda923ce1809fdb65%3AT%3D1707206552%3ART%3D1707222311%3AS%3DALNI_MaK2d3SPUVF4IJTxgRvNqlZhBffOw&gpic=UID%3D00000cfa5e8dcaef%3AT%3D1707206552%3ART%3D1707222311%3AS%3DALNI_MbTGMvXV3ObqK2p_zeWAx2rZgcV7w&eo_id_str=ID%3Dc11bec4f34fbef8f%3AT%3D1707206552%3ART%3D1707222311%3AS%3DAA-AfjZVxZpALXO5F2y5gGs4A3md&prev_fmts=0x0%2C1021x200%2C300x600%2C1021x280&nras=2&correlator=7237666580002&frm=20&pv=1&ga_vid=1424845412.1707206554&ga_sid=1707222313&ga_hid=2092292844&ga_fc=1&rplot=4&u_tz=420&u_his=1&u_h=1080&u_w=1920&u_ah=1040&u_aw=1920&u_cd=24&u_sd=1&dmc=8&adx=281&ady=11234&biw=1857&bih=966&scr_x=0&scr_y=7392&eid=44759876%2C44759927%2C44759837%2C44809530%2C95322434%2C31080836%2C95324155%2C95324160&oid=2&pvsid=1765846021818514&tmod=131698149&wsm=1&uas=0&nvt=1&ref=https%3A%2F%2Fwww.google.com%2F&fc=1920&brdim=0%2C0%2C0%2C0%2C1920%2C0%2C1920%2C1040%2C1872%2C966&vis=1&rsz=%7C%7CEebr%7C&abl=CS&pfx=0&fu=128&bc=31&bz=1.03&psd=W251bGwsbnVsbCxudWxsLDNd&ifi=3&uci=a!3&btvi=2&fsb=1&dtd=20500Explanation:

I know what is going on your mind. You are thinking that how MVC map parameter exactly with correct components. It is very simple. MVC has a Model Binder that does the following task to match parameter with control.

a. Go to View Page
b. Look for control name that match with parameter name.
c. Map that control to parameter with same name.

Model Binder Example

But here is a catch. You have to use the same name as your component name. If you look for Create.cshtml source page you will notice that the controls name are same as the parameter name. It doesn’t matter ordering of parameter but naming should be same.


 

Method 3. Retrieve Form Data Directly from the Model ClassReceive Form Data using StudentModel class

In previous method, Model Binder works great if you have a form with 3 or 5 controls but what if you have a form with 30+ controls. It is not practical to use a 30+ parameter to retrieve form data. Your Model class fixes these issues and makes this job very easier. How see the example.

You must import SaveFormData.Models to use StudentModel Object

  1. using System.Web.Mvc;
  2. using SaveFormData.Models;
  3.  
  4. namespace SaveFormData.Controllers
  5. {
  6. public class HomeController : Controller
  7. {
  8. // GET: Home
  9. public ActionResult Index()
  10. {
  11. return View();
  12. }
  13.  
  14. // GET: Home/Create
  15. public ActionResult Create()
  16. {
  17. return View();
  18. }
  19.  
  20. // POST: Home/Create
  21. [HttpPost]
  22. public ActionResult Create(StudentModel smodel)
  23. {
  24. try
  25. {
  26. if (ModelState.IsValid)
  27. {
  28. ViewData[“Name”] = smodel.Name;
  29. ViewData[“City”] = smodel.City;
  30. ViewData[“Address”] = smodel.Address;
  31.  
  32. return View(“Index”);
  33. }
  34. else
  35. {
  36. return View();
  37. }
  38. }
  39. catch
  40. {
  41. return View();
  42. }
  43. }
  44. }
  45. }

Explanation

In this example, you can receive data directly from your model class. ModelState.IsValid properties ensure that all the data filled in a control was in a correct format and validated.


 

Method 4. Retrieve Form Data using UpdateModel class

You must import SaveFormData.Models to use StudentModel Object

  1. using System.Web.Mvc;
  2. using SaveFormData.Models;
  3.  
  4. namespace SaveFormData.Controllers
  5. {
  6. public class HomeController : Controller
  7. {
  8. // GET: Home
  9. public ActionResult Index()
  10. {
  11. return View();
  12. }
  13.  
  14. // GET: Home/Create
  15. [HttpGet]
  16. [ActionName(“Create”)]
  17. public ActionResult Create_get()
  18. {
  19. return View();
  20. }
  21.  
  22. // POST: Home/Create
  23. [HttpPost]
  24. [ActionName(“Create”)]
  25. public ActionResult Create_post()
  26. {
  27. try
  28. {
  29. StudentModel smodel = new StudentModel();
  30. UpdateModel(smodel);
  31.  
  32. ViewData[“Name”] = smodel.Name;
  33. ViewData[“City”] = smodel.City;
  34. ViewData[“Address”] = smodel.Address;
  35.  
  36. return View(“Index”);
  37. }
  38. catch
  39. {
  40. return View();
  41. }
  42. }
  43. }
  44. }

Explanation:

The UpdateModel class binds control data to models property. But there is a catch. When you use UpdateModel class, there is no parameter in [HttpPost] Create() Method. As you know that there can not be two methods in a class with same name and same parameter types. As there are already a [HttpGet] Create() method without parameter, so you cannot declare [HttpPost] Create() method without parameter. So the solution is to change Create Method name as Create_Get() and Create_Post() or whatever you want to change. Then decorate both method with correct action name as follows:

  1. // GET: Home/Create
  2. [HttpGet]
  3. [ActionName(“Create”)]
  4. public ActionResult Create_get()
  5. {
  6. return View();
  7. }
  8.  
  9. // POST: Home/Create
  10. [HttpPost]
  11. [ActionName(“Create”)]
  12. public ActionResult Create_post()
  13. {
  14. ……..
  15. return View();
  16. }

SUMMARY

In this article, I have shown you 4 different ways to retrieve form value in controller class. It is very necessary to know how to collect form data in a class for each MVC Programmer or learner. Hope, your doubt would be cleared.

Prev Post

All Types Of Action Methods…

Next Post

Star Patterns Program in C

post-bars