DEV Community

Cover image for Part 11: Introduction to Web Development with ASP.NET Core
Adrián Bailador
Adrián Bailador

Posted on

6 1 1 1

Part 11: Introduction to Web Development with ASP.NET Core

Part 11 and last part of the newbie guide. In this last article, we will talk about Web development as it is a vital skill in today's technological landscape, allowing you to create dynamic and easy to use applications, accessible from any browser. In this article, we will explore the fundamentals of developing web applications using ASP.NET Core, taking advantage of the features of the latest version of .NET 8 and C# 12.

1. What is ASP.NET Core?

ASP.NET Core is a modern, open-source, cross-platform framework for web application building. It supports a variety of development styles, including:

  • Razor Pages: For page-focused scenarios.
  • Model-View-Controller (MVC): Ideal for applications with complex UI logic.
  • Minimal APIs: A lightweight approach to building APIs.
  • Blazor: For building interactive web UIs with C# instead of JavaScript.

2. Creating a Simple Web Application

In this section, we’ll create a minimal web application using the latest ASP.NET Core features.

Step 1: Setting Up the Project

  1. Open a terminal or your preferred IDE (e.g., Visual Studio or VS Code).
  2. Run the following command to create a new ASP.NET Core project:
 dotnet new web -n MyFirstWebApp
Enter fullscreen mode Exit fullscreen mode
  1. Navigate to the project folder:
cd MyFirstWebApp
Enter fullscreen mode Exit fullscreen mode
  1. Run the application:
 dotnet run
Enter fullscreen mode Exit fullscreen mode

Visit http://localhost:5000 in your browser to see your first ASP.NET Core application running.

Step 2: Adding an Endpoint with Minimal API

Minimal APIs are a streamlined way to define endpoints in ASP.NET Core. Open the Program.cs file and add the following code:

var builder = WebApplication.CreateBuilder(args);
var app = builder.Build();

app.MapGet("/", () => "Welcome to my first ASP.NET Core application!");

app.Run();
Enter fullscreen mode Exit fullscreen mode

Rerun the application and visit the root URL to see the message displayed.


3. Understanding MVC (Model-View-Controller)

MVC is a design pattern that separates an application into three interconnected components:

  1. Model: Represents the application’s data and business logic.
  2. View: Handles the presentation layer (HTML, CSS, etc.).
  3. Controller: Handles user input and updates the model and view accordingly.

Let’s implement a simple MVC example:

Step 1: Adding MVC to the Project

  1. Update the Program.cs file to include MVC support:
var builder = WebApplication.CreateBuilder(args);
builder.Services.AddControllersWithViews();

var app = builder.Build();

app.MapControllerRoute(
    name: "default",
    pattern: "{controller=Home}/{action=Index}/{id?}");

app.Run();
Enter fullscreen mode Exit fullscreen mode

Step 2: Creating a Controller

Create a folder named Controllers in the project root and add a new file HomeController.cs with the following code:

using Microsoft.AspNetCore.Mvc;

public class HomeController : Controller
{
    public IActionResult Index()
    {
        return View();
    }
}
Enter fullscreen mode Exit fullscreen mode

Step 3: Creating a View

  1. Create a folder named Views in the project root.
  2. Inside Views, create another folder named Home.
  3. Add a new file Index.cshtml in the Home folder with the following content:
<!DOCTYPE html>
<html>
<head>
    <title>Welcome</title>
</head>
<body>
    <h1>Welcome to ASP.NET Core MVC!</h1>
</body>
</html>
Enter fullscreen mode Exit fullscreen mode

Rerun the application and visit the root URL to see your MVC-based page.


4. Building a Simple MVC Application: Student Management

Let’s extend our knowledge by creating a simple MVC application that manages a list of students.

Step 1: Define the Model

Add a new folder named Models and create a file Student.cs:

public class Student
{
    public int Id { get; set; }
    public string Name { get; set; }
    public int Age { get; set; }
}
Enter fullscreen mode Exit fullscreen mode

