ASP.NET WebAPI使用Swagger生成测试文档

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

捣鼓了好久最终效果如下

1、API控制器和action描述

2、测试接口

使用swagger

1.创建webapi项目解决方案

2.引用swagger nuget包

swashbuckle和swagger.NET

删除多余的SwaggerUI文件夹和配置类SwaggerNet

3、添加接口注释

接下来可以访问http://xxxx/swagger 这样并看不到注释

项目属性->勾选生成xml文档文件

修改SwaggerConfig文件

  1. c.IncludeXmlComments(string.Format(@"{0}\App_Data\Api.xml",AppDomain.CurrentDomain.BaseDirectory));

汉化

1.SwaggerConfig

js文件需要嵌入到dll

  1.  
  2. /// <summary>
  3. /// 中文转换
  4. /// </summary>
  5. var SwaggerTranslator = (function () {
  6. //定时执行检测是否转换成中文,最多执行500次 即500*50/1000=25s
  7. var iexcute = 0,
  8. //中文语言包
  9. _words = {
  10. "Warning: Deprecated": "警告:已过时",
  11. "Implementation Notes": "实现备注",
  12. "Response Class": "响应类",
  13. "Status": "状态",
  14. "Parameters": "参数",
  15. "Parameter": "参数",
  16. "Value": "值",
  17. "Description": "描述",
  18. "Parameter Type": "参数类型",
  19. "Data Type": "数据类型",
  20. "Response Messages": "响应消息",
  21. "HTTP Status Code": "HTTP状态码",
  22. "Reason": "原因",
  23. "Response Model": "响应模型",
  24. "Request URL": "请求URL",
  25. "Response Body": "响应体",
  26. "Response Code": "响应码",
  27. "Response Headers": "响应头",
  28. "Hide Response": "隐藏响应",
  29. "Headers": "头",
  30. "Try it out!": "试一下!",
  31. "Show/Hide": "显示/隐藏",
  32. "List Operations": "显示操作",
  33. "Expand Operations": "展开操作",
  34. "Raw": "原始",
  35. "can't parse JSON. Raw result": "无法解析JSON. 原始结果",
  36. "Model Schema": "模型架构",
  37. "Model": "模型",
  38. "apply": "应用",
  39. "Username": "用户名",
  40. "Password": "密码",
  41. "Terms of service": "服务条款",
  42. "Created by": "创建者",
  43. "See more at": "查看更多:",
  44. "Contact the developer": "联系开发者",
  45. "api version": "api版本",
  46. "Response Content Type": "响应Content Type",
  47. "fetching resource": "正在获取资源",
  48. "fetching resource list": "正在获取资源列表",
  49. "Explore": "浏览",
  50. "Show Swagger Petstore Example Apis": "显示 Swagger Petstore 示例 Apis",
  51. "Can't read from server. It may not have the appropriate access-control-origin settings.": "无法从服务器读取。可能没有正确设置access-control-origin。",
  52. "Please specify the protocol for": "请指定协议:",
  53. "Can't read swagger JSON from": "无法读取swagger JSON于",
  54. "Finished Loading Resource Information. Rendering Swagger UI": "已加载资源信息。正在渲染Swagger UI",
  55. "Unable to read api": "无法读取api",
  56. "from path": "从路径",
  57. "Click to set as parameter value": "点击设置参数",
  58. "server returned": "服务器返回"
  59. },
  60. //定时执行转换
  61. _translator2Cn = function () {
  62. if ($("#resources_container .resource").length > 0) {
  63. _tryTranslate();
  64. }
  65. if ($("#explore").text() == "Explore" && iexcute < 500) {
  66. iexcute++;
  67. setTimeout(_translator2Cn, 50);
  68. }
  69. },
  70. //设置控制器注释
  71. _setControllerSummary = function () {
  72. $.ajax({
  73. type: "get",
  74. async: true,
  75. url: $("#input_baseUrl").val(),
  76. dataType: "json",
  77. success: function (data) {
  78. var summaryDict = data.ControllerDesc;
  79. var id, controllerName, strSummary;
  80. $("#resources_container .resource").each(function (i, item) {
  81. id = $(item).attr("id");
  82. if (id) {
  83. controllerName = id.substring(9);
  84. strSummary = summaryDict[controllerName];
  85. if (strSummary) {
  86. $(item).children(".heading").children(".options").prepend('<li class="controller-summary" title="' + strSummary + '">' + strSummary + '</li>');
  87. }
  88. }
  89. });
  90. }
  91. });
  92. },
  93. //尝试将英文转换成中文
  94. _tryTranslate = function () {
  95. $('[data-sw-translate]').each(function () {
  96. $(this).html(_getLangDesc($(this).html()));
  97. $(this).val(_getLangDesc($(this).val()));
  98. $(this).attr('title', _getLangDesc($(this).attr('title')));
  99. });
  100. },
  101. _getLangDesc = function (word) {
  102. return _words[$.trim(word)] !== undefined ? _words[$.trim(word)] : word;
  103. };
  104. return {
  105. Translator: function () {
  106. document.title = "API描述文档";
  107. $('body').append('<style type="text/css">.controller-summary{color:#10a54a !important;word-break:keep-all;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:250px;text-align:right;cursor:default;} </style>');
  108. $("#logo").html("接口描述").attr("href", "/Home/Index");
  109. //设置控制器描述
  110. _setControllerSummary();
  111. _translator2Cn();
  112. }
  113. }
  114. })();
  115. //执行转换
  116. SwaggerTranslator.Translator();
  117.  

