ASP.NET Core Complete Tutorial (ShopNest)
Lesson 23 of 75 31% of course

Dependency Injection in ASP.NET Core — Complete Guide

1 · 5 min · 5/24/2026

Learn Dependency Injection in ASP.NET Core — Complete Guide in our free ASP.NET Core Complete Tutorial (ShopNest) series. Step-by-step explanations, examples, and interview tips on Toolliyo Academy.

Sign in to track progress and bookmarks.

Dependency Injection in ASP.NET Core — Complete Guide — ShopNest
Article 23 of 75 · Module 3: Dependency Injection & Middleware · ShopNest Payment Processing System
Target keyword: dependency injection asp.net core · Read time: ~30 min · .NET: 8 / 9 · Project: ShopNest Payment Processing System

Introduction

Dependency Injection (DI) is built into ASP.NET Core — the framework creates your controllers and injects services like payment gateways, repositories, and loggers. Think of a restaurant: customers order at the counter (controller); the kitchen (services) is staffed by the manager (IoC container), not hired by each customer.

After this article you will

  • Explain IoC container and service lifetimes
  • Register services with AddTransient, AddScoped, AddSingleton
  • Avoid captive dependency bugs
  • Use constructor injection and keyed services (.NET 8)
  • Build PaymentService with multiple dependencies and unit tests

Prerequisites

Concept deep-dive

Service lifetimes

LifetimeCreatedShopNest example
TransientEvery injectionEmail formatter, lightweight helpers
ScopedPer HTTP requestDbContext, PaymentService, UnitOfWork
SingletonOnce per appAppSettings cache, IMemoryCache wrapper
// Program.cs — Payment module registration
builder.Services.AddScoped<IPaymentGateway, RazorpayGateway>();
builder.Services.AddScoped<IOrderRepository, OrderRepository>();
builder.Services.AddScoped<IPaymentService, PaymentService>();

// Keyed services (.NET 8) — multiple gateways
builder.Services.AddKeyedScoped<IPaymentGateway, RazorpayGateway>("razorpay");
builder.Services.AddKeyedScoped<IPaymentGateway, StripeGateway>("stripe");

public class PaymentService : IPaymentService
{
    private readonly IOrderRepository _orders;
    private readonly IPaymentGateway _gateway;
    private readonly ILogger<PaymentService> _logger;

    public PaymentService(IOrderRepository orders, IPaymentGateway gateway,
        ILogger<PaymentService> logger)
    {
        _orders = orders;
        _gateway = gateway;
        _logger = logger;
    }
}

Captive dependency bug

❌ Injecting Scoped DbContext into a Singleton service — singleton lives forever but holds a dead DbContext. Fix: make the dependent Singleton use IServiceScopeFactory to create scopes, or change lifetimes.

Extension methods: group registration in services.AddShopNestPayments(config) for clean Program.cs.

Hands-on — ShopNest Payment Processing System

  1. Define IPaymentService, IPaymentGateway, IOrderRepository.
  2. PaymentService.ProcessAsync: load order, call gateway, update status, log.
  3. CheckoutController injects IPaymentService only — not gateway directly.
  4. xUnit test: mock IOrderRepository and IPaymentGateway; verify ProcessAsync.
[HttpPost]
public async Task<IActionResult> Pay(int orderId)
{
    var result = await _payments.ProcessAsync(orderId, User);
    return result.Success ? RedirectToAction("Receipt", new { orderId })
                          : View("PaymentFailed", result);
}

Common errors & best practices

  • Registering DbContext as Singleton — always Scoped.
  • Service locator anti-pattern — avoid HttpContext.RequestServices.GetService in business code.
  • Too many constructor parameters — split into facades or use MediatR for complex flows.

Interview questions

Q1: Transient vs Scoped vs Singleton?
A: Transient = new each time; Scoped = one per request; Singleton = one for app lifetime.

Q2: Captive dependency?
A: Long-lived service holding short-lived dependency — causes stale DB connections and bugs.

Q3: Constructor vs property injection?
A: Constructor is standard — required dependencies explicit and immutable.

Q4: What is IoC?
A: Inversion of Control — framework creates objects and wires dependencies instead of new everywhere.

Summary

  • DI is first-class in ASP.NET Core via built-in IoC container
  • Scoped services match HTTP request + DbContext lifetime
  • PaymentService demo shows constructor injection at scale
  • Keyed services support multiple payment providers

Previous: EF Core with SQL Server — Advanced Features
Next: Middleware in ASP.NET Core

FAQ

Do I need Autofac?

Built-in DI suffices for most ShopNest apps; Autofac for advanced registration scenarios.

Can I inject IConfiguration directly?

Yes, but prefer IOptions<T> for typed settings (Article 25).

