代码拉取完成,页面将自动刷新
import Koa from 'koa';
import json from 'koa-json';
import koaerror from 'koa-json-error';
import bodyparser from 'koa-bodyparser';
import logger from 'koa-logger';
import staticServe from 'koa-static';
import path from 'path';
import { fileURLToPath } from 'url';
import cors from '@koa/cors';
import KoaJwt from 'koa-jwt';
import system from './routes/system.js';
import support from './routes/support.js';
//调度任务
import { initSchduleTasks } from './controller/schedule/initSchduleTasks.js';
const app = new Koa();
const __filename = fileURLToPath(import.meta.url);
const __dirname = path.dirname(__filename);
// 中间件
app.use(cors());
app.use(bodyparser({ enableTypes: ['json', 'form', 'text'] }));
app.use(json());
app.use(logger());
app.use(staticServe(__dirname + '/public'));
initSchduleTasks();
// 记录处理时间
app.use(async (ctx, next) => {
const start = new Date();
await next();
const ms = new Date() - start;
console.log('🕔🕔🕔🕔 方法: ', `${ctx.method} ;'🕔 路由: ' ${ctx.url} ;'🕔 耗时: ' ${ms}毫秒`);
});
// JWT鉴权路由控制
if (!process.env.NODE_SECRET_KEY) {
console.error('JWT_SECRET_KEY is not set in the environment.');
process.exit(1); // 未设置密钥时,强制退出
}
const excludedPaths = ['/system/login', /^\/image/];
const jwtAuth = KoaJwt({
secret: process.env.NODE_SECRET_KEY
}).unless({
path: excludedPaths
});
// 错误处理中间件,用于捕获KoaJwt抛出的错误
const handleAuthError = async (ctx, next) => {
try {
await next();
} catch (err) {
if (err.status === 401) {
// 401 Unauthorized for JWT errors
ctx.status = 401;
ctx.body = {
error: 'Unauthorized',
message: err.message
};
} else {
throw err; // 如果是其他类型的错误,继续抛出
}
}
};
app.use(handleAuthError); // 全局错误处理中间件
app.use(jwtAuth); // 全局应用鉴权中间件,但排除特定路径
// Routes
app.use(system.routes(), system.allowedMethods());
app.use(support.routes(), support.allowedMethods());
//中间件错误监控
app.use(
koaerror({
format: (err, ctx) => {
const status = err.status || 500;
const isDevelopment = process.env.NODE_ENV === '开发环境';
return {
code: status,
message: err.message,
error: isDevelopment ? err.expose || err.message : '服务器异常!',
path: ctx.path,
result: isDevelopment ? err.stack : undefined
};
}
})
);
// 监听非中间件异常
app.on('error', (err, ctx) => {
console.error('服务器异常!!', err, ctx);
});
console.log(`🔰🔰 你好,${process.env.NODE_HOST} !`);
app.listen(process.env.NODE_PORT, () => {
console.log(`🚀🚀 访问环境: ${process.env.NODE_ENV}`);
console.log(`📦️📦️ 访问地址: ${process.env.NODE_HOST}:${process.env.NODE_PORT}`);
});
export default app;
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。