web-dev-qa-db-ja.com

MiniProfilerをASP.NETCore Web APISwaggerに接続します

MiniProfilerをASP.NETWebAPIおよびSwaggerUIと連携させる方法を説明している このマニュアル のみが見つかりましたが、ASP.NET Core WebAPIをMiniProfilerと連携させる方法を説明しているマニュアルは見つかりませんでした。 SwaggerUIで結果を表示します。

11

必要なのは、 ドキュメント で説明されているようにSwagger _index.html_ファイルをカスタマイズすることだけです。カスタムHTMLファイルを作成したら、次の行を追加します。

_<script async="async" id="mini-profiler" src="/profiler/includes.js?v=4.0.0.0" data-version="4.0.0.0" data-path="/profiler/" data-current-id="865f1487-f416-4d39-87fe-723e34847577" data-ids="" data-position="left" data-authorized="true" data-max-traces="15" data-toggle-shortcut="Alt+P" data-trivial-milliseconds="2.0" data-ignored-duplicate-execute-types="Open,OpenAsync,Close,CloseAsync"></script>
_

基本的に、上記のスクリプトはMiniProfiler.Current.RenderIncludes()メソッドの出力です。

以下は、ConfigureServicesメソッドとConfigureメソッドの下にあり、SwaggerとMiniprofilerの両方がどのように構成されているかを確認できます。

_public void ConfigureServices(IServiceCollection services)
{
    services.AddMvc();
    // Register the Swagger generator, defining one or more Swagger documents
    services.AddSwaggerGen(c =>
    {
        c.SwaggerDoc("v1", new Info { Title = "My API", Version = "v1" });
    });

    services.AddMiniProfiler(options => 
        options.RouteBasePath = "/profiler"
    );
}

// This method gets called by the runtime. Use this method to configure the HTTP request pipeline.
public void Configure(IApplicationBuilder app, IHostingEnvironment env)
{
    if (env.IsDevelopment())
    {
        app.UseDeveloperExceptionPage();
        app.UseMiniProfiler();
    }

    app.UseSwagger();
    app.UseSwaggerUI(c => {
        c.SwaggerEndpoint("/swagger/v1/swagger.json", "My API V1");
        c.IndexStream = () => GetType().GetTypeInfo().Assembly.GetManifestResourceStream("SOMpSwaggerNetCore.SwaggerIndex.html");
    });
    app.UseMvc();
}
_
10