-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathapp.js
91 lines (79 loc) · 2.16 KB
/
app.js
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
84
85
86
87
88
89
90
91
var express = require('express');
var path = require('path');
var favicon = require('serve-favicon');
var logger = require('morgan');
var session = require('express-session');
var MongoStore = require('connect-mongo')(session);
var bodyParser = require('body-parser');
// var config = require('config-lite');
var response = require('./common/Response');
var routes = require('./routes');
var winston = require('winston');
var expressWinston = require('express-winston');
var app = express();
// session 中间件
app.use(session({
secret: 'question', // 用来注册session id 到cookie中,相当与一个密钥
name: 'question', // cookie的name
cookie: {maxAge: 2592000000},
resave: false,
saveUninitialized: true,
store: new MongoStore({
url: 'mongodb://localhost:27017/question',
autoRemove: 'native'
})
}));
// 设置模板目录
app.set('views', path.join(__dirname, 'views'));
// 设置模板引擎为 jade
app.set('view engine', 'jade');
// 设置网站favicon图标
app.use(favicon(path.join(__dirname, 'public', 'favicon.ico')));
// 开启控制台日志
app.use(logger('dev'));
//
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({extended: false}));
// 设置静态文件目录
app.use(express.static(path.join(__dirname, 'public')));
// 设置全局的Response
app.use(function (req, res, next) {
response.setResponse(res);
next();
});
app.use(function (req, res, next) {
if (req.method == 'GET') {
console.log("req.method", req.method);
console.log("req.url", req.url);
res.sendFile(path.join(__dirname, 'public', 'index.html'));
} else {
next();
}
});
// 正常请求的日志
/*app.use(expressWinston.logger({
transports: [
// new (winston.transports.Console)({
// json: true,
// colorize: true
// }),
new winston.transports.File({
filename: 'logs/success.log'
})
]
}));*/
// 路由
routes(app, 'api');
// 错误请求的日志
/*app.use(expressWinston.errorLogger({
transports: [
// new winston.transports.Console({
// json: true,
// colorize: true
// }),
new winston.transports.File({
filename: 'logs/error.log'
})
]
}));*/
module.exports = app;