asp.net-core – 外部包中的模型显示在swagger文档中

前端之家收集整理的这篇文章主要介绍了asp.net-core – 外部包中的模型显示在swagger文档中前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在研究swagger文档,并添加了一个外部包“NodaTime”,并在模型中用作我的属性的类型
public LocalDateTime Date {get;组; }
NodaTime包中的模型和模型显示在文档中.
请看截图中的模型,突出显示的是NodaTime包.
为什么Swagger将其包含在文档中以及如何从文档中排除外部包.

提前致谢.

解决方法

我猜他们正在出现,因为你正在暴露一个使用NodaTime类型的对象. Swashbuckle / Swagger正在显示整个对象图…如果模型使用这些模型,则无法关闭第三方的东西.如果你看看github上的 library中的代码,你可以看到Swashbuckle对几个基类库原语给出了特殊的处理.方法是CreatePrimitiveSchema(),LocalDateTime不在case语句中.因此,作为对此的修复,您可以分叉Swashbuckle并添加NodaTime类型.这可能不值得.

但是,Swashbuckle允许您关闭模型扩展.下面你可以看到我如何设置我的Swashbuckle配置.设置DefaultModelsExpandDepth(-1)将隐藏它们.

public void Configure(IApplicationBuilder app,IHostingEnvironment env,DataGraphContext db) {
        if (env.IsDevelopment()) {
            app.UseDeveloperExceptionPage();
        } else {
            app.UseHsts();
        }

        app.UseSwagger();

        app.UseSwaggerUI(c => {
            c.SwaggerEndpoint("/swagger/v1/swagger.json","API V1");
            c.DefaultModelExpandDepth(0);
            c.DefaultModelsExpandDepth(-1);
        });

        app.UseAuthentication();

        app.UseExceptionHandling();
        app.UseCors("AllowSpecificOrigins");
        app.UseHttpsRedirection();
        app.UseMvc();
    }

猜你在找的asp.Net相关文章