Tutorials ASP.NET Core Tutorial

ASP.NET Core Project Structure — Complete Guide

ASP.NET Core Project Structure — Complete Guide: free step-by-step lesson with examples, common mistakes, and interview tips — part of ASP.NET Core Tutorial on Toolliyo Academy.

On this page

ASP.NET Core Tutorial (ShopNest) · Lesson 7 of 100

ASP.NET Core Project Structure

BeginnerIntermediateAdvancedProfessional

Beginner · 1 — Foundations · ~12 min read · Module 1: Introduction & Setup

Introduction

This lesson is part of the beginner section. We explain ASP.NET Core Project Structure slowly, with examples you can copy and run. If something is unclear, read it twice — that is how everyone learns. A new MVC project includes Program.cs (startup), appsettings.json (config), Controllers/, Models/, Views/, wwwroot/ (CSS/JS/images), Properties/launchSettings.json, and a .csproj file. As apps grow, teams add Services/ and Repositories/ folders. When a teammate says “fix the checkout view,” you need to know Views/ vs Controllers/ vs Services/ without guessing. Enterprise teams organize code so five developers do not edit the same file.

ASP.NET Core Project Structure is setup knowledge. Without it, nothing else in ASP.NET Core will run. Spend time here until dotnet run works without errors.

When will you use this?

You need this before writing any ASP.NET Core code — same as installing Visual Studio before opening a project.

  • Every .NET backend job expects you to run dotnet new and dotnet run on day one.
  • Interviewers often ask you to explain Program.cs and what Kestrel does.

Real-world: Naukri-style job portal API

The Recruitment team building Naukri-style job portal API uses ASP.NET Core Project Structure to know which file to edit when fixing a bug in the checkout API. job seekers and recruiters never see the C# code — they just get a fast, reliable job search and application endpoints.

Production-style code

ShopNest.Web/
  Program.cs           → startup, DI, middleware
  appsettings.json     → connection strings, settings
  Controllers/         → HTTP handlers (thin)
  Models/              → data classes, view models
  Views/               → Razor HTML
  Services/            → business rules (you add this)
  wwwroot/             → static files only
  ShopNest.Web.csproj  → packages, net8.0

What happens in production: In Naukri-style job portal API, getting ASP.NET Core Project Structure right means job seekers and recruiters trust the job search and application endpoints every day.

Lesson example (start here)

Copy this smaller example first. Once it works, compare it with the real-world code above.

ShopNest.Web/
  Program.cs           → startup, DI, middleware
  appsettings.json     → connection strings, settings
  Controllers/         → HTTP handlers (thin)
  Models/              → data classes, view models
  Views/               → Razor HTML
  Services/            → business rules (you add this)
  wwwroot/             → static files only
  ShopNest.Web.csproj  → packages, net8.0

Line-by-line walkthrough

CodeWhat it means
ShopNest.Web/Part of the ASP.NET Core Project Structure example — read it together with the lines before and after.
Program.cs → startup, DI, middlewarePart of the ASP.NET Core Project Structure example — read it together with the lines before and after.
appsettings.json → connection strings, settingsPart of the ASP.NET Core Project Structure example — read it together with the lines before and after.
Controllers/ → HTTP handlers (thin)Part of the ASP.NET Core Project Structure example — read it together with the lines before and after.
Models/ → data classes, view modelsPart of the ASP.NET Core Project Structure example — read it together with the lines before and after.
Views/ → Razor HTMLPart of the ASP.NET Core Project Structure example — read it together with the lines before and after.
Services/ → business rules (you add this)Part of the ASP.NET Core Project Structure example — read it together with the lines before and after.
wwwroot/ → static files onlyPart of the ASP.NET Core Project Structure example — read it together with the lines before and after.
ShopNest.Web.csproj → packages, net8.0Part of the ASP.NET Core Project Structure example — read it together with the lines before and after.

How it works (big picture)

  • Program.cs replaced Startup.cs in modern .NET.
  • wwwroot is the only folder browsers access for static files by default.
  • Never put secrets in appsettings committed to Git — use User Secrets locally.

Do this on your computer

  1. Run dotnet new mvc -n ShopNest.Web
  2. Open each folder and read one file inside.
  3. Change Views/Home/Index.cshtml heading and refresh the browser.
  4. Create an empty Services/ folder — you will use it in lesson 21 (DI).
  5. Read the real-world section and name which part of the app uses this topic.
  6. Run the example locally with dotnet run and confirm the same behavior.
  7. Change one value in the example (route, text, or connection string) and predict what will happen before you save.

Experiments — try changing this

  • Change a string or route in the example and save — watch the browser or Swagger response update.
  • Break the code on purpose (remove a semicolon), read the error message, then fix it.

