Recherche…


Paramètres

Paramètre Détails
IDictionary<string,object> environment C'est la seule collection dans laquelle OWIN communique des informations lors d'un appel. Toutes les clés peuvent être trouvées sur https://docs.asp.net/en/latest/fundamentals/owin.html#owin-keys

Remarques

Le type AppFunc n'est qu'un alias pour le type Func<IDictionary<string, object>, Task> pour raccourcir les signatures de méthode, un peu comme typedef en C ++.

Affiche le chemin de la requête et le temps nécessaire pour le traiter

//define a short alias to avoid chubby method signatures
using AppFunc = Func<IDictionary<string, object>, Task>;

class RequestTimeMiddleware
{
    private AppFunc _next;

    public RequestTimeMiddleware(AppFunc next)
    {
        _next = next;
    }

    public async Task Invoke(IDictionary<string, object> environment)
    {
        IOwinContext context = new OwinContext(environment);
        
        var path = context.Request.Path;
        var sw = Stopwatch.StartNew();
        //Queue up the next middleware in the pipeline
        await _next(environment);
        //When the request comes back, log the elapsed time
        Console.WriteLine($"Request for {path} processed in {sw.ElapsedMilliseconds}ms");
    }
}

public static class RequestTimeMiddlewareExtensions
{
    //Extension method as syntactic sugar, to get a meaningful way 
    //in adding the middleware to the pipeline
    public static void UseRequestTimeMiddleware(this IAppBuilder app)
    {
        app.Use<RequestTimeMiddleware>();
    }
}


public class Startup
{
    public void Configuration(IAppBuilder app)
    {
        //add the Middleware as early as possible
        app.UseRequestTimeMiddleware();
        //Queue up every other module
        app.Use(async (environment, next) =>
        {
            await environment.Response.WriteAsync("Hello from the console world");
            await next();
        });
    }
}


Modified text is an extract of the original Stack Overflow Documentation
Sous licence CC BY-SA 3.0
Non affilié à Stack Overflow