Spaces:
Sleeping
Sleeping
Update server.js
Browse files
server.js
CHANGED
@@ -1,70 +1,69 @@
|
|
1 |
-
const express = require('express');
|
2 |
-
const dotenv = require('dotenv');
|
3 |
-
const cors = require('cors');
|
4 |
-
const morgan = require('morgan');
|
5 |
-
const { connectDB } = require('./config/db');
|
6 |
-
const { errorHandler } = require('./middleware/errorHandler');
|
7 |
-
const routes = require('./routes');
|
8 |
-
const logger = require('./utils/logger');
|
9 |
-
|
10 |
-
// 加载环境变量
|
11 |
-
dotenv.config();
|
12 |
-
|
13 |
-
// 验证关键环境变量
|
14 |
-
const requiredEnvVars = ['MONGODB_URI', 'JWT_SECRET', 'ADMIN_USERNAME', 'ADMIN_PASSWORD'];
|
15 |
-
const missingEnvVars = requiredEnvVars.filter(envVar => !process.env[envVar]);
|
16 |
-
|
17 |
-
if (missingEnvVars.length > 0) {
|
18 |
-
logger.error(`缺少必要的环境变量: ${missingEnvVars.join(', ')}`);
|
19 |
-
process.exit(1);
|
20 |
-
}
|
21 |
-
|
22 |
-
logger.info('环境变量加载成功');
|
23 |
-
logger.info(`NODE_ENV: ${process.env.NODE_ENV}`);
|
24 |
-
logger.info(`ADMIN_USERNAME: ${process.env.ADMIN_USERNAME}`);
|
25 |
-
logger.info(`JWT_SECRET: ${process.env.JWT_SECRET ? '已设置' : '未设置'}`);
|
26 |
-
|
27 |
-
// 初始化 Express 应用
|
28 |
-
const app = express();
|
29 |
-
|
30 |
-
// 中间件
|
31 |
-
app.use(cors());
|
32 |
-
app.use(express.json());
|
33 |
-
app.use(express.urlencoded({ extended: true }));
|
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 |
-
process.exit(1);
|
70 |
});
|
|
|
1 |
+
const express = require('express');
|
2 |
+
const dotenv = require('dotenv');
|
3 |
+
const cors = require('cors');
|
4 |
+
const morgan = require('morgan');
|
5 |
+
const { connectDB } = require('./config/db');
|
6 |
+
const { errorHandler } = require('./middleware/errorHandler');
|
7 |
+
const routes = require('./routes');
|
8 |
+
const logger = require('./utils/logger');
|
9 |
+
|
10 |
+
// 加载环境变量
|
11 |
+
dotenv.config();
|
12 |
+
|
13 |
+
// 验证关键环境变量
|
14 |
+
const requiredEnvVars = ['MONGODB_URI', 'JWT_SECRET', 'ADMIN_USERNAME', 'ADMIN_PASSWORD'];
|
15 |
+
const missingEnvVars = requiredEnvVars.filter(envVar => !process.env[envVar]);
|
16 |
+
|
17 |
+
if (missingEnvVars.length > 0) {
|
18 |
+
logger.error(`缺少必要的环境变量: ${missingEnvVars.join(', ')}`);
|
19 |
+
process.exit(1);
|
20 |
+
}
|
21 |
+
|
22 |
+
logger.info('环境变量加载成功');
|
23 |
+
logger.info(`NODE_ENV: ${process.env.NODE_ENV}`);
|
24 |
+
logger.info(`ADMIN_USERNAME: ${process.env.ADMIN_USERNAME}`);
|
25 |
+
logger.info(`JWT_SECRET: ${process.env.JWT_SECRET ? '已设置' : '未设置'}`);
|
26 |
+
|
27 |
+
// 初始化 Express 应用
|
28 |
+
const app = express();
|
29 |
+
|
30 |
+
// 中间件
|
31 |
+
app.use(cors());
|
32 |
+
app.use(express.json({ limit: '50mb' }));
|
33 |
+
app.use(express.urlencoded({ extended: true, limit: '50mb' }));
|
34 |
+
// 日志中间件
|
35 |
+
if (process.env.NODE_ENV === 'development') {
|
36 |
+
app.use(morgan('dev'));
|
37 |
+
}
|
38 |
+
|
39 |
+
// 连接数据库
|
40 |
+
connectDB();
|
41 |
+
|
42 |
+
// 路由
|
43 |
+
app.use('/api', routes);
|
44 |
+
|
45 |
+
// 健康检查端点
|
46 |
+
app.get('/health', (req, res) => {
|
47 |
+
res.status(200).json({ status: 'ok', message: 'Server is running' });
|
48 |
+
});
|
49 |
+
|
50 |
+
// 错误处理中间件
|
51 |
+
app.use(errorHandler);
|
52 |
+
|
53 |
+
// 启动服务器
|
54 |
+
const PORT = process.env.PORT || 8080;
|
55 |
+
app.listen(PORT, () => {
|
56 |
+
logger.info(`Server running in ${process.env.NODE_ENV} mode on port ${PORT}`);
|
57 |
+
});
|
58 |
+
|
59 |
+
// 处理未捕获的异常
|
60 |
+
process.on('uncaughtException', (err) => {
|
61 |
+
logger.error('Uncaught Exception:', err);
|
62 |
+
process.exit(1);
|
63 |
+
});
|
64 |
+
|
65 |
+
// 处理未处理的 Promise 拒绝
|
66 |
+
process.on('unhandledRejection', (err) => {
|
67 |
+
logger.error('Unhandled Rejection:', err);
|
68 |
+
process.exit(1);
|
|
|
69 |
});
|