Remember

Program.cs boots the app. Controllers + Views = MVC. wwwroot holds static assets; Services/ holds business logic.

Common questions

Where do I add new features?

Controller + View per feature, plus a Service class for rules.

What is launchSettings.json?

Dev-only URLs and environment when you press F5 in Visual Studio.

ASP.NET Core Tutorial
Course syllabus
Start Here ASP.NET Core Complete Beginner's Guide
Module 1: Introduction & Setup Introduction to ASP.NET Core — Complete Guide ASP.NET Core Ecosystem — Complete Guide ASP.NET Core Architecture — Complete Guide Installing .NET SDK — Complete Guide Installing Visual Studio — Complete Guide VS Code Setup — Complete Guide ASP.NET Core Project Structure — Complete Guide The .csproj File — Complete Guide Program.cs Explained — Complete Guide Launch Settings and Configuration — Complete Guide
Module 2: MVC Fundamentals Controllers and Actions — Complete Guide Routing — Complete Guide Models and ViewModels — Complete Guide Razor Views — Complete Guide Layouts and Partial Views — Complete Guide Tag Helpers — Complete Guide Model Binding — Complete Guide Data Annotations Validation — Complete Guide Static Files Middleware — Complete Guide MVC Architecture — Complete Guide
Module 3: Services & Pipeline Dependency Injection — Complete Guide Middleware Pipeline — Complete Guide appsettings.json — Complete Guide Logging — Complete Guide Exception Handling — Complete Guide Filters — Complete Guide Action Results — Complete Guide JSON APIs in MVC — Complete Guide HttpClient — Complete Guide Enterprise Folder Structure — Complete Guide
Module 4: Entity Framework Core Introduction to EF Core — Complete Guide DbContext — Complete Guide Code First Migrations — Complete Guide CRUD with EF Core — Complete Guide LINQ Queries — Complete Guide Relationships in EF Core — Complete Guide Fluent API — Complete Guide Repository Pattern — Complete Guide Unit of Work — Complete Guide EF Core Performance — Complete Guide
Module 5: Web API & Security Building REST APIs — Complete Guide Swagger and OpenAPI — Complete Guide API Versioning — Complete Guide Authentication Basics — Complete Guide ASP.NET Core Identity — Complete Guide JWT Authentication — Complete Guide Authorization Policies — Complete Guide CORS — Complete Guide HTTPS and Data Protection — Complete Guide Input Validation — Complete Guide
Module 6: Advanced Features Minimal APIs — Complete Guide Background Services — Complete Guide Caching — Complete Guide SignalR Basics — Complete Guide File Upload — Complete Guide Health Checks — Complete Guide Rate Limiting — Complete Guide Clean Architecture Intro — Complete Guide CQRS with MediatR — Complete Guide AutoMapper — Complete Guide
Module 7: Testing & Quality Unit Testing with xUnit — Complete Guide Integration Testing — Complete Guide Mocking with Moq — Complete Guide API Testing with Postman — Complete Guide Test-Driven Development — Complete Guide Load Testing Basics — Complete Guide Debugging Techniques — Complete Guide Structured Logging — Complete Guide Error Handling Patterns — Complete Guide Code Quality Tools — Complete Guide
Module 8: Deploy & Cloud Publishing to IIS — Complete Guide Docker for ASP.NET Core — Complete Guide Azure App Service — Complete Guide Azure SQL Database — Complete Guide Secrets Management — Complete Guide GitHub Actions CI/CD — Complete Guide Output Caching — Complete Guide Response Compression — Complete Guide .NET 8 and .NET 9 Features — Complete Guide Production Checklist — Complete Guide
Module 9: Portfolio Projects Blog Application Project — ShopNest Project Student Portal Project — ShopNest Project Job Portal API Project — ShopNest Project E-Commerce API Project — ShopNest Project Inventory System Project — ShopNest Project Task Manager API Project — ShopNest Project Real-Time Chat Project — ShopNest Project Hospital Appointment Project — ShopNest Project Banking Dashboard API Project — ShopNest Project Multi-Tenant SaaS Project — ShopNest Project
Module 10: Professional Topics Microservices Introduction — ShopNest Project Message Queues — ShopNest Project gRPC Basics — ShopNest Project Blazor Server Intro — ShopNest Project GraphQL Basics — ShopNest Project Enterprise API Design — ShopNest Project Performance Tuning — ShopNest Project Security Hardening — ShopNest Project Full-Stack Architecture — ShopNest Project ASP.NET Core Career Roadmap — ShopNest Project
Toolliyo Assistant
Ask about tutorials, ebooks, training, pricing, mentor services, and support. I use public site content only—not admin or internal tools.

care@toolliyo.com

Need callback? Share your details