app.js 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  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 flash from 'connect-flash';
  8. import winston from 'winston';
  9. import expressWinston from 'express-winston';
  10. import path from 'path';
  11. const app = express();
  12. app.use(express.static('./public'));
  13. app.all('*', (req, res, next) => {
  14. res.header("Access-Control-Allow-Origin", "*");
  15. res.header("Access-Control-Allow-Headers", "Content-Type, Authorization, X-Requested-With");
  16. res.header("Access-Control-Allow-Methods","PUT,POST,GET,DELETE,OPTIONS");
  17. res.header("X-Powered-By",' 3.2.1')
  18. if(req.method=="OPTIONS") res.send(200);/*让options请求快速返回*/
  19. else next();
  20. });
  21. app.use(flash());
  22. const MongoStore = connectMongo(session);
  23. app.use(session({
  24. name: config.session.name,
  25. secret: config.session.secret,
  26. resave: true,
  27. saveUninitialized: false,
  28. cookie: config.session.cookie,
  29. store: new MongoStore({
  30. url: config.url
  31. })
  32. }))
  33. app.use((req, res, next) => {
  34. res.locals.user = req.session.user;
  35. res.locals.success = req.flash('success').toString();
  36. res.locals.error = req.flash('error').toString();
  37. next();
  38. });
  39. // app.use(expressWinston.logger({
  40. // transports: [
  41. // new (winston.transports.Console)({
  42. // json: true,
  43. // colorize: true
  44. // }),
  45. // new winston.transports.File({
  46. // filename: 'logs/success.log'
  47. // })
  48. // ]
  49. // }));
  50. router(app);
  51. // app.use(expressWinston.errorLogger({
  52. // transports: [
  53. // new winston.transports.Console({
  54. // json: true,
  55. // colorize: true
  56. // }),
  57. // new winston.transports.File({
  58. // filename: 'logs/error.log'
  59. // })
  60. // ]
  61. // }));
  62. app.use((err, req, res, next) => {
  63. res.send('未找到当前路由');
  64. });
  65. app.listen(config.port);