Easy-DotNET Easy-DotNET
🏠首页
  • 知识地图
  • 源码脑图

    • 总览
    • Program
    • WebApplication
    • Host主机
    • WebHost主机
    • 依赖注入
    • Autofac
    • Middleware中间件
    • RateLimiter限制速率
    • 响应缓存、请求解压缩
  • 设计初衷
  • 克隆
  • 类型转换
  • 日期时间
  • IO流
  • 工具类
  • 语言特性
  • 集合类
  • Codec编码
  • 文本操作
  • 数学
  • 图片
  • 网络
  • Emoji表情
  • C# 12
  • C# 11
  • C# 10
  • C# 9.0
  • C# 8.0
  • C# 早期版本
  • C# 教程
  • ORM
  • 定时任务
  • 日志
  • 认证与授权
  • Swagger
  • 对象映射
  • 熔断重试限流
  • 缓存
  • 注册发现
  • 网关
  • GraphQL
  • 更多
  • Docker

    • 简介
    • Adminer
    • Apisix
    • Apollo
    • Cassandra
    • Cerebro
    • ClickHouse
    • Consul
    • EasyMock
    • Elasticsearch
    • Emqx
    • FastDFS
    • Flink
    • Gitlab
    • Jenkins
    • Jrebel
    • MariaDB
    • MySQL
    • Percona
    • Phpmyadmin
    • PostgreSQL
    • Redis
  • Linux

    • 查看Linux系统信息
    • CentOS7调整磁盘分区
    • IO压测
    • 图形化监控工具Cockpit
  • 总览
  • 列表

    • 算法数据结构
    • API
    • 应用框架
    • 应用模板
    • 操作系统
    • 工作流
    • 入门套件
    • 示例
    • 人工智能
    • 程序集
    • Assets
    • 认证授权
    • Blazor
    • 区块链
    • 书籍
    • 自动构建
    • 报表
    • 缓存
    • 日历
    • 聊天
    • CLI
    • CLR
    • CMS
    • 代码分析和指标
    • 代码片段
    • 压缩
    • 持续集成
    • 密码学
    • 数据库
    • 数据库驱动
    • 日期时间
    • 反编译
    • 部署
    • DirectX
    • 分布式计算
    • DLR
    • 文档
    • 电商支付
    • 模拟器
    • 环境管理
    • ETL
    • 事件消息
    • Exception
    • 扩展
    • 函数式编程
    • 游戏引擎
    • GIS
    • Git工具
    • 绘图
    • GraphQL
    • GUI
    • HTML-CSS
    • HTTP
    • IDE
    • 图片处理
    • 安装工具
    • 交互式编程
    • 国际化
    • 互操作性
    • IoC
    • JS引擎
    • 日志
    • 机器学习和数据科学
    • Markdown
    • 邮件
    • 数学
    • 媒体
    • 指标
    • 微型框架
    • 最小化器
    • MVVM
    • 网络
    • 对象映射
    • Office
    • OpenAI
    • ORM
    • 包管理器
    • PDF
    • 性能分析工具
    • 协议
    • 推送通知
    • SQL构建器
    • 消息队列
    • RPC
    • 响应式编程
    • 实时通信
    • 正则表达式
    • 任务调度
    • SDK和API
    • 搜索引擎
    • 序列化
    • SMS
    • 状态机
    • 静态站点生成
    • 强命名
    • 风格指南
    • 模板引擎
    • 测试
    • 工具
    • 交易
    • UI自动测试
    • Visual Studio 插件
    • Web浏览器
    • Web框架
    • WebServers
    • WebSocket
    • Windows服务
    • WPF
    • 解析器
    • 源码生成
    • 其他
    • 资源
  • AspNetCore面试题
  • Elasticsearch面试题
  • MongoDB面试题
  • MySql面试题
  • Nginx面试题
  • RabbitMQ面试题
  • Redis面试题
  • 设计模式
  • 微服务
