zoukankan      html  css  js  c++  java
  • net5 webapi中 SwaggerUI如何进行版本控制

    创建项目

    net5就自带上了swaggerUI,见红色

         // This method gets called by the runtime. Use this method to add services to the container.
            public void ConfigureServices(IServiceCollection services)
            {
    
                services.AddControllers();
                services.AddSwaggerGen(c =>
                {
                    c.SwaggerDoc("v1", new OpenApiInfo { Title = "Net5.WebAPI", Version = "v1" });
                });
            }
    
            // This method gets called by the runtime. Use this method to configure the HTTP request pipeline.
            public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
            {
                if (env.IsDevelopment())
                {
                    app.UseDeveloperExceptionPage();
                    app.UseSwagger();
                    app.UseSwaggerUI(c => c.SwaggerEndpoint("/swagger/v1/swagger.json", "Net5.WebAPI v1"));
                }
    
                app.UseRouting();
    
                app.UseAuthorization();
    
                app.UseEndpoints(endpoints =>
                {
                    endpoints.MapControllers();
                });
            }
        }

    代码改造

    1.添加FirstController

       public class FirstController : ControllerBase
        {
            /// <summary>
            /// 这是V1版本的GetString
            /// </summary>
            /// <returns></returns>
            [HttpGet]
            public string GetToString()
            {
                return Newtonsoft.Json.JsonConvert.SerializeObject(new
                {
                    Id = 123,
                    Name = "闪电五连鞭"
                });
            }
    
    
            /// <summary>
            /// 这是V1版本的Add
            /// </summary>
            /// <returns>name</returns>
            [HttpPost]
            public string Add(string name)
            {
                return JsonConvert.SerializeObject(new
                {
                    Id = 234,
                    Name = name
                });
            }
    
            [HttpPut]
            public int Update(int Id)
            {
                return Id;
            }
            [HttpDelete]
            public int Delete(int Id)
            {
                return Id;
            }
    
            [HttpPatch]
            public int Patch()
            {
                return 123;
            }
        }

    新建文件夹V2, 放入新版本的代码

        [Route("api/[controller]")]
        [ApiController]
        public class FirstController : ControllerBase
        {
            /// <summary>
            /// 这是V2版本的GetString
            /// </summary>
            /// <returns></returns>
            [HttpGet]
            public string GetToString()
            {
                return Newtonsoft.Json.JsonConvert.SerializeObject(new
                {
                    Id = 123,
                    Name = "闪电五连鞭"
                });
            }
    
    
            /// <summary>
            /// 这是V2版本的Add
            /// </summary>
            /// <returns>name</returns>
            [HttpPost]
            public string Add(string name)
            {
                return JsonConvert.SerializeObject(new
                {
                    Id = 234,
                    Name = name
                });
            }
    
            [HttpPut]
            public int Update(int Id)
            {
                return Id;
            }
            [HttpDelete]
            public int Delete(int Id)
            {
                return Id;
            }
    
            [HttpPatch]
            public int Patch()
            {
                return 123;
            }
        }

    2.生成swagge有关项目的Xml注释文件,并修改其属性为“始终复制”

     

     3.添加版本枚举类

     public enum ApiVersions
            {
                V1 = 1,
                V2 = 2,
                V3 = 3,
                V4 = 4,
                V5 = 5
            }

    4.改造StartUp中swagger代码

         public void ConfigureServices(IServiceCollection services)
            {
    
                services.AddControllers();
                services.AddSwaggerGen(c =>
                {
                    typeof(ApiVersions).GetEnumNames().ToList().ForEach(version =>
                    {
                        c.SwaggerDoc(version, new OpenApiInfo()
                        {
                            Title = "Net5.WebAPI",
                            Version = version,
                            Description = $"Net5.WebAPI的 {version} 版本,可根据需要选择"
                        });
                    });
    
                    #region 为Swagger JSON and UI设置xml文档注释路径 
                    string basePath = Path.GetDirectoryName(typeof(Program).Assembly.Location);//获取应用程序所在目录(绝对,不受工作目录影响,建议采用此方法获取路径)
                    string xmlPath = Path.Combine(basePath, "Net5.WebAPI.xml");
    
                    c.IncludeXmlComments(xmlPath);
                    #endregion
    
                    // c.SwaggerDoc("v1", new OpenApiInfo { Title = "Net5.WebAPI", Version = "v1" });
                });
            }
    
            // This method gets called by the runtime. Use this method to configure the HTTP request pipeline.
            public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
            {
                if (env.IsDevelopment())
                {
                    app.UseDeveloperExceptionPage();
                    app.UseSwagger();
                    app.UseSwaggerUI(c =>
                    {
                        typeof(ApiVersions).GetEnumNames().ToList().ForEach(version =>
                        {
                            c.SwaggerEndpoint($"/swagger/{version}/swagger.json", $"Net5.WebAPI {version}");
                        });
                        //c => c.SwaggerEndpoint("/swagger/v1/swagger.json", "Net5.WebAPI v1")
                    });
                }
    
                app.UseRouting();
    
                app.UseAuthorization();
    
                app.UseEndpoints(endpoints =>
                {
                    endpoints.MapControllers();
                });
            }

    添加版本号

    在需要进行版本控制的控制器添加版本  [ApiExplorerSettings(GroupName = "V?")]   [Route("api/V?/[controller]")]

     大功告成,运行效果如下

     源码下载

    进下面的QQ群,在群在线文档里面

    !

    • 作       者 : 明志德道
    • 希     望: 如果内容对您有用,动动小手点个赞吧,您的支持就是我持续写作的动力!
    • 声     明1 : 如有错误,欢迎讨论,请勿谩骂^_^。
    • 声     明2 : 原创博客请在转载时保留原文链接或在文章开头加上本人博客地址,否则保留追究法律责任的权利。
  • 相关阅读:
    php内核为变量的值分配内存的几个宏
    php7 引用成为一种类型
    function参数
    execvp php-fpm reload使用的函数
    fastcgi
    php-fpm定时器
    php 类继承
    php 对象 调用静态方法
    php unset变量
    php5数组与php7数组区别
  • 原文地址:https://www.cnblogs.com/for-easy-fast/p/14493847.html
Copyright © 2011-2022 走看看