我找到了一个解决方案,可以在没有 java 命令但使用 node 命令的情况下为 Angular 2 TypeScript 生成客户端 API。
从 swagger.yaml 生成 typescript angular 客户端的示例节点脚本。请注意,我们使用 http。如果使用 https,请求无法验证第一个证书(在撰写本文时)
这是 app.js
var fs = require('fs');
var path = require('path');
var jsYaml = require('js-yaml');
var request = require('request');
var unzip = require('unzip2');
var codeGenEndpoint = 'http://generator.swagger.io/api/gen/clients';
var language = 'typescript-angular2';
fs.readFile(path.resolve('swagger.yaml'), 'utf8', function (error, yaml) {
if (error) {
throw error;
}
var swaggerObj = jsYaml.load(yaml);
var postBody = {
spec: swaggerObj,
options: {
modelPropertyNaming: 'camelCase',
apiPackage: 'api.clients.settings',
modelPackage: 'api.clients.settings'
}
};
request.post({
url: codeGenEndpoint + '/' + language,
body: JSON.stringify(postBody),
headers: {
'Content-Type': 'application/json'
}
}, function(error, response, body){
if (error) {
throw error;
}
if (response.statusCode !== 200) {
throw new Error('Response code was not 200. ' + body)
}
var responseObj = JSON.parse(body);
request({
url: responseObj.link,
encoding: null
}).pipe(unzip.Extract({ path: 'src/client/js/codegen/settingsApi'}));
});
});
我只是将变量设置language
为'typescript-angular2
'。之后node app.js
有关可用客户端语言的列表,请访问http://generator.swagger.io/api/gen/clients
有关更多详细信息:https ://github.com/swagger-api/swagger-codegen/wiki/FAQ
部分生成器服务