Step 2: Create the Controller

Add a new controller StudentController.cs in the Controllers folder:

using Microsoft.AspNetCore.Mvc;
using System.Collections.Generic;

public class StudentController : Controller
{
    private static List<Student> students = new List<Student>
    {
        new Student { Id = 1, Name = "Alice", Age = 20 },
        new Student { Id = 2, Name = "Bob", Age = 22 }
    };

    public IActionResult Index()
    {
        return View(students);
    }

    [HttpGet]
    public IActionResult Create()
    {
        return View();
    }

    [HttpPost]
    public IActionResult Create(Student student)
    {
        if (ModelState.IsValid)
        {
            student.Id = students.Count + 1;
            students.Add(student);
            return RedirectToAction("Index");
        }
        return View(student);
    }
}
Enter fullscreen mode Exit fullscreen mode

Step 3: Create the Views

  1. In the Views folder, create a new folder named Student.
  2. Add a file Index.cshtml:
@model List<Student>

<!DOCTYPE html>
<html>
<head>
    <title>Students</title>
</head>
<body>
    <h1>Student List</h1>
    <table>
        <thead>
            <tr>
                <th>ID</th>
                <th>Name</th>
                <th>Age</th>
            </tr>
        </thead>
        <tbody>
            @foreach (var student in Model)
            {
                <tr>
                    <td>@student.Id</td>
                    <td>@student.Name</td>
                    <td>@student.Age</td>
                </tr>
            }
        </tbody>
    </table>
    <a href="/Student/Create">Add New Student</a>
</body>
</html>
Enter fullscreen mode Exit fullscreen mode
  1. Add a file Create.cshtml:
@model Student

<!DOCTYPE html>
<html>
<head>
    <title>Add Student</title>
</head>
<body>
    <h1>Add New Student</h1>
    <form asp-action="Create" method="post">
        <label for="Name">Name:</label>
        <input type="text" id="Name" name="Name" required />
        <br />
        <label for="Age">Age:</label>
        <input type="number" id="Age" name="Age" required />
        <br />
        <button type="submit">Add Student</button>
    </form>
</body>
</html>
Enter fullscreen mode Exit fullscreen mode

Rerun the application and navigate to /Student to manage students.

5. Best Practices

General Tips

  1. Use Dependency Injection to manage services and dependencies effectively.
  2. Validate user input at both client and server levels.
  3. Secure sensitive data with environment variables and the UserSecrets tool.
  4. Use logging frameworks like Serilog for monitoring and debugging.

Keeping Code Clean

  • Use DTOs (Data Transfer Objects) to separate data models from view models.
  • Follow naming conventions and folder structures for maintainability.

Final Thoughts

With ASP.NET Core, you have a powerful framework at your disposal to create modern, scalable web applications. This final chapter of our guide introduces you to web development and provides a foundation to explore more advanced topics like API creation, authentication, and database integration. Happy coding and Happy New Year!

Image of Timescale

Timescale – the developer's data platform for modern apps, built on PostgreSQL

Timescale Cloud is PostgreSQL optimized for speed, scale, and performance. Over 3 million IoT, AI, crypto, and dev tool apps are powered by Timescale. Try it free today! No credit card required.

Try free

Top comments (0)

A Workflow Copilot. Tailored to You.

Pieces.app image

Our desktop app, with its intelligent copilot, streamlines coding by generating snippets, extracting code from screenshots, and accelerating problem-solving.

Read the docs

👋 Kindness is contagious

Engage with a sea of insights in this enlightening article, highly esteemed within the encouraging DEV Community. Programmers of every skill level are invited to participate and enrich our shared knowledge.

A simple "thank you" can uplift someone's spirits. Express your appreciation in the comments section!

On DEV, sharing knowledge smooths our journey and strengthens our community bonds. Found this useful? A brief thank you to the author can mean a lot.

Okay