app.js
1.99 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
/**
* app.js
* @author: feng.chen<feng.chen@yoho.cn>
* @date: 2017/04/13
*/
'use strict';
const bodyParser = require('body-parser');
const cookieParser = require('cookie-parser');
const compression = require('compression');
const Express = require('express');
const pkg = require('../package.json');
// const session = require('express-session');
const cookieSession = require('cookie-session');
const favicon = require('serve-favicon');
const path = require('path');
const multipart = require('connect-multiparty');
const multipartMiddleware = multipart();
global.env = {
version: pkg.version,
Production: process.env.NODE_ENV === 'production' || process.env.NODE_ENV === 'gray',
Gray: process.env.NODE_ENV === 'gray',
Test: (process.env.NODE_ENV || '').indexOf('test') >= 0
};
let app = new Express();
const config = require('./common/config');
const logger = require('yoho-node-lib/lib/logger').init(config);
const helpers = require('yoho-node-lib/lib/helpers');
global.yoho = {
logger,
helpers,
config
};
app.use(cookieSession({
name: 'yoho-shop',
secret: 'yoho!shop@manage',
maxAge: 2 * 60 * 60 * 1000
}));
app.use(compression());
app.use(favicon(path.join(__dirname, '/favicon.ico')));
app.use(Express.static(path.join(__dirname, 'public')));
app.use(bodyParser.json({
limit: 1 * 1024 * 1024 // 限制请求长度1m
}));
app.use(bodyParser.urlencoded({extended: false}));
app.use(cookieParser());
app.use(multipartMiddleware);
const middleware = require('./middleware');
const controllers = require('./controllers');
try {
app.use(middleware.main);
// 前置中间件
app.use(middleware.before);
// controller
app.use('/Api', controllers);
// 鉴权中间件
app.use(middleware.auth);
// 接口代理中间件
app.use(middleware.proxy);
// 异常捕获中间件
app.use(middleware.error);
} catch (err) {
logger.error(err);
}
app.listen(config.port, () => {
logger.info(`yoho shop manage start at ${config.port}`);
});