app.js 2.1 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 cookieParser from 'cookie-parser'
  6. import session from 'express-session';
  7. import connectMongo from 'connect-mongo';
  8. import winston from 'winston';
  9. import expressWinston from 'express-winston';
  10. import history from 'connect-history-api-fallback';
  11. import chalk from 'chalk';
  12. // import Statistic from './middlewares/statistic'
  13. const app = express();
  14. app.all('*', (req, res, next) => {
  15. const { origin, Origin, referer, Referer } = req.headers;
  16. const allowOrigin = origin || Origin || referer || Referer || '*';
  17. res.header("Access-Control-Allow-Origin", allowOrigin);
  18. res.header("Access-Control-Allow-Headers", "Content-Type, Authorization, X-Requested-With");
  19. res.header("Access-Control-Allow-Methods", "PUT,POST,GET,DELETE,OPTIONS");
  20. res.header("Access-Control-Allow-Credentials", true); //可以带cookies
  21. res.header("X-Powered-By", 'Express');
  22. if (req.method == 'OPTIONS') {
  23. res.sendStatus(200);
  24. } else {
  25. next();
  26. }
  27. });
  28. // app.use(Statistic.apiRecord)
  29. const MongoStore = connectMongo(session);
  30. app.use(cookieParser());
  31. app.use(session({
  32. name: config.session.name,
  33. secret: config.session.secret,
  34. resave: true,
  35. saveUninitialized: false,
  36. cookie: config.session.cookie,
  37. store: new MongoStore({
  38. url: config.url
  39. })
  40. }))
  41. // app.use(expressWinston.logger({
  42. // transports: [
  43. // new (winston.transports.Console)({
  44. // json: true,
  45. // colorize: true
  46. // }),
  47. // new winston.transports.File({
  48. // filename: 'logs/success.log'
  49. // })
  50. // ]
  51. // }));
  52. router(app);
  53. // app.use(expressWinston.errorLogger({
  54. // transports: [
  55. // new winston.transports.Console({
  56. // json: true,
  57. // colorize: true
  58. // }),
  59. // new winston.transports.File({
  60. // filename: 'logs/error.log'
  61. // })
  62. // ]
  63. // }));
  64. app.use(history());
  65. app.use(express.static('./public'));
  66. app.listen(config.port, () => {
  67. console.log(
  68. chalk.green(`成功监听端口:${config.port}`)
  69. )
  70. });