1.引入Swashbuckle包

2.添加汉化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

3.修改配置文件SwaggerConfig

4.获取注释

SwaggerConfig添加配置

5.补充

方法要配置Route特性

效果

Swagger(webapi自动生成接口说明文档)的更多相关文章

  1. WebApi使用swagger ui自动生成接口文档

    之前就写到.最近正在使用webapi.这里介绍一个实用的东西swageer ui现在开发都是前后端分开.我们这里是给前端提供api.有时候对于一个api的描述,并不想专门写一份文档.很浪费时间.swa ...

  2. weiapi2.2 HelpPage自动生成接口说明文档和接口测试功能

    在开发Webapi项目时每写完一个方法时,是不是需要添加相应的功能说明和测试案例呢?为了更简单方便的写说明接口文档和接口测试HelpPage提供了一个方便的途径. 她的大致原理是:在编译时会生成.dl ...

  3. spring boot 中使用swagger 来自动生成接口文档

    1.依赖包 <dependency> <groupId>io.springfox</groupId> <artifactId>springfox-swa ...

  4. .net core 使用swagger自动生成接口文档

     前言 swagger是一个api文档自动生动工具,还集成了在线调试. 可以为项目自动生成接口文档, 非常的方便快捷 Swashbuckle.AspNetCore 是一个开源项目,用于生成 ASP.N ...

  5. Spring Boot(九)Swagger2自动生成接口文档和Mock模拟数据

    一.简介 在当下这个前后端分离的技术趋势下,前端工程师过度依赖后端工程师的接口和数据,给开发带来了两大问题: 问题一.后端接口查看难:要怎么调用?参数怎么传递?有几个参数?参数都代表什么含义? 问题二 ...

  6. Spring Boot Swagger2自动生成接口文档

    一.简介 在当下这个前后端分离的技术趋势下,前端工程师过度依赖后端工程师的接口和数据,给开发带来了两大问题: 1.问题一.后端接口查看难:要怎么调用?参数怎么传递?有几个参数?参数都代表什么含义? 2 ...

  7. JApiDocs(自动生成接口文档神器)

    JApiDocs教程 前言 作为一名优秀的程序员来说,由于涉及到要与前端进行对接,所以避免不了的就是写接口文档.写完接口文档,一旦代码返回结果,参数等出现变动,接口文档还得随之改动,十分麻烦,违背了我 ...

  8. [Django REST framework - 自动生成接口文档、分页]

    [Django REST framework - 自动生成接口文档.分页] 自动生成接口文档 # 后端人员写好接口,编写接口文档,给前端人员看,前端人员依照接口文档开发 # 公司里主流 -后端,使用w ...

  9. rbac介绍、自动生成接口文档、jwt介绍与快速签发认证、jwt定制返回格式

    今日内容概要 RBAC 自动生成接口文档 jwt介绍与快速使用 jwt定制返回格式 jwt源码分析 内容详细 1.RBAC(重要) # RBAC 是基于角色的访问控制(Role-Based Acces ...

随机推荐

  1. 深入理解JSX

    本文由笔者翻译自官方文档的JSX In Depth,若干案例经过了改写.其实说白了也好像不算太深入,但还是提示了一些可能的盲区. JSX是为构造React元素方法React.createElement ...

  2. java创建文件和目录

    java创建文件和目录 2013-09-04 12:56 99933人阅读 评论(7) 收藏 举报  分类: JAVA基础(10)  版权声明:本文为博主原创文章,未经博主允许不得转载. 创建文件和目 ...

  3. mysql-proxy 读写分离

    mysql-proxy 读写分离 主从复制 MySQL Replication可以将master的数据复制分布到多个slave上,然后利用slave来分担master的读压力. 读写分离 MySQL- ...

  4. Linux 新手的学习笔记

    系统分区: MBR分区(主分区不超过4个,单个分区不超过2TB) fdisk -l fdisk /dev/sdb n(添加一个分区)p(添加一个主分区,主分区)e(添加一个扩展分区)l(添加一个逻辑分 ...

  5. 利用exp/imp备份恢复数据库实例

    用exp/imp备份数据库: Oracle数据导入导出imp/exp功能:Oracle数据导入导出imp/exp就相当与oracle数据还原与备份. 大多情况都可以用Oracle数据导入导出完成数据的 ...

  6. window.open打开新窗口被浏览器拦截的处理方法

    一般我们在打开页面的时候, 最常用的就是用<a>标签,如果是新窗口打开就价格target="_blank"属性就可以了, 如果只是刷新当前页面就用window.loca ...

  7. MATLAB-RSP 随笔

    1.Getting Started with Signal Analyzer App 161216 (1) 在命令行中输入:signalAnalyzer. (2)在工作空间中选择要分析的信号

  8. 利用Java代码在某些时刻创建Spring上下文

    上一篇中,描述了如何使用Spring隐式的创建bean,但当我们需要引进第三方类库添加到我们的逻辑上时,@Conponent与@Autowired是无法添加到类上的,这时,自动装配便不适用了,我们需要 ...

  9. js拖拽效果实现

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  10. new Array(n) 的坑 密集数组和稀疏数组

    今天写Vue时遇到一个奇怪问题,需要监控网页上的input 是否都有值 // var blanks = new Array(number); // blanks的监控属性 var emptyNumbe ...