Skip to main content

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.


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...