前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >使用Swagger生成ASP.NET Web API的文档

使用Swagger生成ASP.NET Web API的文档

作者头像
花落花飞去
发布2017-12-27 14:59:49
3.3K0
发布2017-12-27 14:59:49
举报
文章被收录于专栏:人工智能人工智能

在本文中,我将介绍一些可以为ASP.NET Web API生成文档的方法。除非你从未生成过Web API网站,否则你将会意识到,默认模板已经包含了为你可能实现的API 生成文档的功能,其中的一个示例位于authme.ws

入门

关于如何使用Swagger为ASP.NET Web API生成文档已经写了不止两篇文章(还有一个叫做Swashbuckle的NuGet包,你可以很容易地集成它),但是我需要一些动态的东西 - 事实上,我需要 生成表示我们提升到生产(即时点)的静态文档,因为它需要提供给审计。

传统的文档(例如Sandcastle Help File Builder)显然不可行,因为它记录了托管代码,而不是更重要的API接口和运行时的模型。

幸运的是,有一个很赞的工具集Swagger,称为Swagger codegen,它生成客户端代码来使用API,对于我来说 - 生成静态HTML的能力。不幸的是,我找不到Swagger Codegen ,所以我咬一咬牙,决定使用Maven和最新的JDK, 从源代码编译Java二进制文件。

你需要什么

你需要能够在IIS或IIS Express中可以启动的Web API站点。理想情况下,你要做的是将前面提到的Swashbuckle NuGet包集成到你现有的(或新的)Web API项目中。安装完成后,你只需更改项目设置即可生成注释XML文件(不是强制性步骤,但非常有用 - 请参阅下图),然后配置插入App_Startup文件夹下项目的SwaggerConfig.cs文件。

[图片]
[图片]

启用XML注释输出。

[图片]
[图片]

Swashbuckle NuGet packages(Swashbuckle和Swashbuckle.Core)

下面是一个非常简短(最小)的SwaggerConfig实现,删除了大量的注释:

public class SwaggerConfig
{
   public static void Register()
   {
       var thisAssembly = typeof(SwaggerConfig).Assembly;
       GlobalConfiguration.Configuration 
       .EnableSwagger(c =>
       {                      
          c.SingleApiVersion("v1", "API Services");
          c.IncludeXmlComments(GetXmlCommentsPath());
       })
      .EnableSwaggerUi(c =>
       {
       });            
   }
   private static string GetXmlCommentsPath()
   {
       var path = String.Format(@"{0}bin\Services.XML", AppDomain.CurrentDomain.BaseDirectory);
    }
}

如果你编译并运行,你应该能够看到下面这个Swagger UI,如下所示:

[图片]
[图片]

[图片]
[图片]

非常非常令人印象深刻的动态文档UI。

这里的关键是在生成的JSON中,可以通过文本框中的URI访问,在我的情况下是: http://localhost:2218/swagger/docs/v1(swagger.json)

[图片]
[图片]

swagger JSON示例

转换为静态文档

移动到swagger codegen,你还需要一个Java JDK的副本。在安装JDK之后(如果你还没有的话),你需要确保JAVA_HOME 环境变量正确地运行在正确的目录下(而不是运行时目录),并安装/提取Maven二进制文件。

我使用了最新的JDK(1.8,32位),它具有以下目录:C:\Program Files (x86)\Java\jdk1.8.0_51我还安装有Maven到Java目录,并把它添加到系统路径(具体来说应该是bin目录):

[图片]
[图片]

准备好之后,你需要将swagger codegen代码解压缩到本地目录中,然后在命令提示符中浏览到该目录,然后输入mvn package:

[图片]
[图片]
[图片]
[图片]

Maven抓包,等待一会儿

一旦编译成功,执行编译后的jar文件就简单了。在我的情况下,我把提取的swagger文件放在C:\ Tools中。打开命令提示符并浏览到以下位置:

C:\Tools\swagger-codegen-master\

要为你的API生成静态HTML文档,请使用以下语法:

java -jar modules/swagger-codegen-cli/target/swagger-codegen-cli.jar generate-i<http://localhost:2218/swagger/docs/v1>-l html

这会产生一个很好的Web API静态文档:

[图片]
[图片]

一个不错的静态HTML文件,你可以将它转换成PDF,或复制并粘贴到Word中

故障排除

如果你生成的.json产生这样的空对象:

“Object”:{ 
“type”:“object”,
“properties”:{} 
}

这可能是由于在响应中缺乏关于数据类型的足够信息。例如,采取以下示例控制器定义:

public class VersionController : ApiController
{    private readonly IVersionQuery _query;
            public VersionController(IVersionQuery query)
    {
        Guard.That(query, "query").IsNotNull();
        _query = query;
    }    [AllowAnonymous]
    public IHttpActionResult Get()
    {
        var version = _query.GetVersion();
        return Ok(version);
    }
}

我们在这里丢失的是一个提供返回类型的属性,像这样,装饰Get(),然后实现:

[ResponseType(typeof(VersionInfo))]

在写这篇文章的过程中,我从[2], [3]获得了帮助。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 入门
  • 你需要什么
  • 转换为静态文档
  • 故障排除
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档