提交供应商以及删除无关代码
This commit is contained in:
218
server.js
218
server.js
@@ -86,210 +86,22 @@ const limiter = rateLimit({
|
||||
}
|
||||
}
|
||||
});
|
||||
app.use('/api', limiter);
|
||||
|
||||
// 静态文件服务 - 必须在API路由之前
|
||||
// 为uploads路径配置CORS和静态文件服务
|
||||
app.use('/uploads', express.static(path.join(__dirname, 'uploads'), {
|
||||
setHeaders: (res, filePath) => {
|
||||
// 设置CORS头部
|
||||
res.setHeader('Access-Control-Allow-Origin', '*');
|
||||
res.setHeader('Access-Control-Allow-Methods', 'GET, OPTIONS');
|
||||
res.setHeader('Access-Control-Allow-Headers', 'Origin, X-Requested-With, Content-Type, Accept');
|
||||
|
||||
// 设置缓存和内容类型
|
||||
if (filePath.endsWith('.jpg') || filePath.endsWith('.jpeg')) {
|
||||
res.setHeader('Content-Type', 'image/jpeg');
|
||||
} else if (filePath.endsWith('.png')) {
|
||||
res.setHeader('Content-Type', 'image/png');
|
||||
} else if (filePath.endsWith('.gif')) {
|
||||
res.setHeader('Content-Type', 'image/gif');
|
||||
} else if (filePath.endsWith('.webp')) {
|
||||
res.setHeader('Content-Type', 'image/webp');
|
||||
}
|
||||
res.setHeader('Cache-Control', 'public, max-age=86400'); // 1天缓存
|
||||
}
|
||||
}));
|
||||
|
||||
// 处理vite.svg请求
|
||||
app.get('/vite.svg', (req, res) => {
|
||||
const referer = req.get('Referer');
|
||||
if (referer && referer.includes('/admin')) {
|
||||
// 为admin页面提供logo.svg
|
||||
res.setHeader('Content-Type', 'image/svg+xml');
|
||||
res.sendFile(path.join(__dirname, 'admin/dist/logo.svg'));
|
||||
} else {
|
||||
// 前端页面没有vite.svg,返回404
|
||||
res.status(404).send('File not found');
|
||||
}
|
||||
});
|
||||
|
||||
// 静态文件服务配置
|
||||
// 专门处理admin路径下的assets
|
||||
app.use('/admin/assets', express.static(path.join(__dirname, 'admin/dist/assets'), {
|
||||
setHeaders: (res, filePath) => {
|
||||
res.removeHeader('Origin-Agent-Cluster');
|
||||
if (filePath.endsWith('.css')) {
|
||||
res.setHeader('Content-Type', 'text/css; charset=utf-8');
|
||||
res.setHeader('Cache-Control', 'public, max-age=31536000');
|
||||
} else if (filePath.endsWith('.js')) {
|
||||
res.setHeader('Content-Type', 'application/javascript; charset=utf-8');
|
||||
res.setHeader('Cache-Control', 'public, max-age=31536000');
|
||||
}
|
||||
}
|
||||
}));
|
||||
|
||||
// 为admin页面的assets提供服务(当从admin页面访问/assets/时)
|
||||
app.use('/assets', (req, res, next) => {
|
||||
// 检查referer来判断是否来自admin页面
|
||||
const referer = req.get('Referer');
|
||||
if (referer && referer.includes('/admin')) {
|
||||
// 如果来自admin页面,从admin/dist/assets提供文件
|
||||
express.static(path.join(__dirname, 'admin/dist/assets'), {
|
||||
setHeaders: (res, filePath) => {
|
||||
res.removeHeader('Origin-Agent-Cluster');
|
||||
if (filePath.endsWith('.css')) {
|
||||
res.setHeader('Content-Type', 'text/css; charset=utf-8');
|
||||
res.setHeader('Cache-Control', 'public, max-age=31536000');
|
||||
} else if (filePath.endsWith('.js')) {
|
||||
res.setHeader('Content-Type', 'application/javascript; charset=utf-8');
|
||||
res.setHeader('Cache-Control', 'public, max-age=31536000');
|
||||
}
|
||||
}
|
||||
})(req, res, next);
|
||||
} else {
|
||||
// 否则从frontend/dist/assets提供文件
|
||||
express.static(path.join(__dirname, 'frontend/dist/assets'), {
|
||||
setHeaders: (res, filePath) => {
|
||||
res.removeHeader('Origin-Agent-Cluster');
|
||||
if (filePath.endsWith('.css')) {
|
||||
res.setHeader('Content-Type', 'text/css; charset=utf-8');
|
||||
res.setHeader('Cache-Control', 'public, max-age=31536000');
|
||||
} else if (filePath.endsWith('.js')) {
|
||||
res.setHeader('Content-Type', 'application/javascript; charset=utf-8');
|
||||
res.setHeader('Cache-Control', 'public, max-age=31536000');
|
||||
}
|
||||
}
|
||||
})(req, res, next);
|
||||
}
|
||||
});
|
||||
|
||||
app.use('/admin', express.static(path.join(__dirname, 'admin/dist'), {
|
||||
setHeaders: (res, filePath) => {
|
||||
// 移除Origin-Agent-Cluster头部以避免冲突
|
||||
res.removeHeader('Origin-Agent-Cluster');
|
||||
|
||||
if (filePath.endsWith('.css')) {
|
||||
res.setHeader('Content-Type', 'text/css; charset=utf-8');
|
||||
res.setHeader('Cache-Control', 'public, max-age=31536000'); // 1年缓存
|
||||
} else if (filePath.endsWith('.js')) {
|
||||
res.setHeader('Content-Type', 'application/javascript; charset=utf-8');
|
||||
res.setHeader('Cache-Control', 'public, max-age=31536000'); // 1年缓存
|
||||
} else if (filePath.endsWith('.html')) {
|
||||
res.setHeader('Cache-Control', 'no-cache, no-store, must-revalidate'); // HTML文件不缓存
|
||||
res.setHeader('Pragma', 'no-cache');
|
||||
res.setHeader('Expires', '0');
|
||||
} else if (filePath.endsWith('.svg')) {
|
||||
res.setHeader('Content-Type', 'image/svg+xml');
|
||||
}
|
||||
}
|
||||
}));
|
||||
|
||||
app.use(express.static(path.join(__dirname, 'frontend/dist'), {
|
||||
setHeaders: (res, filePath) => {
|
||||
// 移除Origin-Agent-Cluster头部以避免冲突
|
||||
res.removeHeader('Origin-Agent-Cluster');
|
||||
|
||||
if (filePath.endsWith('.css')) {
|
||||
res.setHeader('Content-Type', 'text/css; charset=utf-8');
|
||||
res.setHeader('Cache-Control', 'public, max-age=31536000'); // 1年缓存
|
||||
} else if (filePath.endsWith('.js')) {
|
||||
res.setHeader('Content-Type', 'application/javascript; charset=utf-8');
|
||||
res.setHeader('Cache-Control', 'public, max-age=31536000'); // 1年缓存
|
||||
} else if (filePath.endsWith('.html')) {
|
||||
res.setHeader('Cache-Control', 'no-cache, no-store, must-revalidate'); // HTML文件不缓存
|
||||
res.setHeader('Pragma', 'no-cache');
|
||||
res.setHeader('Expires', '0');
|
||||
} else if (filePath.endsWith('.svg')) {
|
||||
res.setHeader('Content-Type', 'image/svg+xml');
|
||||
}
|
||||
}
|
||||
}));
|
||||
app.use('/', limiter);
|
||||
|
||||
// 引入数据库初始化模块
|
||||
const { initDatabase } = require('./config/database-init');
|
||||
|
||||
|
||||
// API路由
|
||||
app.use('/api/auth', require('./routes/auth'));
|
||||
app.use('/api/users', require('./routes/users'));
|
||||
app.use('/api/user', require('./routes/users')); // 添加单数形式的路由映射
|
||||
app.use('/api/products', require('./routes/products'));
|
||||
app.use('/api/specifications', require('./routes/specifications'));
|
||||
app.use('/api/orders', require('./routes/orders'));
|
||||
app.use('/api/points', require('./routes/points'));
|
||||
app.use('/api/captcha', require('./routes/captcha')); // 验证码路由
|
||||
app.use('/api/sms', require('./routes/sms')); // 短信验证路由
|
||||
|
||||
app.use('/api/upload', require('./routes/upload'));
|
||||
app.use('/api/transfers', require('./routes/transfers'));
|
||||
app.use('/api/matching', require('./routes/matching'));
|
||||
app.use('/api/admin/matching', require('./routes/matchingAdmin'));
|
||||
app.use('/api/system', require('./routes/system'));
|
||||
app.use('/api/risk', require('./routes/riskManagement'));
|
||||
app.use('/api/agents', require('./routes/agents'));
|
||||
app.use('/api/admin/agents', require('./routes/agents/agents'));
|
||||
app.use('/api/admin/withdrawals', require('./routes/agents/withdrawals'));
|
||||
app.use('/api/agent-withdrawals', require('./routes/agent-withdrawals'));
|
||||
app.use('/api/regions', require('./routes/regions'));
|
||||
app.use('/api/addresses', require('./routes/addresses'));
|
||||
app.use('/api/address-labels', require('./routes/address-labels'));
|
||||
app.use('/api/cart', require('./routes/cart'));
|
||||
app.use('/api/announcements', require('./routes/announcements')); // 通知公告路由
|
||||
app.use('/api/wechat-pay', require('./routes/wechatPay')); // 只保留微信支付
|
||||
app.use('/api/payment', require('./routes/payment'));
|
||||
|
||||
// 商城后台相关接口
|
||||
app.use('/api/shopbackend', require('./routes/shopbackend'));
|
||||
|
||||
// 前端路由 - 必须在最后,作为fallback
|
||||
app.get('/', (req, res) => {
|
||||
res.removeHeader('Origin-Agent-Cluster');
|
||||
res.setHeader('Cache-Control', 'no-cache, no-store, must-revalidate');
|
||||
res.setHeader('Pragma', 'no-cache');
|
||||
res.setHeader('Expires', '0');
|
||||
res.sendFile(path.join(__dirname, 'frontend/dist/index.html'));
|
||||
});
|
||||
|
||||
app.get('/admin*', (req, res) => {
|
||||
res.removeHeader('Origin-Agent-Cluster');
|
||||
res.setHeader('Cache-Control', 'no-cache, no-store, must-revalidate');
|
||||
res.setHeader('Pragma', 'no-cache');
|
||||
res.setHeader('Expires', '0');
|
||||
res.sendFile(path.join(__dirname, 'admin/dist/index.html'));
|
||||
});
|
||||
|
||||
app.get('/frontend*', (req, res) => {
|
||||
res.removeHeader('Origin-Agent-Cluster');
|
||||
res.setHeader('Cache-Control', 'no-cache, no-store, must-revalidate');
|
||||
res.setHeader('Pragma', 'no-cache');
|
||||
res.setHeader('Expires', '0');
|
||||
res.sendFile(path.join(__dirname, 'frontend/dist/index.html'));
|
||||
});
|
||||
|
||||
// SPA fallback - 处理前端路由
|
||||
app.get('*', (req, res) => {
|
||||
// 如果请求的是静态资源但找不到,返回404(不返回JSON)
|
||||
if (req.path.includes('.')) {
|
||||
return res.status(404).send('File not found');
|
||||
}
|
||||
// 否则返回前端应用的index.html
|
||||
res.removeHeader('Origin-Agent-Cluster');
|
||||
res.setHeader('Cache-Control', 'no-cache, no-store, must-revalidate');
|
||||
res.setHeader('Pragma', 'no-cache');
|
||||
res.setHeader('Expires', '0');
|
||||
res.sendFile(path.join(__dirname, 'frontend/dist/index.html'));
|
||||
});
|
||||
app.use('/shopbackend', require('./routes/shopbackend'));
|
||||
//订单管理接口
|
||||
app.use('/orders', require('./routes/orders'))
|
||||
//商品列表
|
||||
app.use('/products', require('./routes/products'))
|
||||
//供应商接口
|
||||
app.use('/supplier',require('./routes/supplier'))
|
||||
//规格处理
|
||||
app.use('/specifications', require('./routes/specifications'));
|
||||
|
||||
// 404处理
|
||||
app.use(notFound);
|
||||
@@ -309,16 +121,6 @@ app.listen(PORT, async () => {
|
||||
console.log(`服务器运行在 http://localhost:${PORT}`);
|
||||
|
||||
await initDatabase();
|
||||
// global.sqlReq = mysql.createConnection()
|
||||
// 启动转账超时检查服务
|
||||
const timeoutService = require('./services/timeoutService');
|
||||
timeoutService.startTimeoutChecker();
|
||||
console.log('转账超时检查服务已启动');
|
||||
|
||||
// 启动数据库连接监控
|
||||
// const dbMonitor = require('./db-monitor');
|
||||
// dbMonitor.startMonitoring(60000); // 每分钟监控一次
|
||||
// console.log('数据库连接监控已启动');
|
||||
global.captchaStore = new Map();
|
||||
logger.info('Server started successfully', {
|
||||
port: PORT,
|
||||
|
||||
Reference in New Issue
Block a user