🧑‍💻.NET Blog
GitHub (opens new window)
🏠首页
  • 知识地图
  • 源码脑图

    • 总览
    • Program
    • WebApplication
    • Host主机
    • WebHost主机
    • 依赖注入
    • Autofac
    • Middleware中间件
    • RateLimiter限制速率
    • 响应缓存、请求解压缩
  • 设计初衷
  • 克隆
  • 类型转换
  • 日期时间
  • IO流
  • 工具类
  • 语言特性
  • 集合类
  • Codec编码
  • 文本操作
  • 数学
  • 图片
  • 网络
  • Emoji表情
  • C# 12
  • C# 11
  • C# 10
  • C# 9.0
  • C# 8.0
  • C# 早期版本
  • C# 教程
  • ORM
  • 定时任务
  • 日志
  • 认证与授权
  • Swagger
  • 对象映射
  • 熔断重试限流
  • 缓存
  • 注册发现
  • 网关
  • GraphQL
  • 更多
  • Docker

    • 简介
    • Adminer
    • Apisix
    • Apollo
    • Cassandra
    • Cerebro
    • ClickHouse
    • Consul
    • EasyMock
    • Elasticsearch
    • Emqx
    • FastDFS
    • Flink
    • Gitlab
    • Jenkins
    • Jrebel
    • MariaDB
    • MySQL
    • Percona
    • Phpmyadmin
    • PostgreSQL
    • Redis
  • Linux

    • 查看Linux系统信息
    • CentOS7调整磁盘分区
    • IO压测
    • 图形化监控工具Cockpit
  • 总览
  • 列表

    • 算法数据结构
    • API
    • 应用框架
    • 应用模板
    • 操作系统
    • 工作流
    • 入门套件
    • 示例
    • 人工智能
    • 程序集
    • Assets
    • 认证授权
    • Blazor
    • 区块链
    • 书籍
    • 自动构建
    • 报表
    • 缓存
    • 日历
    • 聊天
    • CLI
    • CLR
    • CMS
    • 代码分析和指标
    • 代码片段
    • 压缩
    • 持续集成
    • 密码学
    • 数据库
    • 数据库驱动
    • 日期时间
    • 反编译
    • 部署
    • DirectX
    • 分布式计算
    • DLR
    • 文档
    • 电商支付
    • 模拟器
    • 环境管理
    • ETL
    • 事件消息
    • Exception
    • 扩展
    • 函数式编程
    • 游戏引擎
    • GIS
    • Git工具
    • 绘图
    • GraphQL
    • GUI
    • HTML-CSS
    • HTTP
    • IDE
    • 图片处理
    • 安装工具
    • 交互式编程
    • 国际化
    • 互操作性
    • IoC
    • JS引擎
    • 日志
    • 机器学习和数据科学
    • Markdown
    • 邮件
    • 数学
    • 媒体
    • 指标
    • 微型框架
    • 最小化器
    • MVVM
    • 网络
    • 对象映射
    • Office
    • OpenAI
    • ORM
    • 包管理器
    • PDF
    • 性能分析工具
    • 协议
    • 推送通知
    • SQL构建器
    • 消息队列
    • RPC
    • 响应式编程
    • 实时通信
    • 正则表达式
    • 任务调度
    • SDK和API
    • 搜索引擎
    • 序列化
    • SMS
    • 状态机
    • 静态站点生成
    • 强命名
    • 风格指南
    • 模板引擎
    • 测试
    • 工具
    • 交易
    • UI自动测试
    • Visual Studio 插件
    • Web浏览器
    • Web框架
    • WebServers
    • WebSocket
    • Windows服务
    • WPF
    • 解析器
    • 源码生成
    • 其他
    • 资源
  • AspNetCore面试题
  • Elasticsearch面试题
  • MongoDB面试题
  • MySql面试题
  • Nginx面试题
  • RabbitMQ面试题
  • Redis面试题
  • 设计模式
  • 微服务
🧑‍💻.NET Blog
GitHub (opens new window)
npm
  • 简介
  • ORM

    • EFCore
    • Dapper
    • FreeSql
    • SqlSugar
  • 任务调度

    • Hangfire
    • Quartz
    • FluentScheduler
    • Coravel
    • Quartzmin
  • 日志

    • Serilog
    • NLog
    • Log4Net
    • Stackdriver
    • ExceptionLess
  • 身份认证与授权

    • IdentityServer4
    • Identity
    • JWTBearer
    • Auth0
    • OpenIddict
  • Swagger文档

    • Swagger
    • Swashbuckle
    • NSwag
    • ReDoc
      • 安装
      • 集成到 .NET 项目中
        • 方法一:使用 HTML 文件引用
        • 方法二:使用 ASP.NET Core 中间件
      • 配置选项
      • 使用示例
      • 结论
  • 对象映射

    • AutoMapper
    • EmitMapper
    • AgileMapper
    • Mapster
  • 消息传递

    • MediatR
    • MassTransit
    • Rebus
    • NServiceBus
  • 熔断重试限流

    • Polly
    • Resilience4j
    • AkkaNET
  • 缓存

    • CsRedis
    • FreeRedis
    • EasyCaching
    • StackExchangeRedis
    • CacheCow
    • NCache
    • Memory
  • 注册发现

    • Consul
    • Nacos
    • Apollo
  • 网关

    • Ocelot
    • Kong
    • Traefik
    • Zuul
  • GraphQL

    • GraphQLPlatform
    • GraphQLdotnet
  • 更多

    • NodaTime
    • FluentAssertions
    • Humanizer
    • 爬虫-AngleSharp
    • 邮件-MailKit
  • NET微服务
  • Swagger文档
一个大西瓜
2023-04-20
目录

ReDoc

开源地址

Github:https://github.com/Redocly/redoc (opens new window)

ReDoc 是一个使用 OpenAPI 规范生成文档的工具,支持多种语言和框架。在 .NET 中,使用 Swagger UI 或 Swashbuckle 可以方便地生成文档,但是 ReDoc 的渲染效果更好,而且支持多种自定义选项。在本文中,我们将介绍如何在 .NET 中使用 ReDoc 生成文档,并提供详细的使用示例。