2.控制器描述和接口文档缓存

  1. public class CachingSwaggerProvider : ISwaggerProvider
  2. {
  3. private static ConcurrentDictionary<string, SwaggerDocument> _cache =
  4. new ConcurrentDictionary<string, SwaggerDocument>();
  5. private readonly ISwaggerProvider _swaggerProvider;
  6. public CachingSwaggerProvider(ISwaggerProvider swaggerProvider)
  7. {
  8. _swaggerProvider = swaggerProvider;
  9. }
  10. public SwaggerDocument GetSwagger(string rootUrl, string apiVersion)
  11. {
  12. var cacheKey = string.Format("{0}_{1}", rootUrl, apiVersion);
  13. SwaggerDocument srcDoc = null;
  14. //只读取一次
  15. if (!_cache.TryGetValue(cacheKey, out srcDoc))
  16. {
  17. srcDoc = _swaggerProvider.GetSwagger(rootUrl, apiVersion);
  18. srcDoc.vendorExtensions = new Dictionary<string, object> { { "ControllerDesc", GetControllerDesc() } };
  19. _cache.TryAdd(cacheKey, srcDoc);
  20. }
  21. return srcDoc;
  22. }
  23. /// <summary>
  24. /// 从API文档中读取控制器描述
  25. /// </summary>
  26. /// <returns>所有控制器描述</returns>
  27. public static ConcurrentDictionary<string, string> GetControllerDesc()
  28. {
  29. string xmlpath = string.Format(@"{0}\App_Data\Api.xml", System.AppDomain.CurrentDomain.BaseDirectory);
  30. ConcurrentDictionary<string, string> controllerDescDict = new ConcurrentDictionary<string, string>();
  31. if (File.Exists(xmlpath))
  32. {
  33. XmlDocument xmldoc = new XmlDocument();
  34. xmldoc.Load(xmlpath);
  35. string type = string.Empty, path = string.Empty, controllerName = string.Empty;
  36. string[] arrPath;
  37. int length = -1, cCount = "Controller".Length;
  38. XmlNode summaryNode = null;
  39. foreach (XmlNode node in xmldoc.SelectNodes("//member"))
  40. {
  41. type = node.Attributes["name"].Value;
  42. if (type.StartsWith("T:"))
  43. {
  44. //控制器
  45. arrPath = type.Split('.');
  46. length = arrPath.Length;
  47. controllerName = arrPath[length - 1];
  48. if (controllerName.EndsWith("Controller"))
  49. {
  50. //获取控制器注释
  51. summaryNode = node.SelectSingleNode("summary");
  52. string key = controllerName.Remove(controllerName.Length - cCount, cCount);
  53. if (summaryNode != null && !string.IsNullOrEmpty(summaryNode.InnerText) && !controllerDescDict.ContainsKey(key))
  54. {
  55. controllerDescDict.TryAdd(key, summaryNode.InnerText.Trim());
  56. }
  57. }
  58. }
  59. }
  60. }
  61. return controllerDescDict;
  62. }
  63. }

有什么问题大家可以在下面评论,本人技术不怎么到位,写的不好希望大家见谅。

