【问题标题】:spring mvc swaggger ui getting xml response but the swagger ui requires json formatspring mvc swagger ui 获得 xml 响应,但 swagger ui 需要 json 格式
【发布时间】:2016-04-01 05:08:08
【问题描述】:

前天我知道了swagger。它太棒了。但可能是因为我缺乏知识,所以我无法做到。我努力解决它,最后我把它作为一个问题放在这里。

我的 pom.xml

<dependency>

        <groupId>com.mangofactory</groupId>

        <artifactId>swagger-springmvc</artifactId>

        <version>0.5.2</version>

 </dependency>

我已经添加了这个依赖。 我的 servlet-context.xml 如下。我确实绑定了 swagger 配置 bean 并启用了此配置配置。

<!-- Configuration Bean -->


<bean id="documentationConfig" class="com.mangofactory.swagger.configuration.DocumentationConfig"/>
<context:annotation-config />

<mvc:default-servlet-handler/>

使用以下条目创建 swagger.properties。

documentation.services.version=1.0
documentation.services.basePath=http://localhost:8080/swagger

并在 myapplication 上下文中包含与包含任何其他属性文件的方式相同的内容。

<context:property-placeholder location="classpath:/swagger.properties" />

我的控制器记录 api 及其方法

@Controller    

@Api(value="onlinestore", description="Operations pertaining to Online Store")

@RequestMapping(value="/onlinestore")       

