Asp.Net Core遇到Swagger(二)-Swashbuckle技巧a篇(上)

简介: Asp.Net Core遇到Swagger(二)-Swashbuckle技巧a篇

一、前言

上篇Swashbuckle(一),主要是讲解的Coreswagger对应框架Swashbuckle的基础使用,本篇文章讲解基于Swashbuckle的进一步实践应用操作和配置。

二、实践技巧

2.1 显示中文注释

Api文档从Xml注释文档中获取描述信息,将基本的信息展示到Swagger UI文档中。

1) 基础配置

编辑项目xxxx.csproj文件,添加如下节点:

<PropertyGroup>
     <GenerateDocumentationFile>true</GenerateDocumentationFile>
     <NoWarn>$(NoWarn);1591</NoWarn>
 </PropertyGroup>

修改Configure函数中SwaggerGen中间件服务配置,用于加载xml注释文件配置;

public void ConfigureServices(IServiceCollection services)
{
    ..........
    services.AddSwaggerGen(
        options => {
            //获取当前执行程序集名称+.xml,作为实际xml注释文件名称
            string filename = $"{Assembly.GetExecutingAssembly().GetName().Name}.xml";
            //拼接路径-路径间隔符由系统决定
            string path = System.IO.Path.Combine(System.AppContext.BaseDirectory, filename
            //添加xml注释文件到swaggergen中用于生成api json
            options.IncludeXmlComments(path);
        }
        );
    .........
}

为案例项目中的控制器下Action添加如下内容:

/// <summary>
/// 天气预报服务
/// </summary>
[ApiController]
[Route("[controller]")]
public class WeatherForecastController : ControllerBase
{
    ......
    /// <summary>
    /// 获取天气预报信息
    /// </summary>
    /// <returns>天气预报结果</returns>
    [HttpGet]
    public IEnumerable<WeatherForecast> Get()
    {
        var rng = new Random();
        return Enumerable.Range(1, 5).Select(index => new WeatherForecast
        {
            Date = DateTime.Now.AddDays(index),
            TemperatureC = rng.Next(-20, 55),
            Summary = Summaries[rng.Next(Summaries.Length)]
        })
        .ToArray();
    }
    ......
}

实体类WeatherForecast添加注释:

/// <summary>
/// 天气预报实体
/// </summary>
public class WeatherForecast
{
    /// <summary>
    /// 日期
    /// </summary>
    public DateTime Date { get; set; }
    /// <summary>
    /// 温度-摄氏度
    /// </summary>
    public int TemperatureC { get; set; }
    /// <summary>
    /// 温度-华摄氏度
    /// </summary>
    public int TemperatureF => 32 + (int)(TemperatureC / 0.5556);
    /// <summary>
    /// 描述
    /// </summary>
    public string Summary { get; set; }
}

重新生成项目后,可以在当前项目的bin/debug文件夹下,查看到对应的xxxx.xml

<?xml version="1.0"?>
<doc>
    <assembly>
        <name>swaggertestbase</name>
    </assembly>
    <members>
        <member name="T:swaggertestbase.Controllers.WeatherForecastController">
            <summary>
            天气预报服务
            </summary>
        </member>
        <member name="M:swaggertestbase.Controllers.WeatherForecastController.Get">
            <summary>
            获取天气预报信息
            </summary>
            <returns>天气预报结果</returns>
        </member>
        <member name="T:swaggertestbase.WeatherForecast">
            <summary>
            天气预报实体
            </summary>
        </member>
        <member name="P:swaggertestbase.WeatherForecast.Date">
            <summary>
            日期
            </summary>
        </member>
        <member name="P:swaggertestbase.WeatherForecast.TemperatureC">
            <summary>
            温度-摄氏度
            </summary>
        </member>
        <member name="P:swaggertestbase.WeatherForecast.TemperatureF">
            <summary>
            温度-华摄氏度
            </summary>
        </member>
        <member name="P:swaggertestbase.WeatherForecast.Summary">
            <summary>
            描述
            </summary>
        </member>
    </members>
</doc>

运行项目,Api文档如下:

2)添加范例

注释中使用Remarks标记进行范例添加,

