Skip to main content

What is Dependency Injection in ASP.NET Core MVC

  What is Dependency Injection (DI)?

Dependency Injection (DI) is a design pattern used to manage dependencies between different parts of your application.

A dependency is simply an object that another object relies on to do its job.

DI is a way to provide those dependencies from the outside, rather than letting a class create them internally.

🤔 Why Use DI?

Without DI:

public class HomeController

{

    private TimeService _timeService = new TimeService(); // tightly coupled


    public string GetTime()

    {

        return _timeService.GetCurrentTime();

    }

}

❌ The controller is directly creating the dependency.


❌ Hard to test (can’t easily replace TimeService with a mock).


❌ If the implementation changes, you have to change the controller code.



public class HomeController

{

    private readonly ITimeService _timeService;


    public HomeController(ITimeService timeService)

    {

        _timeService = timeService;

    }

}

✅ TimeService is injected from outside.


✅ Easily replaceable with a mock or a new implementation.


✅ Controller is only dependent on interface, not implementation.


✅ Promotes loose coupling and separation of concerns.


🧪 Real-World Example

Imagine you're ordering pizza at a restaurant:


You (Controller) want a pizza.


The Pizza (Dependency) is made by a chef.


Without DI: You walk into the kitchen and make it yourself. 🍕❌


With DI: You just request the pizza, and someone delivers it to you, already made. 🍕✅


That someone is the Dependency Injection Container.


⚙️ How It Works in ASP.NET Core

ASP.NET Core has built-in support for DI, using a central Service Container.


Step 1:

Register Services in Program.cs


builder.Services.AddScoped<ITimeService, TimeService>();

Inject Services in constructors


public HomeController(ITimeService timeService)

Framework Resolves Dependencies automatically when creating controllers, middleware, etc.


✅ Scenario:

We want to create a service that returns the current time and display it in a controller.


📁 Step-by-step Code Example

1. Create the Interface


// Services/ITimeService.cs

public interface ITimeService

{

    string GetCurrentTime();

}

2. Create the Service Implementation


// Services/TimeService.cs

public class TimeService : ITimeService

{

    public string GetCurrentTime()

    {

        return DateTime.Now.ToString("hh:mm:ss tt");

    }

}

3. Register the Service in Program.cs

This tells ASP.NET Core to inject ITimeService wherever it's needed.



// Program.cs (ASP.NET Core 6 or later)


var builder = WebApplication.CreateBuilder(args);


// Register the service for DI (Scoped/Transient/Singleton based on need)

builder.Services.AddTransient<ITimeService, TimeService>();


builder.Services.AddControllersWithViews();


var app = builder.Build();


app.UseStaticFiles();

app.UseRouting();

app.MapDefaultControllerRoute();


app.Run();

4. Inject Service into Controller


// Controllers/HomeController.cs

using Microsoft.AspNetCore.Mvc;

using YourNamespace.Services; // Replace with actual namespace


public class HomeController : Controller

{

    private readonly ITimeService _timeService;


    // Constructor Injection

    public HomeController(ITimeService timeService)

    {

        _timeService = timeService;

    }


    public IActionResult Index()

    {

        ViewBag.CurrentTime = _timeService.GetCurrentTime();

        return View();

    }

}

5. Display Time in the View


@* Views/Home/Index.cshtml *@


<h2>Current Time from DI Service:</h2>

<p>@ViewBag.CurrentTime</p>

🎉 Output:

When you run the app and open the homepage, it will show:



Current Time from DI Service:

04:18:52 PM


Comments

Popular posts from this blog

Uncontrolled form input in React-JS

  Uncontrolled form input in React-JS? If we want to take input from users without any separate event handling then we can uncontrolled the data binding technique. The uncontrolled input is similar to the traditional HTML form inputs. The DOM itself handles the form data. Here, the HTML elements maintain their own state that will be updated when the input value changes. To write an uncontrolled component, you need to use a ref to get form values from the DOM. In other words, there is no need to write an event handler for every state update. You can use a ref to access the input field value of the form from the DOM. Example of Uncontrolled Form Input:- import React from "react" ; export class Info extends React . Component {     constructor ( props )     {         super ( props );         this . fun = this . fun . bind ( this ); //event method binding         this . input = React . createRef ();...

JSP Page design using Internal CSS

  JSP is used to design the user interface of an application, CSS is used to provide set of properties. Jsp provide proper page template to create user interface of dynamic web application. We can write CSS using three different ways 1)  inline CSS:-   we will write CSS tag under HTML elements <div style="width:200px; height:100px; background-color:green;"></div> 2)  Internal CSS:-  we will write CSS under <style> block. <style type="text/css"> #abc { width:200px;  height:100px;  background-color:green; } </style> <div id="abc"></div> 3) External CSS:-  we will write CSS to create a separate file and link it into HTML Web pages. create a separate file and named it style.css #abc { width:200px;  height:100px;  background-color:green; } go into Jsp page and link style.css <link href="style.css"  type="text/css" rel="stylesheet"   /> <div id="abc"> </div> Exam...

JDBC Database Connectivity using JSP and Servlet, Database connectivity on Java

JDBC Database Connectivity using JSP and Servlet, Database connectivity on Java JDBC:-   JDBC means Java database connectivity, it is used to connect from the front-end(application server) to the back-end(database server) in the case of Java web application. The database provides a set of tables to store records and JDBC will work similarly to the  bridge between the database table and application form. 1)  Class.forName("drivername")  // Manage Drive         Class.formName("com.mysql.jdbc.Driver");  // MYSQL      Class.forName ("oracle.jdbc.driver.OracleDriver"); //Oracle 2)  Manage Connection String     It establish connection from application server to database server, Java provide DriverManage class and getConnection that will return Connection object.    Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/databasename","username","password"); 3)  Manage Statement to...