我使用Swagger Yaml描述了一个端点并生成了模拟服务器。现有端点(我在嘲笑)没有100%遵循RESTful原则,因此我只想覆盖由模拟服务器返回的响应。简单的服务器代码如下所示:
var swagger = require('swagger-server');
var server = swagger('map-cache.yaml');
var port = 7072;
server.post('/map-qa_trunk/v2/getData', function(req, res, next) {
var foo = {
err : 123,
msg : "error message"
};
res.json(foo);
});
server.listen(port, function() {
console.log('Map Cache Mock Server is now running at http://localhost:' + port);
});
在Yaml定义中,有一个定义为MapResponseData的对象,如何创建该对象的实例,以便可以根据需要填充该对象并返回res.json()?类似于以下内容:
var response = getMapResponseData(); // don't know what this call should be
response.fieldA = 123;
res.json(response);
我猜这应该是可能的,因为Swagger解析了YAML文件,并且知道所有指定的定义。
尝试将请求对象输出到console.log,以查看是否可以找到对swagger定义的引用。另一个选择是从yaml文件中提取已解析的swagger定义(例如,使用js-yaml)并从中提取。
但是,我最好的建议是使用swagger-tools而不是swagger-server。swagger-server软件包是alpha版本,与swagger-tools相比,具有更少的下载,修订和用户。swagger-tools的好处是将得到积极维护,并且有一个更大的社区可以为您提供支持。要将项目转换为swagger-tools,请使用swagger.io> Swagger编辑器>在线编辑器>左窗格中的粘贴yaml>生成服务器> Node.js
在swagger-tools中,整个Swagger Yaml定义包含在每个请求对象中:
req.swagger.swaggerObject
并且您可以根据需要从中提取响应对象的定义。
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句