DEV Community

Abhay Singh Kathayat
Abhay Singh Kathayat

Posted on

Understanding MVC Architecture and How to Implement It in PHP

What is MVC Architecture, and How Would You Implement It in PHP?

MVC (Model-View-Controller) is a widely-used architectural pattern in software development that separates an application into three interconnected components:

  • Model: Represents the data and business logic of the application.
  • View: Represents the UI (user interface) that displays the data to the user.
  • Controller: Acts as an intermediary between the Model and the View, handling user input, updating the Model, and rendering the View.

The main goal of the MVC pattern is to separate concerns, making the application easier to maintain, scale, and test. It allows developers to work on different parts of the application independently, improving productivity and code organization.

In PHP, the MVC architecture can be implemented by structuring your application in a way that separates the data, logic, and presentation layers. Let’s explore how you can implement MVC in a PHP application.


1. Overview of MVC Components

Model

The Model is responsible for the business logic and data manipulation. It interacts with the database and holds the data that the application processes. The Model also contains the logic for validating and managing that data.

  • Responsibilities:
    • Fetch data from the database.
    • Save data to the database.
    • Perform business logic and validation.

View

The View is responsible for displaying the data to the user. It represents the UI of the application and is often made up of HTML, CSS, and JavaScript. The View receives data from the Controller and renders it to the user.

  • Responsibilities:
    • Present the data received from the Controller.
    • Display the UI elements.
    • Provide interactive features, but without containing logic for processing data.

Controller

The Controller acts as a mediator between the Model and the View. It takes user input, updates the Model based on that input, and then updates the View with the data that the Model has processed.

  • Responsibilities:
    • Handle user requests (e.g., form submissions, button clicks).
    • Update the Model based on user actions.
    • Choose which View to display to the user.
    • Control the flow of the application.

2. Implementing MVC in PHP

Let’s implement a basic MVC architecture in PHP. We’ll break the application into three folders:

  • app/Model/: Contains the Model classes.
  • app/View/: Contains the View files (e.g., HTML templates).
  • app/Controller/: Contains the Controller classes.

Additionally, we’ll need an entry point (usually index.php) that initializes the application and routes the requests.

Step 1: Define the Model

The Model class is responsible for handling data operations, such as fetching records from the database. Let’s assume we have a simple "User" model.

app/Model/User.php:

<?php

namespace App\Model;

class User
{
    private $db;

    public function __construct($db)
    {
        $this->db = $db;
    }

    // Fetch all users
    public function getAllUsers()
    {
        $query = "SELECT * FROM users";
        $result = $this->db->query($query);
        return $result->fetchAll(PDO::FETCH_ASSOC);
    }

    // Add a new user
    public function addUser($name, $email)
    {
        $query = "INSERT INTO users (name, email) VALUES (:name, :email)";
        $stmt = $this->db->prepare($query);
        $stmt->bindParam(':name', $name);
        $stmt->bindParam(':email', $email);
        return $stmt->execute();
    }
}
Enter fullscreen mode Exit fullscreen mode

In this example, we have the User model that handles fetching all users from the database and adding a new user.

Step 2: Define the View

The View contains the HTML that renders the data for the user. Let’s assume we have a simple page that lists all users.

app/View/UserListView.php:

<?php

namespace App\View;

class UserListView
{
    public function render($users)
    {
        echo "<h1>User List</h1>";
        echo "<ul>";
        foreach ($users as $user) {
            echo "<li>{$user['name']} - {$user['email']}</li>";
        }
        echo "</ul>";
    }
}
Enter fullscreen mode Exit fullscreen mode

In this example, the UserListView class renders a list of users. It receives the users' data from the controller and displays them in an HTML list.

Step 3: Define the Controller

The Controller receives input from the user, processes it (e.g., fetching data from the Model), and then renders the appropriate View.

app/Controller/UserController.php:

<?php

namespace App\Controller;

use App\Model\User;
use App\View\UserListView;

class UserController
{
    private $userModel;
    private $userView;

    public function __construct(User $userModel, UserListView $userView)
    {
        $this->userModel = $userModel;
        $this->userView = $userView;
    }

    // Fetch users and pass data to the view
    public function listUsers()
    {
        $users = $this->userModel->getAllUsers();
        $this->userView->render($users);
    }
}
Enter fullscreen mode Exit fullscreen mode

The UserController class is responsible for fetching the list of users from the User model and passing that data to the UserListView to be rendered.

Step 4: Set Up Routing and Application Flow

The routing logic determines how user requests are handled and which controller method is invoked.

public/index.php (Entry Point):

<?php

require_once '../vendor/autoload.php';

use App\Controller\UserController;
use App\Model\User;
use App\View\UserListView;

// Database connection (assuming PDO)
$db = new PDO('mysql:host=localhost;dbname=your_database', 'root', '');

// Create instances of the Model, View, and Controller
$userModel = new User($db);
$userView = new UserListView();
$userController = new UserController($userModel, $userView);

// Simple Routing (for example purposes)
if ($_SERVER['REQUEST_URI'] === '/users') {
    $userController->listUsers();
}
Enter fullscreen mode Exit fullscreen mode

In this index.php file, we:

  1. Set up a PDO database connection.
  2. Create instances of the User model, UserListView, and UserController.
  3. Route requests to the appropriate controller method (listUsers) based on the URL.

Step 5: Autoloading

Make sure your classes are autoloaded using Composer. You can define your namespace and folder structure in the composer.json file like this:

{
    "autoload": {
        "psr-4": {
            "App\\": "app/"
        }
    }
}
Enter fullscreen mode Exit fullscreen mode

Run composer dump-autoload to generate the autoloader.


3. How Does MVC Help in PHP Development?

Implementing MVC in PHP offers several advantages, such as:

Separation of Concerns

MVC promotes the separation of concerns, which means the data (Model), the UI (View), and the logic (Controller) are separated into different components. This makes the application more modular and easier to maintain.

Maintainability

Since the business logic is separated from the UI, it's easier to make changes to one part of the application without affecting the others. For example, you can update the UI (View) without modifying the business logic (Model).

Testability

With MVC, it becomes easier to write unit tests. You can test the Model independently of the View and Controller, which makes testing much more straightforward.

Reusability

The components of an MVC application are reusable. For example, the same Model can be used by different Views (like listing users in a table or a chart), making your code more reusable and flexible.


4. Conclusion

MVC is a highly effective architectural pattern for structuring PHP applications. It helps to separate concerns, making the code easier to maintain and test. By implementing the MVC pattern in PHP, you can build scalable, modular applications with a clean, organized structure. Using tools like Composer for autoloading and managing dependencies, you can simplify the development process even further.

By following the MVC pattern, you will ensure that your PHP applications are well-structured, efficient, and easy to maintain.


Top comments (0)