server.js 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124
  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. require('./modules/main/models/calc_program_model');
  27. //config.setupCache();
  28. let cfgCacheUtil = require("./config/cacheCfg");
  29. cfgCacheUtil.setupDftCache();
  30. let app = express();
  31. let _rootDir = __dirname;
  32. log.use(app);
  33. app.use(express.static(_rootDir));
  34. app.set('views', path.join(__dirname, 'web'));
  35. app.engine('.html', require('ejs').__express);
  36. app.set('view engine', 'html');
  37. let bodyParser = require('body-parser');
  38. app.use(bodyParser.urlencoded({limit: '3mb', extended: false}));
  39. app.use(bodyParser.json({limit: '3mb'}));
  40. app.use(session({
  41. name: 'usersSession',
  42. secret: 'session users secret',
  43. cookie: {maxAge: 1000*60*30},
  44. resave: false,
  45. rolling: true,
  46. saveUninitialized: true
  47. //*
  48. ,store: new DBStore({
  49. url: 'mongodb://' + config.current.server + ':' + config.current.port + '/usersManages'
  50. })
  51. //*/
  52. }));
  53. // 登录状态全局判断
  54. app.use(function (req, res, next) {
  55. let url = req.originalUrl;
  56. // @todo 上一个页面跳转
  57. let referer = '';
  58. if (/^\/login/.test(url)) {
  59. // 如果是登录页面则忽略判断数据
  60. next();
  61. } else {
  62. try {
  63. // 判断session
  64. let sessionUser = req.session.sessionUser;
  65. if (!sessionUser) {
  66. throw 'session error';
  67. }
  68. res.locals.sessionUser = sessionUser;
  69. } catch (error) {
  70. return res.redirect('/login');
  71. }
  72. next();
  73. }
  74. });
  75. //加载路由文件
  76. fileUtils.getGlobbedFiles('./modules/**/routes/*.js').forEach(function(modelPath) {
  77. require(path.resolve(modelPath))(app);
  78. })
  79. //app.use(express.static(_rootDir+"/web"));
  80. //app.use(express.static(_rootDir+"/lib"));
  81. //let rations_Router = require("./modules/rationLibEditor/routes/rationLibEditor_route");
  82. //app.use("/rationLibEditor",rations_Router);
  83. //-----------------
  84. app.use(function(req, res, next) {
  85. res.status(404).send('404 Error');
  86. });
  87. app.use(function(err, req, res, next) {
  88. console.error(err.stack);
  89. res.status(500).send('500 Error');
  90. });
  91. //设置Date Format函数
  92. fs.readFile(__dirname + '/public/web/date_util.js', 'utf8', 'r', function (err, data) {
  93. eval(data);
  94. // let dt = new Date();
  95. // console.log(dt.Format('yyyy-M-dd'));
  96. // console.log(dt.Format('yyyy 年 M 月 dd 日'));
  97. // console.log(dt.Format('yyyy 年 M 月 20 日'));
  98. });
  99. app.listen(6060, function(){
  100. console.log('server started!');
  101. });