如何使用 swagger-node 生成/使用 XML

Posted

技术标签:

【中文标题】如何使用 swagger-node 生成/使用 XML【英文标题】:How to produce/consume XML using swagger-node 【发布时间】:2015-10-02 01:51:24 【问题描述】:

我是使用 swagger-node (swagger-spec 2.0) 的新手,我需要我的 API 来使用和生成 XML 和 JSON(因为这是客户想要的)。目前我只关注“生产”部分。

在生成响应时,我知道我可以使用 jstoxml 或 easyxml 等工具将我的 js 对象转换为 XML。所以问题是:在使用 swagger-node 时这是否必要,或者工具是否应该处理这个问题?我想我需要帮助我的控制器代码应该返回什么。

例如,使用 swagger 创建一个新项目 swagger project create myproject (choose express framework)

更改 /hello api 的 yaml 文件,以便 get: 返回 json 或 xml

paths:
  /hello:
    # binds a127 app logic to a route
    x-swagger-router-controller: hello_world
    get:
      description: Returns 'Hello' to the caller
      # used as the method name of the controller
      operationId: hello
      produces:
        - application/json
        - application/xml

然后更改 hello_world.js 控制器以返回 json 对象而不是字符串

  // variables defined in the Swagger document can be referenced using req.swagger.params.parameter_name
  var name = req.swagger.params.name.value || 'stranger';
  var hello = util.format('Hello, %s!', name);

  // this sends back a JSON response which is a single string
  res.json(message:hello);

当我启动项目并使用带有 Header Accept = application/json 的 Postman 我得到了回应:


    "message": "Hello, stranger!"

如果我更改标头 Accept application/xml,我仍然会收到 JSON 响应,而不是 XML。我希望看到的是:

<object>
<message>Hello, stranger!</message>
</object>

我知道我的代码使用 res.json() 是错误的,因为我相信它将 Content-Type 设置为 application/json

我不知道还可以使用什么来生成 XML 响应。当我更改 res.json() 以使用 easyxml

var xml = easyxml.render(message:hello);
res.type('xml').end(xml);

然后我从 swagger 那里得到一个验证错误:

[
  
    "status": 500,
    "message": "Response validation failed: value expected to be an array/object but is not"
  
]

那么我的控制器应该如何格式化响应以返回 XML 或 JSON?

【问题讨论】:

【参考方案1】:

我不确定 easyxml 正在做什么或为什么它不起作用,但 jstoxml 效果很好:

var jstoxml = require('jstoxml');
var express = require('express');
var util = require('util');
var app = express();

app.get('/', function(req, res) 
    var name = 'stranger';
    var hello = 
        object: 
            message: util.format('Hello, %s!', name)
        
    ;
    if (req.headers.accept === 'application/xml') 
        res.type('xml')
        res.end(jstoxml.toXML(hello));
     else 
        res.json(hello);
    
);

app.listen(process.env.PORT || 8100);

接受:application/json


    "object": 
    
        "message": "Hello, stranger!"
    

接受:应用程序/xml

<object>
    <message>Hello, stranger!</message>
</object>

【讨论】:

我相信问题不仅仅是让 express 以有效的 xml 响应,而且我从 swagger 那里得到了与 Greg 相同的验证错误(使用 js2xmlparser 生成 xml)。我认为这与 swagger.yaml 或 swagger.json 文件未正确定义响应模式有关,因为它似乎需要一个对象或数组而不是 xml 字符串。在我的 swagger.yaml 中,我尝试添加以下内容,但仍然没有运气:produces: - application/json - application/xml【参考方案2】:

显然有没有正确的方法。 remus 的回答没有考虑到Swagger explicit XML support。 在任何情况下,控制器绝对不应该弄乱 API i/o 格式,而只是实现业务逻辑。

【讨论】:

以上是关于如何使用 swagger-node 生成/使用 XML的主要内容,如果未能解决你的问题,请参考以下文章

如何使用 Maven 3.x 为 findbugs 生成 html 报告

如何在 Play 2.2.x 的 dist 任务中禁用 ScalaDoc 生成(使用 project/build.scala)?

如何使用 jaxb2-maven-plugin 2.x 从 WSDL 生成 Java 类?

如何使用 spring boot 插件 2.0.x 从一个具有不同依赖项的 gradle 项目生成 2 个 jars

如何从openssl生成的密钥生成X.509证书

如何使用spring boot plugin 2.0.x从一个具有不同依赖项的gradle项目生成2个jar