public class OnlineStoreController {

@Autowired

private IStoreFront storeFrontService;           

@ApiOperation(value = "View the Specific info of the product")

@RequestMapping(value="/authorize/viewProduct/{productid}", method=RequestMethod.GET)     

public ResponseEntity<Object> viewProduct(@ApiParam(name="productId", value="The Id of the product to be viewed", required=true)

现在通过点击以下链接,我可以看到文档

http://localhost:8080/swagger/api-docs

结果如下

<ApiDocumentation>
<apiVersion>1.0</apiVersion>
<apis>
<description>Operations pertaining to Online Store</description>
<path>/api-docs/onlinestore</path>
</apis>
<basePath>http://localhost:8080/swagger</basePath>
<swaggerVersion>1.0</swaggerVersion>
</ApiDocumentation>

它返回 xml 格式。然后我使用以下链接 https://github.com/swagger-api/swagger-ui 集成了招摇 UI。 index.html 页面如下:

<!DOCTYPE html>
<html>
<head>
  <meta charset="UTF-8">
  <title>Swagger UI</title>
  <link rel="icon" type="image/png" href="images/favicon-32x32.png" sizes="32x32" />
  <link rel="icon" type="image/png" href="images/favicon-16x16.png" sizes="16x16" />
  <link href='css/typography.css' media='screen' rel='stylesheet' type='text/css'/>
  <link href='css/reset.css' media='screen' rel='stylesheet' type='text/css'/>
  <link href='css/screen.css' media='screen' rel='stylesheet' type='text/css'/>
  <link href='css/reset.css' media='print' rel='stylesheet' type='text/css'/>
  <link href='css/print.css' media='print' rel='stylesheet' type='text/css'/>
  <script src='lib/jquery-1.8.0.min.js' type='text/javascript'></script>
  <script src='lib/jquery.slideto.min.js' type='text/javascript'></script>
  <script src='lib/jquery.wiggle.min.js' type='text/javascript'></script>
  <script src='lib/jquery.ba-bbq.min.js' type='text/javascript'></script>
  <script src='lib/handlebars-2.0.0.js' type='text/javascript'></script>
  <script src='lib/js-yaml.min.js' type='text/javascript'></script>
  <script src='lib/lodash.min.js' type='text/javascript'></script>
  <script src='lib/backbone-min.js' type='text/javascript'></script>
  <script src='swagger-ui.js' type='text/javascript'></script>
  <script src='lib/highlight.9.1.0.pack.js' type='text/javascript'></script>
  <script src='lib/highlight.9.1.0.pack_extended.js' type='text/javascript'></script>
  <script src='lib/jsoneditor.min.js' type='text/javascript'></script>
  <script src='lib/marked.js' type='text/javascript'></script>
  <script src='lib/swagger-oauth.js' type='text/javascript'></script>

  <!-- Some basic translations -->
  <!-- <script src='lang/translator.js' type='text/javascript'></script> -->
  <!-- <script src='lang/ru.js' type='text/javascript'></script> -->
  <!-- <script src='lang/en.js' type='text/javascript'></script> -->

  <script type="text/javascript">
    $(function () {
      var url = window.location.search.match(/url=([^&]+)/);
      if (url && url.length > 1) {
        url = decodeURIComponent(url[1]);
      } else {
        url = "http://localhost:8080/swagger/api-docs";
      }

      hljs.configure({
        highlightSizeThreshold: 5000
      });

      // Pre load translate...
      if(window.SwaggerTranslator) {
        window.SwaggerTranslator.translate();
      }
      window.swaggerUi = new SwaggerUi({
        url: url,
        dom_id: "swagger-ui-container",
        supportedSubmitMethods: ['get', 'post', 'put', 'delete', 'patch'],
        onComplete: function(swaggerApi, swaggerUi){
          if(typeof initOAuth == "function") {
            initOAuth({
              clientId: "your-client-id",
              clientSecret: "your-client-secret-if-required",
              realm: "your-realms",
              appName: "your-app-name",
              scopeSeparator: ",",
              additionalQueryStringParams: {}
            });
          }

          if(window.SwaggerTranslator) {
            window.SwaggerTranslator.translate();
          }
        },
        onFailure: function(data) {
          log("Unable to Load SwaggerUI");
        },
        docExpansion: "none",
        jsonEditor: false,
        defaultModelRendering: 'schema',
        showRequestHeaders: false
      });

      window.swaggerUi.load();

      function log() {
        if ('console' in window) {
          console.log.apply(console, arguments);
        }
      }
  });
  </script>
</head>

<body class="swagger-section">
<div id='header'>
  <div class="swagger-ui-wrap">
    <a id="logo" href="http://swagger.io"><img class="logo__img" alt="swagger" height="30" width="30" src="images/logo_small.png" /><span class="logo__title">swagger</span></a>
    <form id='api_selector'>
      <div class='input'><input placeholder="http://example.com/api" id="input_baseUrl" name="baseUrl" type="text"/></div>
      <div id='auth_container'></div>
      <div class='input'><a id="explore" class="header__btn" href="#" data-sw-translate>Explore</a></div>
    </form>
  </div>
</div>

<div id="message-bar" class="swagger-ui-wrap" data-sw-translate>&nbsp;</div>
<div id="swagger-ui-container" class="swagger-ui-wrap"></div>
</body>
</html>

现在当我点击这个链接http://localhost:8080/swagger/dist/index.html

我得到如上。很明显,它告诉我它期待 json 但将 xml 作为输入作为http://localhost:8080/swagger/api-docs 正在返回 xml。它正在期待这样的事情:

{ “API 文档”:{ "apiVersion": "1.0", “API”:{ "description": "与网上商店有关的操作", “路径”:“/api-docs/onlinestore” }, "basePath": "http://localhost:8080/onlineStore", “招摇版本”:“1.0” } }

我无法理解我哪里出错了。

【问题讨论】:

    标签: spring-mvc swagger swagger-ui


    【解决方案1】:

    您需要首先确保您的服务器配置为生成 JSON:

    curl -H Accept:application/json http://localhost:8080/swagger/api-docs
    

    如果您没有返回 JSON,则说明您存在服务器配置问题。如果这显示 JSON,则您的服务器可能需要一个不同的 Accept 标头,例如 application/json;charset=UTF8,在这种情况下,您可以告诉 swagger-ui 发送它,而不仅仅是 application/json

     window.swaggerUi = new SwaggerUi({
        url: url,
        swaggerRequestHeaders: 'application/json;charset=UTF8',
        // ...
    

    【讨论】:

    • 我确实添加了 swaggerRequestHeaders:'application/json;charset=UTF8'。我得到以下结果: 406 : Apache Tomcat/8.0.20 - 错误报告
    • curl -H Accept:application/json localhost:8080/swagger/api-docs 也给出了上面的 E:\Softwares\curl-7.47.0-win64-mingw\bin>curl -H Accept:application/json @987654323 @ Apache Tomcat/8.0.20 - 错误报告.......

      说明 此请求标识的资源只能生成具有根据请求“接受”标头 s 不可接受的特征的响应。


      Apache Tomcat/8.0. 20

      E:\Softwares\curl-7.47.0-win64-mingw\bin>
    猜你喜欢
    • 1970-01-01
    • 2021-03-29
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2020-11-11
    • 1970-01-01
    相关资源
    最近更新 更多