1、创建WebAPI项目解决方案

2、使用nuget引入Swashbuckle包

引入Swashbuckle包后App_Start文件夹下会多出一个SwaggerConfig文件

3、添加接口注释

项目属性->生成,勾选生成xml文档文件(有些太古老的WebSite项目不支持注释功能,因为根本没有生成xml这一个选项)

生成xml文档后在SwaggerConfig文件里加入配置

  1. var xmlAPI = $@"{AppDomain.CurrentDomain.BaseDirectory}\bin\WebApplication.xml";

包含xml注释,在.EnableSwagger里找到c.IncludeXmlComments并传入刚才添加的xml路径,此处是(XMLAPI)

  1. .EnableSwagger(c=>{
      c.IncludeXmlComments(xmlAPI);
    })

到此已经可以运行项目并且可以看到注释,在浏览器地址栏输入http://xxx/Swagger回车即可

现在看到的文档界面都是英文的,接下来进行汉化

4、汉化

  4.1创建js文件,把下面的js代码放入到项目里

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

右击刚才创建的js文件,选择属性,生成操作改为嵌入的资源

SwaggerConfig文件里加入配置

  1. .EnableSwaggerUi(c =>{
  2.  //路径规则,项目命名空间.文件夹名称.js文件名称
  3.   c.InjectJavaScript(thisAssembly, "WebApplication.Scripts.swagger-ui-zh-cn.js");
  4. })

  4.2、控制器描述和接口文档缓存

在App_Start目录下创建类文件CachingSwaggerProvider

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

SwaggerConfig文件里加入配置

  1. .EnableSwagger(c=>{
  2.   c.CustomProvider((defaultProvider) => new CachingSwaggerProvider(defaultProvider,xmlAPI));
  3. })

  4.3、action 方法名称相同处理

  1. .EnableSwagger(c=>{
  2.   c.ResolveConflictingActions(apiDescriptions => apiDescriptions.First());
  3. })

5、一个Controller不支持多个Get/Post请求问题,修改WebApiConfig.cs

打开 App_Start目录下的WebApiConfig文件

 

MVC项目集成swagger的更多相关文章

  1. 项目集成swagger,并暴露指定端点给swagger

    项目集成swagger 一:思考: 1.swagger解决了我们什么问题? 传统开发中,我们在开发完成一个接口后,为了测试我们的接口,我们通常会编写单元测试,以测试我们的接口的可用性,或者用postm ...

  2. Maven + SpringMVC项目集成Swagger

    Swagger 是一个规范和完整的框架,用于生成.描述.调用和可视化 RESTful 风格的 Web 服务.总体目标是使客户端和文件系统作为服务器以同样的速度来更新.文件的方法,参数和模型紧密集成到服 ...

  3. DryIoc mvc 项目集成

    据IOC性能测试排名,DryIoc是目前运行性能最好的依赖注入组件. 详情参考:https://bitbucket.org/dadhi/dryioc/ 下面一步一步搭建我们的DryIoc 的mvc项目 ...

  4. 项目集成swagger【转载】

    地址链接:https://blog.csdn.net/lx1309244704/article/details/81808788 swagger是一款高效易用的嵌入式文档插件,同时支持在线测试接口,快 ...

  5. 【Spring Boot&&Spring Cloud系列】Spring Boot项目集成Swagger UI

    前言 Swagger 是一个规范和完整的框架,用于生成.描述.调用和可视化 RESTful 风格的 Web 服务.总体目标是使客户端和文件系统作为服务器以同样的速度来更新.文件的方法,参数和模型紧密集 ...

  6. SpringBoot项目集成swagger报NumberFormatException: For input string: ""

    java.lang.NumberFormatException: For input string: "" at java.lang.NumberFormatException.f ...

  7. springboot (spring mvc)集成swagger

    最近用springboot构建rest接口,考虑到最方便的验证接口,想到了引入swagger. 基本的步骤大致如下: 1.pom中引入swagger依赖: <dependency> < ...

  8. SpringBoot+SpringCloud+vue+Element开发项目——集成Swagger文档

    在pom.xml文件中添加Maven依赖 <!--swagger--> <dependency> <groupId>io.springfox</groupId ...

  9. SpringBoot项目集成Swagger启动报错: Failed to start bean 'documentationPluginsBootstrapper'; nested exception is

    使用的Swagger版本是2.9.2.knife4j版本是2.0.4. SpringBoot 版本是2.6.2将SpringBoot版本回退到2.5.6就可以正常启动

随机推荐

  1. POJ 1252 Euro Efficiency ( 完全背包变形 && 物品重量为负 )

    题意 : 给出 6 枚硬币的面值,然后要求求出对于 1~100 要用所给硬币凑出这 100 个面值且要求所用的硬币数都是最少的,问你最后使用硬币的平均个数以及对于单个面值所用硬币的最大数. 分析 :  ...

  2. CF 546 B Soldier and Badges(贪心)

    原题链接:http://codeforces.com/problemset/problem/546/B 原题描述: Soldier and Badges Colonel has n badges. H ...

  3. String、StringBuffer与StringBuilder介绍

    关于这三个类在字符串处理中的位置不言而喻,那么他们到底有什么优缺点,到底什么时候该用谁呢?下面我们从以下几点说明一下 1.三者在执行速度方面的比较:     StringBuilder > St ...

  4. Oracle Or子句

    Oracle Or子句 作者:初生不惑 Oracle基础 评论:0 条 Oracle技术QQ群:175248146 在本教程中,我们来学习如何使用Oracle OR运算符来组合两个或更多的布尔表达式. ...

  5. IDEA 创建spring boot 的Hello World 项目

    1.Open IDEA,choose "New-->Project" 2.Choose "Spring Initializr" 3. Choose jav ...

  6. 大数据笔记(一)——Hadoop的起源与背景知识

    一.大数据的5个特征(IBM提出): Volume(大量) Velocity(高速) Variety(多样) Value(价值) Varacity(真实性) 二.OLTP与OLAP 1.OLTP:联机 ...

  7. 8 Django模型层(1)

    知识预览 ore简介 单表操作 章节作业 ore简介 MVC或者MVC框架中包括一个重要的部分,就是ORM,它实现了数据模型与数据库的解耦,即数据模型的设计不需要依赖于特定的数据库,通过简单的配置就可 ...

  8. 消息队列之 ActiveMQ

    简介 ActiveMQ 特点 ActiveMQ 是由 Apache 出品的一款开源消息中间件,旨在为应用程序提供高效.可扩展.稳定.安全的企业级消息通信. 它的设计目标是提供标准的.面向消息的.多语言 ...

  9. CSS- 层叠和继承

    层叠和继承 - 学习 Web 开发 | MDN 优先级 - CSS:层叠样式表 | MDN 继承 - CSS:层叠样式表 | MDN CSS 层叠 - CSS:层叠样式表 | MDN

  10. Matplotlib字体大小设置

    参考:https://blog.csdn.net/henkekao/article/details/72871882 ax = plt.subplot(111) # 设置刻度字体大小 plt.xtic ...