server.js 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123
  1. let express = require('express');
  2. let config = require("./config/config.js");
  3. let fileUtils = require("./modules/common/fileUtils");
  4. let dbm = require("./config/db/db_manager");
  5. let log = require("./logs/log_helper");
  6. ///config.setToLocalDb();
  7. config.setupDb(process.env.NODE_ENV);
  8. let path = require('path');
  9. let session = require('express-session');
  10. let DBStore = require('connect-mongo')(session);
  11. let fs = require('fs');
  12. let URL = require('url');
  13. dbm.connect();
  14. //这里现在只引入了定额工料机里的models,当其它模块的models修改后使用:./modules/**/models/*.js引入所有的模块
  15. fileUtils.getGlobbedFiles('./modules/ration_glj/models/*.js').forEach(function(modelPath) {
  16. require(path.resolve(modelPath));
  17. })
  18. //暂时引入其它模块的model
  19. require('./modules/fee_rates/models/fee_rates');
  20. //引入报表模块
  21. fileUtils.getGlobbedFiles('./modules/reports/models/*.js').forEach(function(modelPath) {
  22. require(path.resolve(modelPath));
  23. })
  24. // 引入人工系数模块
  25. require('./modules/main/models/labour_coe_model');
  26. //config.setupCache();
  27. let cfgCacheUtil = require("./config/cacheCfg");
  28. cfgCacheUtil.setupDftCache();
  29. let app = express();
  30. let _rootDir = __dirname;
  31. log.use(app);
  32. app.use(express.static(_rootDir));
  33. app.set('views', path.join(__dirname, 'web'));
  34. app.engine('.html', require('ejs').__express);
  35. app.set('view engine', 'html');
  36. let bodyParser = require('body-parser');
  37. app.use(bodyParser.urlencoded({limit: '3mb', extended: false}));
  38. app.use(bodyParser.json({limit: '3mb'}));
  39. app.use(session({
  40. name: 'usersSession',
  41. secret: 'session users secret',
  42. cookie: {maxAge: 1000*60*30},
  43. resave: false,
  44. rolling: true,
  45. saveUninitialized: true
  46. //*
  47. ,store: new DBStore({
  48. url: 'mongodb://' + config.current.server + ':' + config.current.port + '/usersManages'
  49. })
  50. //*/
  51. }));
  52. // 登录状态全局判断
  53. app.use(function (req, res, next) {
  54. let url = req.originalUrl;
  55. // @todo 上一个页面跳转
  56. let referer = '';
  57. if (/^\/login/.test(url)) {
  58. // 如果是登录页面则忽略判断数据
  59. next();
  60. } else {
  61. try {
  62. // 判断session
  63. let sessionUser = req.session.sessionUser;
  64. if (!sessionUser) {
  65. throw 'session error';
  66. }
  67. res.locals.sessionUser = sessionUser;
  68. } catch (error) {
  69. return res.redirect('/login');
  70. }
  71. next();
  72. }
  73. });
  74. //加载路由文件
  75. fileUtils.getGlobbedFiles('./modules/**/routes/*.js').forEach(function(modelPath) {
  76. require(path.resolve(modelPath))(app);
  77. })
  78. //app.use(express.static(_rootDir+"/web"));
  79. //app.use(express.static(_rootDir+"/lib"));
  80. //let rations_Router = require("./modules/rationLibEditor/routes/rationLibEditor_route");
  81. //app.use("/rationLibEditor",rations_Router);
  82. //-----------------
  83. app.use(function(req, res, next) {
  84. res.status(404).send('404 Error');
  85. });
  86. app.use(function(err, req, res, next) {
  87. console.error(err.stack);
  88. res.status(500).send('500 Error');
  89. });
  90. //设置Date Format函数
  91. fs.readFile(__dirname + '/public/web/date_util.js', 'utf8', 'r', function (err, data) {
  92. eval(data);
  93. // let dt = new Date();
  94. // console.log(dt.Format('yyyy-M-dd'));
  95. // console.log(dt.Format('yyyy 年 M 月 dd 日'));
  96. // console.log(dt.Format('yyyy 年 M 月 20 日'));
  97. });
  98. app.listen(6060, function(){
  99. console.log('server started!');
  100. });