• 自动生成在线文档


    SwaggerUI,Swashbuckle,WebAPI 自动生成在线文档

     

    1.前言

    1.1 SwaggerUI

    SwaggerUI 是一个简单的Restful API 测试和文档工具。简单、漂亮、易用(官方demo)。通过读取JSON 配置显示API. 项目本身仅仅也只依赖一些 html,css.js静态文件. 你可以几乎放在任何Web容器上使用。

    1.2 Swashbuckle

    Swashbuckle 是.NET类库,可以将WebAPI所有开放的控制器方法生成对应SwaggerUI的JSON配置。再通过SwaggerUI 显示出来。类库中已经包含SwaggerUI 。所以不需要额外安装。

    2.版本和资源

    你可以通过下列连接获取相关说明。

    Swashbuckle 项目地址:
    https://github.com/domaindrivendev/Swashbuckle
    swagger-ui 项目地址:
    https://github.com/swagger-api/swagger-ui
    swagger-ui 官网地址:
    http://swagger.io/swagger-ui/

    3.快速开始

    • WebAPI 安装 Swashbuckle

      Install-Package Swashbuckle
    • 浏览器访问

      http://<yourhostname>.com/swagger/ui/index
    • 如果不出意外则显示
      运行截图

      4.代码注释生成文档说明。

      Swashbuckle 是通过生成的XML文件来读取注释的,生成 SwaggerUI,JSON 配置中的说明的。
      安装时会在项目目录 App_Start 文件夹下生成一个 SwaggerConfig.cs 配置文件,用于配置 SwaggerUI 相关展示行为的。如图:

    配置文件

    将配置文件第99行,注释去掉,并修改为

    c.IncludeXmlComments(GetXmlCommentsPath(thisAssembly.GetName().Name));

    并在当前类中添加如下代码

    /// <summary>
    /// </summary>
    /// <param name="name"></param>
    /// <returns></returns>
    protected static string GetXmlCommentsPath(string name)
    {
         return string.Format(@"{0}in{1}.XML", AppDomain.CurrentDomain.BaseDirectory, name);
    }

    紧接着你在此Web项目属性选型,生成选卡中 选择 “XML 文档文件”

    此处输入图片的描述

    打开控制 "ValuesController" 添加注释

    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Net;
    using System.Net.Http;
    using System.Web.Http;
    using ClassLibrary1;
    
    namespace WebApplication1.Controllers
    {
        [Authorize]
        public class ValuesController : ApiController
        {
            //some code.....
            
            /// <summary>
            /// 根据ID获取一个值
            /// </summary>
            /// <param name="id">值的ID</param>
            /// <remarks>当前方法根据ID获取一个值</remarks>
            /// <returns>返回</returns>
            public string Get(int id)
            {
                return "value";
            }
            
            // some code ....
        }
    }
    

    保存重写生成. 如图

    此处输入图片的描述

    4.添加自定义HTTP Header

    待续..

    5.显示上传文件参数

    待续..

    6.编写 Swashbuckle 扩展

  • 相关阅读:
    HDU-5980
    HDU-5974
    HDU-5979
    关于position的定位
    javascript学习笔记w3chool
    表单相关css技巧
    fis压缩工具的使用
    将HTML页面内容存入json数组
    中介PHP连接前台HTML与数据库MySQL
    lesscss的使用
  • 原文地址:https://www.cnblogs.com/Leo_wl/p/5148212.html
Copyright © 2020-2023  润新知