- 更新 .gitignore 文件,排除 Idea 项目配置 - 移除 vuepress 缓存目录 - 优化 app.js 中的错误处理和状态码导入- 调整 CORS 配置,移除未使用的 allowdHeaders - 更新 hashUtils.js 中的密码处理函数 - 优化 index.js 中的路由定义 - 更新 mongodbConfig.js 中的数据库连接逻辑 - 升级 express到 5.0.0- 更新 mongoose 到 8.7.1
94 lines
2.5 KiB
JavaScript
94 lines
2.5 KiB
JavaScript
const createError = require('http-errors')
|
||
const express = require('express')
|
||
const path = require('path')
|
||
const logger = require('morgan')
|
||
const cors = require('cors')
|
||
const session = require('express-session')
|
||
const { RedisStore } = require('connect-redis')
|
||
const Redis = require('ioredis')
|
||
const cookieParser = require('cookie-parser')
|
||
const indexRouter = require('./routes/index')
|
||
const userRouter = require('./routes/userRouter')
|
||
const accountRouter = require('./routes/accountRouter')
|
||
require('dotenv').config()
|
||
|
||
// mongodb数据库连接
|
||
const { connectMongoDB } = require('./config/mongodbConfig')
|
||
const loginUtil = require('./utils/loginUtil')
|
||
const { HTTP_STATUS } = require('./common/constant/httpStatus')
|
||
|
||
// 初始化 Redis 客户端
|
||
const redisClient = new Redis({
|
||
host: process.env.REDIS_HOST,
|
||
port: process.env.REDIS_PORT || 6379,
|
||
password: process.env.REDIS_PASSWORD,
|
||
db: 0
|
||
})
|
||
|
||
const app = express()
|
||
|
||
app.use(logger('dev'))
|
||
app.use(express.json())
|
||
app.use(express.urlencoded({ extended: false }))
|
||
app.use(express.static(path.join(__dirname, 'public')))
|
||
app.use(cookieParser())
|
||
app.use(
|
||
session({
|
||
name: 'identityKey',
|
||
store: new RedisStore({ client: redisClient }),
|
||
secret: process.env.SESSION_SECRET,
|
||
resave: false,
|
||
saveUninitialized: false,
|
||
cookie: {
|
||
httpOnly: true,
|
||
maxAge: 24 * 60 * 60 * 1000
|
||
}
|
||
})
|
||
)
|
||
|
||
const corsOptions = {
|
||
origin: 'http://localhost:5173', // 指定允许的源
|
||
credentials: true, // 允许发送凭据(如 cookies)
|
||
optionsSuccessStatus: 200
|
||
}
|
||
|
||
app.use(cors(corsOptions))
|
||
|
||
async function startServer() {
|
||
try {
|
||
await connectMongoDB()
|
||
} catch (error) {
|
||
console.error('Server error:', error)
|
||
process.exit(1)
|
||
}
|
||
}
|
||
|
||
startServer().then((r) => logger(r))
|
||
|
||
app.use('/', indexRouter)
|
||
app.use('/user', loginUtil.authenticateSession, userRouter)
|
||
app.use('/account', accountRouter)
|
||
|
||
// catch 404 and forward to error handler
|
||
app.use(function (req, res, next) {
|
||
next(createError(404))
|
||
})
|
||
|
||
// error handler
|
||
app.use(function (err, req, res) {
|
||
// 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 || HTTP_STATUS.INTERNAL_SERVER_ERROR)
|
||
res.json({
|
||
error: true,
|
||
message: err.message || 'Something went wrong',
|
||
// 只在开发环境下返回堆栈信息
|
||
...(req.app.get('env') === 'development' ? { stack: err.stack } : {})
|
||
})
|
||
})
|
||
|
||
module.exports = app
|