app.js 1.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. import express from 'express';
  2. import db from './mongodb/db.js';
  3. import config from 'config-lite';
  4. import router from './routes/index.js';
  5. import session from 'express-session';
  6. import connectMongo from 'connect-mongo';
  7. import winston from 'winston';
  8. import expressWinston from 'express-winston';
  9. import path from 'path';
  10. const app = express();
  11. app.use(express.static('./public'));
  12. app.all('*', (req, res, next) => {
  13. res.header("Access-Control-Allow-Origin", req.headers.origin);
  14. res.header("Access-Control-Allow-Headers", "Content-Type, Authorization, X-Requested-With");
  15. res.header("Access-Control-Allow-Methods","PUT,POST,GET,DELETE,OPTIONS");
  16. res.header("Access-Control-Allow-Credentials", true); //可以带cookies
  17. res.header("X-Powered-By",' 3.2.1')
  18. if (req.method == 'OPTIONS') {
  19. res.send(200);
  20. } else {
  21. next();
  22. }
  23. });
  24. const MongoStore = connectMongo(session);
  25. app.use(session({
  26. name: config.session.name,
  27. secret: config.session.secret,
  28. resave: true,
  29. saveUninitialized: false,
  30. cookie: config.session.cookie,
  31. store: new MongoStore({
  32. url: config.url
  33. })
  34. }))
  35. // app.use(expressWinston.logger({
  36. // transports: [
  37. // new (winston.transports.Console)({
  38. // json: true,
  39. // colorize: true
  40. // }),
  41. // new winston.transports.File({
  42. // filename: 'logs/success.log'
  43. // })
  44. // ]
  45. // }));
  46. router(app);
  47. // app.use(expressWinston.errorLogger({
  48. // transports: [
  49. // new winston.transports.Console({
  50. // json: true,
  51. // colorize: true
  52. // }),
  53. // new winston.transports.File({
  54. // filename: 'logs/error.log'
  55. // })
  56. // ]
  57. // }));
  58. app.use((err, req, res, next) => {
  59. res.status(404).send('未找到当前路由');
  60. });
  61. app.listen(config.port);