node.js - Nodejs 中 swagger-jsdoc 设置的语法错误

标签 node.js express swagger swagger-ui swagger-jsdocs

我在尝试使用我的 Express 应用程序设置 swagger 时遇到语法错误

我试图在这里学习本教程 https://itnext.io/setting-up-swagger-in-a-node-js-application-d3c4d7aa56d4作为快速入门指南,我不知道为什么会收到该错误

这是我的 app.js

import 'regenerator-runtime/runtime';
import express from 'express';
import bodyParser from 'body-parser';
import cors from 'cors';
import swaggerUI from 'swagger-ui-express';
import swaggerJSDocs from 'swagger-jsdoc';
import allRoutes from './routes';


const definitions = {
  info: {
    // API information (required)
    title: 'Wayfarer', // Title (required)
    version: '1.0.0', // Version (required)
  },
  securityDefinitions: {
    bearerAuth: {
      type: 'apiKey',
      name: 'Authorization',
      scheme: 'bearer',
      in: 'header',
    },
  },
};

const options = {
  definitions,
  apis: ['./routes/index.js'],
};

const swaggerSpec = swaggerJSDocs(options);

const app = express();

app.get('/swagger.json', (req, res) => {
  res.setHeader('Content-Type', 'application/json');
  res.send(swaggerSpec);
});
app.use('/api-docs', swaggerUI.serve, swaggerUI.setup(swaggerSpec));
app.use(cors());
app.use(bodyParser.urlencoded({
  extended: true,
}));
app.use(bodyParser.json());

allRoutes(app);

export default app;

这是我在 ./routes/index.js 的路线

import userRouter from './users';
import busRouter from './buses';
import tripRouter from './trips';

const versionNumber = '/api/v1';

export default (app) => {
  app.use(versionNumber, userRouter);
  app.use(versionNumber, busRouter);
  app.use(versionNumber, tripRouter);
};

其中一条路线例如./routes/users

import router from './router';
import userMiddleware from '../middleware/users';

router.post('/auth/signup', userMiddleware.signupClients(), userController.signUp.bind(userController));

router.post('/auth/signin', userMiddleware.signinClients(), userController.signinClients.bind(userController));

router.post('/auth/signin/admin', userMiddleware.signinAdmin(), userController.signinAdmin.bind(userController));

export default router;

我按照说明进行操作,我的应用程序应该可以正常工作,但我得到了 Error: SyntaxError: Unexpected token u in JSON at position 0 at module.exports (/home/frank/Desktop/Web Dev/Git projects/Way-Farer/node_modules/swagger-jsdoc/lib/index.js:32:11) at Object.<anonymous> (/home/frank/Desktop/Web Dev/Git projects/Way-Farer/api/src/app.js:32:21)错误

最佳答案

在 app.js 中,将 definitions(复数)更改为 definition(单数)。 swagger-jsdoc expects包含 API 定义的选项命名为 options.swaggerDefinitionoptions.definition

const definition = {  // <-----
  ...
};

const options = {
  definition,      // <-----
  apis: ['./routes/index.js'],
};

关于node.js - Nodejs 中 swagger-jsdoc 设置的语法错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56968662/

相关文章:

javascript - 带有 express.js 的 jquery-file-upload-middleware : how to move files & add watermarks?

node.js - 如何通过web3使用私钥登录以太坊账户?

Spring Data Rest、SpringFox 和 JpaRepository 自定义查找器

python - 使用 flask restplus 进行 api 记录的特定时间格式

node.js - 使用 findOne 然后 save() 替换文档,mongoose

node.js - 添加或更新在spurCommerce中不起作用的产品

javascript - 您将如何测试此路由代码?

node.js - Mongoose 中干净的版本控制/更改历史记录实现

C#NSwag和带有Enums的swagger-codegen

node.js - 在 Node.js 中记录每个请求