加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
app.js 4.61 KB
一键复制 编辑 原始数据 按行查看 历史
var ejs = require('ejs');
var createError = require('http-errors');
var express = require('express');
var path = require('path');
var cookieParser = require('cookie-parser');
var bodyParser = require('body-parser');
var logger = require('morgan');
var TokenHelper = require('./common/TokenHelper');
var usersRouter = require('./routes/users');
var startRouter = require('./routes/start');
var homeRouter = require('./routes/home');
var mainRouter = require('./routes/main');
var investorRouter = require('./routes/investor');
var investmentRouter = require('./routes/investment');
var paramPouter = require('./routes/param');
var permitconfigRouter = require('./routes/permitconfig');
var permitRouter = require('./routes/permit');
var roleRouter = require('./routes/role');
var navtreeRouter = require('./routes/navtree');
var informationRouter = require('./routes/information');
var xcxRouter = require('./routes/weixinxcx');
var leadinginRouter = require('./routes/leadingin');
var liuliangRouter = require('./routes/liuliang');
var imageRouter = require('./routes/image');
var app = express();
var fs = require('fs');
var FileStreamRotator = require('file-stream-rotator');
var HttpLimitConn = require('./common/HttpLimitConn');
var httpLimit = new HttpLimitConn({
limit: 120,
space: '30 * * * * *',
whitelist: [], //微信小程序要用,允许跨域
});
var { HttpParamsLimit } = require('./web.config');
app.all('*', function(req, res, next) {
if (!httpLimit.verifyClient(req)) {
return res.status(403).json({ flag: 'False', message: 'overflow limit' });
}
res.header('Access-Control-Allow-Origin', '*');
res.header('Access-Control-Allow-Credentials', 'true');
res.header('Access-Control-Expose-Headers', 'access-token,permit-token');
res.header('Access-Control-Allow-Headers', 'X-Requested-With,Content-Type,access-token,permit-token');
res.header('Access-Control-Allow-Methods', 'PUT,POST,GET,DELETE,OPTIONS');
res.header('X-Powered-By', ' 3.2.1');
res.header('Content-Type', 'application/json;charset=utf-8');
if (req.headers['access-token'] && req.method.toLocaleUpperCase() !== 'OPTIONS') {
TokenHelper.get(req.headers['access-token'])
.then(user => {
delete user.iat;
delete user.exp;
req['UserInfo'] = user;
if (user && !/logout/gi.test(req.url)) {
res.header('access-token', TokenHelper.set(user));
}
TokenHelper.get(req.headers['permit-token'])
.then(permit => {
delete permit.iat;
delete permit.exp;
req['UserPermit'] = permit;
res.header('permit-token', TokenHelper.set(permit));
next();
})
.catch(() => {
next();
});
})
.catch(() => {
req['UserInfo'] = null; // 只要权限为空,直接退出登录
next();
});
} else {
next();
}
});
// view engine setup
app.set('views', path.join(__dirname, 'views'));
app.engine('html', ejs.__express);
app.set('view engine', 'html');
//日志设置
var logDirectory = path.join(__dirname, 'logs');
fs.existsSync(logDirectory) || fs.mkdirSync(logDirectory);
var accessLogStream = FileStreamRotator.getStream({
date_format: 'YYYYMMDD',
filename: path.join(logDirectory, 'access-%DATE%.log'),
frequency: 'daily',
verbose: false,
});
app.use(logger('combined', { stream: accessLogStream }));
app.use(express.json());
app.use(express.urlencoded({ extended: false }));
app.use(cookieParser());
app.use(express.static(path.join(__dirname, 'public')));
// 请求大小设置
app.use(bodyParser.json({ limit: HttpParamsLimit }));
app.use(bodyParser.urlencoded({ limit: HttpParamsLimit, extended: true }));
app.use('/api/start', startRouter);
app.use('/api/home', homeRouter);
app.use('/api/main', mainRouter);
app.use('/api/investor', investorRouter);
app.use('/api/investment', investmentRouter);
app.use('/api/param', paramPouter);
app.use('/api/permitconfig', permitconfigRouter);
app.use('/api/permit', permitRouter);
app.use('/api/role', roleRouter);
app.use('/api/user', usersRouter);
app.use('/api/navtree', navtreeRouter);
app.use('/api/information', informationRouter);
app.use('/api/weixin', xcxRouter);
app.use('/api/leadingin', leadinginRouter);
app.use('/api/liuliang', liuliangRouter);
app.use('/api/image', imageRouter);
app.use(function(req, res, next) {
// res.type('html'); 与下面选用一个即可
res.header('Content-Type', 'text/html; charset=utf-8');
next(createError(404));
});
// error handler
app.use(function(err, req, res, next) {
// set locals, only providing error in development
res.locals.message = err.message;
res.locals.error = req.app.get('env') === 'development' ? err : {};
// render the error page
res.status(err.status || 500);
res.render('error');
});
module.exports = app;
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化