app.js 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. var createError = require('http-errors');
  2. var express = require('express');
  3. var path = require('path');
  4. var cookieParser = require('cookie-parser');
  5. var logger = require('morgan');
  6. var indexRouter = require('./routes/index');
  7. require('./db/mysql')
  8. var app = express();
  9. // 配置跨域中间件
  10. app.use((req, res, next) => {
  11. // 允许所有来源访问,生产环境应谨慎设置,可替换为具体域名
  12. res.setHeader('Access-Control-Allow-Origin', '*');
  13. // 允许的请求方法
  14. res.setHeader('Access-Control-Allow-Methods', 'GET, POST, PUT, DELETE, OPTIONS');
  15. // 允许的请求头
  16. res.setHeader('Access-Control-Allow-Headers', 'Content-Type, Authorization');
  17. // 处理 OPTIONS 预检请求,直接返回 204 状态码
  18. if (req.method === 'OPTIONS') {
  19. res.sendStatus(204);
  20. } else {
  21. next();
  22. }
  23. });
  24. // view engine setup
  25. // app.set('views', path.join(__dirname, 'views'));
  26. // app.set('view engine', 'jade');
  27. app.use(logger('dev'));//日志
  28. app.use(express.json());//json格式传输
  29. app.use(express.urlencoded({ extended: false }));
  30. app.use(cookieParser());
  31. // app.use(express.static(path.join(__dirname, 'public')));
  32. app.use('/data', indexRouter);
  33. // catch 404 and forward to error handler
  34. app.use(function(req, res, next) {
  35. next(createError(404));
  36. });
  37. // error handler
  38. app.use(function(err, req, res, next) {
  39. // set locals, only providing error in development
  40. res.locals.message = err.message;
  41. res.locals.error = req.app.get('env') === 'development' ? err : {};
  42. // render the error page
  43. res.status(err.status || 500);
  44. res.render('error');
  45. });
  46. module.exports = app;