在后台接口开发中,接口文档是必不可少的。在复杂的业务当中和多人对接的情况下,简单的接口文档又不能满足需求,试想你的单应用后台有几十个模块,几百甚至更多的接口,又有上百个ViewModel。怎么能让人用起来更顺手更明了?本篇介绍第一步的中度优化,下一篇将分享下一阶段的深度优化。
第一篇:ASP.NET WebApi 文档Swagger中度优化
1.上手使用
2.Controller注释读取和汉化
3.Actionf group by 分组
4.通过exe整合xxxModel.xml和xxxAPI.XML
5.通过批处理命令在生成后调用exe
第二篇:ASP.NET WebApi 文档Swashbuckle.Core与SwaggerUI深度定制
Swagger是一款完全开源的文档工具,其优点在于前后端的完整分离,他们之间的契约就是Json的数据格式。其后台项目就是github中的Swashbuckle。其前台项目就是github中的SwaggerUI。有一点需要注意的是,如果你直接从nuget安装Swashbuckle的话,你也并不想做更多的定制化,那么UI界面你完全不需要处理,因为所有的资源Resources都是嵌入到Swashbuckle.dll当中的,你可以在vs对象管理器中查看到Resources,如下图,是不是又复习了dll的作用了呢?其中还可以包含css,js,image等资源:
看下本次分享的效果图吧,只选了四个Controller做展示,个人觉得还是比较明了的吧,如果模块和控制器多了起来,就会深刻体会到好处:
先学会上手使用
nuget中搜索Swashbuckle并安装到你的WebApi项目中,其他的不用安装哦。
安装完成后你的App_Start中会多一个SwaggerConfig这样一个配置文件,这个文件是Swagger为我们留下的配置入口,我们可以根据其中的注释和介绍做很多事情。然后我把Swagger单独出来一个文件夹,直接将配置类拖进去,如下效果:
下一步配置你的项目属性,在其生成选项当中,选择下图配置:
配置文件中主要有两个入口:EnableSagger和EnableSwaggerUi,顾名思义,配置其后台项和前台项。
找到下面这行代码,传入你所需的两个字符串
下一步找到IncludeXmlComments方法,配置读取XML的路径:
c.IncludeXmlComments(string.Format("{0}/bin/SwaggerDemo.XML", System.AppDomain.CurrentDomain.BaseDirectory));
至此基本就可以显示你的接口了,请访问:localhost:xxxx/swagger 你可能会问为什么我没有添加页面也能展示,这就是因为页面和其路由设置都在dll中了!下面这段源码揭示了为什么可以直接通过路由访问到你的swagger主页,当然你也可以不必关心下面这段:
public void EnableSwaggerUi( string routeTemplate, Action<SwaggerUiConfig> configure = null) { var config = new SwaggerUiConfig(_discoveryPaths, _rootUrlResolver); if (configure != null) configure(config); _httpConfig.Routes.MapHttpRoute( name: "swagger_ui" + routeTemplate, routeTemplate: routeTemplate, defaults: null, constraints: new { assetPath = @".+" }, handler: new SwaggerUiHandler(config) ); if (routeTemplate == DefaultRouteTemplate) { _httpConfig.Routes.MapHttpRoute( name: "swagger_ui_shortcut", routeTemplate: "swagger", defaults: null, constraints: new { uriResolution = new HttpRouteDirectionConstraint(HttpRouteDirection.UriResolution) }, handler: new RedirectHandler(_rootUrlResolver, "swagger/ui/index")); } }
Controller注释读取
默认情况下,Controller注释是没有读取的。那么你需要通过如下配置来达到目的,增加这样一个类,不用问为什么。下面这段代码也是参考了。汉化我也没必要讲了,他已经说的很详细了。