# 安装

在使用 ReDoc 之前,需要先安装它。可以使用 npm 进行安装,也可以直接下载预编译的文件。在 .NET 中,我们通常会选择下载预编译的文件,因为这样可以方便地集成到项目中。可以从 ReDoc 的官方网站 (opens new window) 下载最新版本的文件。

# 集成到 .NET 项目中

有多种方法可以将 ReDoc 集成到 .NET 项目中。下面介绍其中两种常见的方法。

# 方法一:使用 HTML 文件引用

首先,将下载的 ReDoc 文件解压到项目的静态文件目录中,例如 wwwroot 目录。然后,创建一个 HTML 文件,用于加载 ReDoc 并指定要渲染的 OpenAPI 规范文件。以下是一个示例文件:


<!DOCTYPE html>
<html>
<head>
    <title>ReDoc Demo</title>
    <meta charset="utf-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1" />
    <link rel="stylesheet" href="/redoc/redoc.min.css" />
</head>
<body>
    <redoc spec-url="/swagger/v1/swagger.json"></redoc>
    <script src="/redoc/redoc.min.js"></script>
</body>
</html>

在这个文件中,我们首先引用了 ReDoc 的 CSS 文件,然后在 <body> 中添加了一个 <redoc> 元素,用于指定要渲染的 OpenAPI 规范文件的 URL。在这个示例中,我们使用了 ASP.NET Core 中自带的 Swagger UI 生成的规范文件。最后,我们引用了 ReDoc 的 JavaScript 文件。

# 方法二:使用 ASP.NET Core 中间件

另一种常见的方法是使用 ASP.NET Core 中间件来集成 ReDoc。这种方法比较灵活,可以更方便地进行配置。下面是一个示例:


app.UseReDoc(options =>
{
    options.SpecUrl = "/swagger/v1/swagger.json";
    options.RoutePrefix = "redoc";
    options.DocumentTitle = "ReDoc Demo";
});

在这个示例中,我们使用了一个名为 UseReDoc 的中间件,用于指定要渲染的 OpenAPI 规范文件的 URL,并设置了一些其他的选项,例如路由前缀和文档标题。

# 配置选项

ReDoc 提供了许多自定义选项,可以用来调整渲染的效果

下面是一些常见的选项:

  • specUrl:要渲染的 OpenAPI 规范文件的 URL。
  • theme:主题选项,可以选择默认的明亮或暗黑主题,或者自定义主题。
  • scrollYOffset:滚动偏移量,用于控制页面滚动时的偏移量。
  • hideDownloadButton:是否隐藏下载按钮。
  • hideLoading:是否隐藏加载动画。
  • untrustedSpec:是否允许渲染不受信任的规范文件。

可以在 ReDoc 的官方文档中查看完整的选项列表和说明。

# 使用示例

在使用 ReDoc 生成文档时,我们需要先准备一个 OpenAPI 规范文件。在 .NET 中,可以使用 Swagger UI 或 Swashbuckle 来生成规范文件。以下是一个使用 Swashbuckle 生成规范文件的示例:


services.AddSwaggerGen(options =>
{
    options.SwaggerDoc("v1", new OpenApiInfo { Title = "My API", Version = "v1" });
    options.IncludeXmlComments(Path.Combine(AppContext.BaseDirectory, "MyApi.xml"));
});

在这个示例中,我们使用了 AddSwaggerGen 方法来配置 Swashbuckle,并生成了一个名为 v1 的规范文件。同时,我们还指定了一个 XML 文档文件,用于生成 API 文档注释。

接下来,我们需要将生成的规范文件传递给 ReDoc,进行渲染。我们可以使用之前介绍的两种方法之一来集成 ReDoc。以下是一个使用 HTML 文件引用的示例:


<!DOCTYPE html>
<html>
<head>
    <title>ReDoc Demo</title>
    <meta charset="utf-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1" />
    <link rel="stylesheet" href="/redoc/redoc.min.css" />
</head>
<body>
    <redoc spec-url="/swagger/v1/swagger.json"></redoc>
    <script src="/redoc/redoc.min.js"></script>
</body>
</html>

在这个示例中,我们指定了要渲染的规范文件的 URL 为 /swagger/v1/swagger.json,这与之前配置 Swashbuckle 时生成的规范文件相对应。在浏览器中打开这个 HTML 文件,就可以看到生成的 API 文档了。

# 结论

ReDoc 是一个强大的文档生成工具,可以方便地生成漂亮、易读的 API 文档。在 .NET 中,我们可以使用 Swagger UI 或 Swashbuckle 来生成 OpenAPI 规范文件,然后使用 ReDoc 来渲染这些规范文件。通过选择适合自己的集成方法和配置选项,我们可以轻松地生成高质量的文档,帮助我们更好地理解和使用 API。

上次更新: 2023/04/26, 22:10:06
NSwag
AutoMapper

← NSwag AutoMapper→

Theme by Vdoing | Copyright © 2019-2024 一个大西瓜 | MIT License | 苏ICP备2023013501号
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式