/// <summary>
/// 天气预报服务
/// </summary>
[ApiController]
[Route("[controller]")]
public class WeatherForecastController : ControllerBase
{
    ......
    /// <summary>
    /// 获取天气预报信息
    /// </summary>
    /// <returns>天气预报结果</returns>
    /// <remarks>
    /// 测试范例:
    /// 
    ///     GET /WeatherForecast/
    ///     
    /// </remarks>
    [HttpGet]
    public IEnumerable<WeatherForecast> Get()
    {
        var rng = new Random();
        return Enumerable.Range(1, 5).Select(index => new WeatherForecast
        {
            Date = DateTime.Now.AddDays(index),
            TemperatureC = rng.Next(-20, 55),
            Summary = Summaries[rng.Next(Summaries.Length)]
        })
        .ToArray();
    }
    ......
}

运行效果:

相关文章
|
8天前
|
开发框架 .NET 开发者
简化 ASP.NET Core 依赖注入(DI)注册-Scrutor
Scrutor 是一个简化 ASP.NET Core 应用程序中依赖注入(DI)注册过程的开源库,支持自动扫描和注册服务。通过简单的配置,开发者可以轻松地从指定程序集中筛选、注册服务,并设置其生命周期,同时支持服务装饰等高级功能。适用于大型项目,提高代码的可维护性和简洁性。仓库地址:&lt;https://github.com/khellang/Scrutor&gt;
30 5
|
27天前
|
开发框架 .NET C#
在 ASP.NET Core 中创建 gRPC 客户端和服务器
本文介绍了如何使用 gRPC 框架搭建一个简单的“Hello World”示例。首先创建了一个名为 GrpcDemo 的解决方案,其中包含一个 gRPC 服务端项目 GrpcServer 和一个客户端项目 GrpcClient。服务端通过定义 `greeter.proto` 文件中的服务和消息类型,实现了一个简单的问候服务 `GreeterService`。客户端则通过 gRPC 客户端库连接到服务端并调用其 `SayHello` 方法,展示了 gRPC 在 C# 中的基本使用方法。
38 5
在 ASP.NET Core 中创建 gRPC 客户端和服务器
|
16天前
|
开发框架 缓存 .NET
GraphQL 与 ASP.NET Core 集成:从入门到精通
本文详细介绍了如何在ASP.NET Core中集成GraphQL,包括安装必要的NuGet包、创建GraphQL Schema、配置GraphQL服务等步骤。同时,文章还探讨了常见问题及其解决方法,如处理复杂查询、错误处理、性能优化和实现认证授权等,旨在帮助开发者构建灵活且高效的API。
24 3
|
2月前
|
开发框架 JavaScript 前端开发
一个适用于 ASP.NET Core 的轻量级插件框架
一个适用于 ASP.NET Core 的轻量级插件框架
|
3月前
|
开发框架 前端开发 JavaScript
ASP.NET MVC 教程
ASP.NET 是一个使用 HTML、CSS、JavaScript 和服务器脚本创建网页和网站的开发框架。
48 7
|
3月前
|
存储 开发框架 前端开发
ASP.NET MVC 迅速集成 SignalR
ASP.NET MVC 迅速集成 SignalR
75 0
|
4月前
|
开发框架 前端开发 .NET
ASP.NET MVC WebApi 接口返回 JOSN 日期格式化 date format
ASP.NET MVC WebApi 接口返回 JOSN 日期格式化 date format
56 0
|
4月前
|
开发框架 前端开发 安全
ASP.NET MVC 如何使用 Form Authentication?
ASP.NET MVC 如何使用 Form Authentication?
|
4月前
|
开发框架 .NET
Asp.Net Core 使用X.PagedList.Mvc.Core分页 & 搜索
Asp.Net Core 使用X.PagedList.Mvc.Core分页 & 搜索
143 0
|
7月前
|
开发框架 前端开发 .NET
ASP.NET CORE 3.1 MVC“指定的网络名不再可用\企图在不存在的网络连接上进行操作”的问题解决过程
ASP.NET CORE 3.1 MVC“指定的网络名不再可用\企图在不存在的网络连接上进行操作”的问题解决过程
212 0