ASP.NET WebAPI使用Swagger生成测试文档的更多相关文章

  1. ASP.NET WEBAPI 使用Swagger生成API文档

    一.安装 新建一个没有身份验证的mvc项目 - SwaggerMvc5Demo,然后添加一个名为Remote(自定义)且包含基础读写(不想手写)的ApiController   开源地址:https: ...

  2. ASP.NET WebApi 使用Swagger生成接口文档

    前言 公司一直采用Word文档方式与客户端进行交流.随着时间的推移,接口变的越来越多,文档变得也很繁重.而且一份文档经常由多个开发人员维护,很难保证文档的完整性.而且有时写完代码也忘了去更新文档,为了 ...

  3. asp.net core 使用 swagger 生成接口文档

    参考地址:http://www.cnblogs.com/daxnet/p/6181366.html http://www.jianshu.com/p/fa5a9b76f3ed 微软参考文档:https ...

  4. .Net Core 3.1 WebApi使用Swagger生成Api文档

    用swagger生成Api文档 1.安装Swashbuckle.AspNetCore 右键单击"解决方案资源管理器" > "管理 NuGet 包"中的项目 ...

  5. ASP.NET WebApi使用Swagger生成api说明文档

    最近做的项目使用mvc+webapi(非.Net Core),采取前后端分离的方式,后台提供API接口给前端开发人员.这个过程中遇到一个问题后台开发人员怎么提供接口说明文档给前端开发人员,最初打算使用 ...

  6. WebAPI使用Swagger生成接口文档

    开发工具:VS2017 版本15.7.1 新建项目,选择空模板,下面只勾选WebAPI 配置Web.config <system.webServer> 节点改为 <system.we ...

  7. ASP.NET Core WebApi使用Swagger生成api说明文档看这篇就够了

    引言 在使用asp.net core 进行api开发完成后,书写api说明文档对于程序员来说想必是件很痛苦的事情吧,但文档又必须写,而且文档的格式如果没有具体要求的话,最终完成的文档则完全取决于开发者 ...

  8. ASP.NET Core WebApi使用Swagger生成api说明文档

    1. Swagger是什么? Swagger 是一个规范和完整的框架,用于生成.描述.调用和可视化 RESTful 风格的 Web 服务.总体目标是使客户端和文件系统作为服务器以同样的速度来更新.文件 ...

  9. 【转】ASP.NET Core WebApi使用Swagger生成api说明文档看这篇就够了

    原文链接:https://www.cnblogs.com/yilezhu/p/9241261.html 引言 在使用asp.net core 进行api开发完成后,书写api说明文档对于程序员来说想必 ...

随机推荐

  1. 对于ES6中Promise的个人见解

    1.js中常见的异步 JavaScript可以响应用户的一些异步交互,比如单击鼠标和按键盘等操作. let button = document.getElementById("btn&quo ...

  2. 网页加速特技之 AMP

    据统计,40%的人会放弃使用加载时间超过3秒的网站.对于加载慢的页面我也是没耐心等待的,同类型网站那么多,为什么不选择加载速度更快体验更好的呢.为了解决网页加载慢的问题,Google联合数十家技术机构 ...

  3. 关于c# SESSION丢失问题解决办法

    我们在用C#开发程序的时候经常会遇到Session很不稳定,老是数据丢失.下面就是Session数据丢失的解决办法希望对您有好处.1.在WEB.CONFIG文件中修改SESSION状态保存模式,如:& ...

  4. HDnoip2017题解

    那么,作为一名初入信息竞赛的选手,我也试着开始用博客记录自己的学习历程,那么这篇文章先简单介绍一下我自己吧. 本人开始学习信息学大概以来,主要都是用的C++,所以对其他语言并不是十分熟悉.2016我还 ...

  5. eclipse中hibernate和mybatis中xml配置文件的没有标签提醒解决方法

    当我们使用eclipse编写Mybatis或hibernate的xml文件时,面对众多标签的配置文件,却没有自动提醒,对于工作和学习都十分不方便. 之所以没有自动提醒,是因为dtd文件没有加载成功. ...

  6. Linux系列教程(二十四)——Linux的系统管理

    上篇博客介绍了Linux的服务管理,不管是以RPM包安装的服务,还是通过源码包安装的服务,万能启动服务的方法都可以通过 /绝对路径/启动脚本名 start .而通过 RPM 包安装的服务还可以通过 s ...

  7. C# 串口接收数据中serialPort.close()死锁

    最近在做一个有关高铁模拟仓显示系统的客户端程序,在这个程序中要运用串口serialPort传输数据,因为每次接收数据结束后要更新UI界面,所以就用到了的Invoke,将更新UI的程序代码封装到一个方法 ...

  8. lua API函数大全

    Lua5.1中的API函数 lua_State* luaL_newstate()Lua脚本的编译执行是相互独立的,在不同的线程上执行.通过luaL_newstate()函数可以申请一个虚拟机,返回指针 ...

  9. spring中的自定义标签

    为了给系统提供可配置化支持,一般会用原生态的方式去解析定义好的XML文件,然后转化为配置对象.这种方式对于简单.单一的配置文件,或者是XML配置格式固定的配置文件,比较容易处理.但是对于一些配置非常复 ...

  10. 查找算法(Java实现)

    1.二分查找算法 package other; public class BinarySearch { /* * 循环实现二分查找算法arr 已排好序的数组x 需要查找的数-1 无法查到数据 */ p ...