server.js 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127
  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. import rptCronJob from "./modules/reports/util/rpt_tmp_file_sweep";
  14. dbm.connect(process.env.NODE_ENV);
  15. //这里现在只引入了定额工料机里的models,当其它模块的models修改后使用:./modules/**/models/*.js引入所有的模块
  16. fileUtils.getGlobbedFiles('./modules/all_models/*.js').forEach(function(modelPath) {
  17. require(path.resolve(modelPath));
  18. })
  19. //config.setupCache();
  20. let cfgCacheUtil = require("./config/cacheCfg");
  21. cfgCacheUtil.setupDftCache();
  22. let online_logs = require("./logs/online_logs");
  23. let app = express();
  24. let _rootDir = __dirname;
  25. app.locals.rootDir = _rootDir;
  26. log.use(app);
  27. app.use(express.static(_rootDir));
  28. app.set('views', path.join(__dirname, 'web'));
  29. app.engine('.html', require('ejs').__express);
  30. app.set('view engine', 'html');
  31. let bodyParser = require('body-parser');
  32. app.use(bodyParser.urlencoded({limit: '10mb', extended: false}));
  33. app.use(bodyParser.json({limit: '10mb'}));
  34. app.use(session({
  35. name: 'usersSession',
  36. secret: 'session users secret',
  37. // @todo 上线前修改回正常值 (目前为24小时)
  38. cookie: {maxAge: 3600 * 24 * 1000},
  39. resave: false,
  40. rolling: true,
  41. saveUninitialized: true,
  42. //*
  43. store: new DBStore({
  44. url: config.getSessionURL(process.env.NODE_ENV)
  45. })
  46. //*/
  47. }));
  48. // 登录状态全局判断
  49. app.use(async function (req, res, next) {
  50. let url = req.originalUrl;
  51. // if (/^\/login/.test(url) || /\.map|\.ico$/.test(url) || /^\/sms/.test(url) || /^\/cld/.test(url) || /^\/captcha/.test(url) || /^\/accountIsPro/.test(url)) {
  52. if (/^\/login/.test(url) || /\.map|\.ico$/.test(url) || /^\/sms/.test(url) || /^\/cld/.test(url) || /^\/captcha/.test(url)) {
  53. // 如果是登录页面或短信接口或cld接口则忽略判断数据
  54. next();
  55. } else {
  56. try {
  57. if (req.query.ssoID !== undefined && req.query.ssoID !== null && req.query.token !== undefined && req.query.token !== null) {
  58. delete req.session.sessionUser;
  59. delete req.session.sessionCompilation;
  60. return res.redirect('/login' + url);
  61. } else {
  62. // 判断session
  63. let sessionUser = req.session.sessionUser;
  64. if (!sessionUser) {
  65. //处理 ajax 请求 session 过期问题
  66. if (req.headers["x-requested-with"] != null
  67. && req.headers["x-requested-with"] == "XMLHttpRequest"
  68. && req.url != "/login") {
  69. return res.json({ret_code: 99, ret_msg: '登录信息失效,请您重新登录'});
  70. } else {
  71. throw 'session error';
  72. }
  73. }
  74. res.locals.sessionUser = sessionUser;
  75. }
  76. } catch (error) {
  77. // 最后一个页面存入session
  78. req.session.lastPage = url;
  79. return res.redirect('/login');
  80. }
  81. next();
  82. await online_logs.saveOnlineTime(req);//记录登录时长
  83. }
  84. });
  85. //加载路由文件
  86. fileUtils.getGlobbedFiles('./modules/**/routes/*.js').forEach(function(modelPath) {
  87. if(modelPath.indexOf("import/routes")==-1) require(path.resolve(modelPath))(app);//排除掉导出导入服务
  88. });
  89. //app.use(express.static(_rootDir+"/web"));
  90. //app.use(express.static(_rootDir+"/lib"));
  91. //let rations_Router = require("./modules/rationLibEditor/routes/rationLibEditor_route");
  92. //app.use("/rationLibEditor",rations_Router);
  93. //-----------------
  94. app.use(function(req, res, next) {
  95. res.status(404).send('404 Error');
  96. });
  97. app.use(function(err, req, res, next) {
  98. console.error(err.stack);
  99. res.status(500).send('500 Error');
  100. });
  101. //设置外增的Date对象Format函数
  102. //备注: 经过测试nodejs 8.9.3版本不支持eval的方式修改prototype,为兼容考虑,把方法调整到stringUtil文件里
  103. require('./public/stringUtil').setupDateFormat();
  104. app.listen(6060, function(){
  105. console.log('server started!');
  106. });
  107. //设置schedule job
  108. //1. 报表临时文件
  109. rptCronJob.createJob(null, __dirname + "/tmp");
  110. //2. 其他(待补充)...