Full Stack Web Development Internship Program
- 29k Enrolled Learners
- Weekend/Weekday
- Live Class
In the Web Development field, Model-View-Controller is one of the most talked-about design patterns in the web programming world today. MVC Architecture was initially included in the two major web development frameworks – Struts and Ruby on Rails. In this article, let’s explore a little bit about MVC Architecture in Java.
The topics that will be covered in this article are as follows:
Before we actually get into the technicalities of MVC Architecture, there are certain concepts that you need to know.
Model designs based on MVC architecture follow the MVC design pattern and they separate the application logic from the user interface when designing software. As the name implies MVC pattern has three layers, which are:
In Java Programming context, the Model consists of simple Java classes, the View displays the data and the Controller consists of servlets. This separation results in user requests being processed as follows:
Separating a software application into these three distinct components is a good idea for a number of reasons. Let’s take a look at what those are.
MVC architecture offers a lot of advantages for a programmer when developing applications, which include:
Now you know why the MVC is the most popular design patterns in the web programming world. But, if you are still struggling to get your head around the concept of MVC, don’t worry. We will dig deep into each of these layers and learn their purpose with the help of an example program.
To implement a web application based on MVC design pattern, we will create
Now, let’s explore these layers one by one.
In the MVC design pattern, the model is the data layer which defines the business logic of the system and also represents the state of the application. The model objects retrieve and store the state of the model in a database. Through this layer, we apply rules to data, which eventually represents the concepts our application manages. Now, let’s create a model using Course Class.
package MyPackage; public class Course { private String CourseName; private String CourseId; private String CourseCategory; public String getId() { return CourseId; } public void setId(String id) { this.CourseId = id; } public String getName() { return CourseName; } public void setName(String name) { this.CourseName = name; } public String getCategory() { return CourseCategory; } public void setCategory(String category) { this.CourseCategory = category; } }
The code is easy to understand and is self-explanatory. It consists of functions to get/set course details.
This layer of the MVC design pattern represents the output of the application or the user interface. It displays the data fetched from the model layer by the controller and presents the data to the user whenever asked for. It receives all the information it needs from the controller and it doesn’t need to interact with the business layer directly. Let’s create a view using CourseView Class.
package MyPackage; public class CourseView { public void printCourseDetails(String CourseName, String CourseId, String CourseCategory){ System.out.println("Course Details: "); System.out.println("Name: " + CourseName); System.out.println("Course ID: " + CourseId); System.out.println("Course Category: " + CourseCategory); } }
This code is simply to print the values to the console. Next up we have the controller of the web application.
The Controller is like an interface between Model and View. It receives the user requests from the view layer and processes them, including the necessary validations. The requests are then sent to model for data processing. Once they are processed, the data is again sent back to the controller and then displayed on the view. Let’s create CourseContoller Class which acts as a controller.
package MyPackage; public class CourseController { private Course model; private CourseView view; public CourseController(Course model, CourseView view){ this.model = model; this.view = view; } public void setCourseName(String name){ model.setName(name); } public String getCourseName(){ return model.getName(); } public void setCourseId(String id){ model.setId(id); } public String getCourseId(){ return model.getId(); } public void setCourseCategory(String category){ model.setCategory(category); } public String getCourseCategory(){ return model.getCategory(); } public void updateView(){ view.printCourseDetails(model.getName(), model.getId(), model.getCategory()); } }
A cursory glance at the code will tell us that this controller class is just responsible for calling the model to get/set the data and updating the view based on that. Now let’s have a look at how all of these are tied together.
Let’s call this class “MVCPatternDemo.java”. Check out the code below.
package MyPackage; public class MVCPatternDemo { public static void main(String[] args) { //fetch student record based on his roll no from the database Course model = retriveCourseFromDatabase(); //Create a view : to write course details on console CourseView view = new CourseView(); CourseController controller = new CourseController(model, view); controller.updateView(); //update model data controller.setCourseName("Python"); System.out.println("nAfter updating, Course Details are as follows"); controller.updateView(); } private static Course retriveCourseFromDatabase(){ Course course = new Course(); course.setName("Java"); course.setId("01"); course.setCategory("Programming"); return course; } }
The above class fetches the course data from the function using which user enters the set of values. It then pushes those values into the Course model. Then, it initializes the view we had created earlier in the article. Further, it also invokes the CourseController class and binds it to the Course class and the CourseView class. The updateView() method which is a part of the controller then updates the course details on the console. Check out the output below.
Output
Course Details: Name: Java Course ID: 01 Course Category: Programming After updating, Course Details are as follows Course Details: Name: Python Course ID: 01 Course Category: Programming
The MVC Architecture provides an altogether new level of modularity to your code which makes it a lot more readable and maintainable. This brings us to the end of this article. Hope you are clear with all that has been shared with you.
If you’re just beginning, then watch at this Java Tutorial to Understand the Fundamental Java Concepts.
Make sure you practice as much as possible and revert your experience.
Check out the Java Course Online by Edureka, a trusted online learning company with a network of more than 250,000 satisfied learners spread across the globe. We are here to help you with every step on your journey, we come up with a curriculum which is designed for students and professionals who want to be a Java Developer.
Got a question for us? Please mention it in the comments section of this ‘MVC Architecture in Java’ article and we will get back to you as soon as possible.
Course Name | Date | Details |
---|---|---|
Java Course Online | Class Starts on 5th October,2024 5th October SAT&SUN (Weekend Batch) | View Details |
edureka.co