Ad Code

✨🎆 Diwali Dhamaka Offer! 🎆✨

Get 20% OFF on All Courses at Shiva Concept Solution click

What is Middleware in ASP.NET Core MVC | Explain Middleware in depth

What is Middleware in ASP.NET Core MVC:

 

Middleware is a fundamental component in ASP.NET Core's request processing pipeline. Understanding it is essential for customizing how HTTP requests and responses are handled in your application.


Each middleware component:

  1. Receives the HTTP request.

  2. Performs some processing.

  3. Optionally calls the next middleware in the pipeline.

  4. Optionally modifies the HTTP response.


Middleware in ASP.NET Core Pipeline

The middleware pipeline is configured in Startup.cs (or Program.cs in .NET 6+).

For .NET Core 3.1/ASP.NET Core MVC:


public void Configure(IApplicationBuilder app, IWebHostEnvironment env) { // Built-in middleware examples app.UseDeveloperExceptionPage(); // 1. Show developer error page app.UseStaticFiles(); // 2. Serve static files (CSS, JS) app.UseRouting(); // 3. Enable routing app.UseAuthentication(); // 4. Handle authentication app.UseAuthorization(); // 5. Handle authorization app.UseEndpoints(endpoints => // 6. Match request to controller/action { endpoints.MapControllerRoute( name: "default", pattern: "{controller=Home}/{action=Index}/{id?}"); }); }

🔹 How Middleware Works
Every middleware is a function that takes in: HttpContext A RequestDelegate (the next middleware) Each middleware can decide: To process and pass to the next middleware. To short-circuit the pipeline.

Example of custom middleware: public class MyCustomMiddleware { private readonly RequestDelegate _next; public MyCustomMiddleware(RequestDelegate next) { _next = next; } public async Task InvokeAsync(HttpContext context) { // Before next middleware Console.WriteLine("Request: " + context.Request.Path); await _next(context); // Call the next middleware // After next middleware Console.WriteLine("Response: " + context.Response.StatusCode); } } To register it in the pipeline: public void Configure(IApplicationBuilder app, IWebHostEnvironment env) { app.UseMiddleware<MyCustomMiddleware>();
} 🔹 Middleware Lifecycle (Request to Response) Incoming Request: Passes through all middleware in the order they are registered. Terminal Middleware: Ends the request without calling next (e.g., app.Run()). Response: Travels backward through middleware, allowing each to act on the response. 🔹 Built-in Middleware Examples Middleware Purpose UseStaticFiles() Serves static files like CSS, JS, images UseRouting() Enables routing system UseAuthentication() Handles user authentication UseAuthorization() Checks user permissions UseExceptionHandler() Centralized error handling UseCors() Enables CORS (Cross-Origin Resource Sharing) UseSession() Enables session state UseEndpoints() Maps routes to endpoints (controllers)

🔹 When to Use Middleware?
Use middleware when: You want to log request/response. You want to perform actions globally, not tied to a specific controller. You want to modify requests or responses. You want to implement cross-cutting concerns like CORS, caching, auth, etc.


إرسال تعليق

0 تعليقات