Test your knowledge

Quizzes linked to this course—pass to earn certificates.

Browse all quizzes
ASP.NET Core Complete Tutorial (ShopNest)

On this page

Introduction After this article you will Prerequisites Concept deep-dive Service lifetimes Hands-on — ShopNest Payment Processing System Common errors &amp; best practices Interview questions Summary FAQ Do I need Autofac? Can I inject IConfiguration directly?
Module 1: Foundations
What is ASP.NET Core? Complete Guide Setting Up ASP.NET Core Development Environment ASP.NET Core Project Structure Explained MVC Architecture in ASP.NET Core — Complete Guide Controllers and Actions in ASP.NET Core Routing in ASP.NET Core — Conventional and Attribute Routing Views and Razor Syntax in ASP.NET Core Layouts, Partial Views and View Components Models and ViewModels in ASP.NET Core Forms, Model Binding and Validation in ASP.NET Core Tag Helpers in ASP.NET Core — Complete Guide Static Files, Bundling and Minification in ASP.NET Core
Module 2: Entity Framework Core
Entity Framework Core — Introduction and Setup EF Core Code First — Models, Migrations, Database EF Core CRUD Operations — Create, Read, Update, Delete EF Core LINQ Queries — Beginner to Advanced EF Core Relationships — One-to-One, One-to-Many, Many-to-Many EF Core Fluent API — Advanced Configuration EF Core Repository Pattern and Unit of Work EF Core Performance Optimization Database First Approach with EF Core (Scaffold) EF Core with SQL Server — Advanced Features
Module 3: Dependency Injection & Middleware
Dependency Injection in ASP.NET Core — Complete Guide Middleware in ASP.NET Core — Complete Guide Configuration in ASP.NET Core — appsettings, Environment Variables, Secrets Filters in ASP.NET Core — Action, Authorization, Exception, Resource, Result Logging in ASP.NET Core — ILogger, Serilog, NLog Error Handling and Exception Management in ASP.NET Core
Module 4: Authentication & Security
ASP.NET Core Identity — Complete Setup Guide Authentication in ASP.NET Core — Cookie and JWT Authorization in ASP.NET Core — Roles, Policies, Claims JWT Authentication with Refresh Tokens — Complete Implementation OAuth2 and External Login (Google, Facebook, Microsoft) Data Protection and Encryption in ASP.NET Core HTTPS, SSL Certificates and Security Best Practices
Module 5: Web API
Building REST APIs with ASP.NET Core — Complete Guide API Versioning in ASP.NET Core Swagger / OpenAPI Documentation in ASP.NET Core Input Validation in Web APIs — FluentValidation and Data Annotations Pagination, Filtering and Sorting in ASP.NET Core APIs HTTP Client and Consuming External APIs in ASP.NET Core Minimal APIs in ASP.NET Core .NET 8 SignalR — Real-Time Web Applications
Module 6: Advanced Architecture
Clean Architecture in ASP.NET Core CQRS Pattern with MediatR in ASP.NET Core Repository Pattern — Deep Dive with Generic Repository Background Services and Hosted Services in ASP.NET Core Caching in ASP.NET Core — In-Memory, Distributed, Redis Health Checks in ASP.NET Core AutoMapper in ASP.NET Core Microservices with ASP.NET Core — Introduction Message Queues with RabbitMQ / Azure Service Bus in ASP.NET Core gRPC with ASP.NET Core
Module 7: Testing
Unit Testing ASP.NET Core with xUnit and Moq Integration Testing in ASP.NET Core Testing EF Core — In-Memory vs SQLite Performance Testing and Load Testing ASP.NET Core APIs Test-Driven Development (TDD) in ASP.NET Core
Module 8: Deployment & DevOps
Deploying ASP.NET Core to IIS on Windows Server Docker and Containerization for ASP.NET Core Deploying ASP.NET Core to Azure App Service CI/CD with GitHub Actions for ASP.NET Core Azure SQL Database with ASP.NET Core Environment Configuration and Secrets Management
Module 9: Real-World Projects
Build a Complete Blog Website with ASP.NET Core MVC Build an E-Commerce Product Catalog API (ASP.NET Core Web API) Build a Student Management System (Complete CRUD App) Build a Job Portal (Full Stack ASP.NET Core) Build a REST API with Clean Architecture — Complete Guide Build a Real-Time Chat App with SignalR and ASP.NET Core
Module 10: Advanced Topics
Blazor WebAssembly and Blazor Server — Complete Guide gRPC, GraphQL and Alternative API Styles in ASP.NET Core Rate Limiting and API Throttling in ASP.NET Core .NET 8 Output Caching in ASP.NET Core .NET 8 ASP.NET Core .NET 9 New Features — Complete Guide