app.js 2.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. import Koa from 'koa';
  2. import bodyParser from 'koa-bodyparser';
  3. import serve from 'koa-static';
  4. import session from 'koa-session';
  5. import path from 'path';
  6. import { fileURLToPath } from 'url';
  7. import config from './config/index.js';
  8. import { decryptUrlMiddle } from './util/crypto/index.js';
  9. import { stringUtils } from './util/stringClass.js';
  10. import queryParamSanitizer from './middleware/queryParamSanitizer.js';
  11. import commonRouter from './api/common/routes.js';
  12. import mpsRouter from './api/mps/routes.js';
  13. import phonicsRouter from './api/phonics/routes.js';
  14. import pinyinRouter from './api/pinyin/routes.js';
  15. import hanziRouter from './api/hanzi/routes.js';
  16. import mathcalculateRouter from './api/mathcalculate/routes.js';
  17. import webRouter from './api/web/routes.js';
  18. const __dirname = path.dirname(fileURLToPath(import.meta.url));
  19. const app = new Koa();
  20. // 使用中间件
  21. app.use(bodyParser());
  22. app.use(queryParamSanitizer());
  23. // 静态文件服务
  24. app.use(serve(__dirname + '/../public'));
  25. // 错误处理
  26. app.use(async (ctx, next) => {
  27. try {
  28. await next();
  29. } catch (err) {
  30. ctx.status = err.status || 500;
  31. ctx.body = {
  32. error: err.message,
  33. url: ctx.url
  34. };
  35. console.log("error_url:"+ctx.url);
  36. ctx.app.emit('error', err, ctx);
  37. }
  38. });
  39. // 设置签名密钥
  40. app.keys = ['some secret hurr'];
  41. const SessionConfig = {
  42. key: 'koa.sess', // cookie密钥
  43. maxAge: 86400000, // cookie的过期时间 maxAge in ms (default is 1 days)
  44. autoCommit: true, // 自动提交头部
  45. overwrite: true, // 是否允许重写
  46. httpOnly: true, // 是否允许js访问cookie
  47. signed: true, // 签名默认true
  48. rolling: true, // 每次请求强制设置cookie,重置cookie过期时间(默认:false)
  49. renew: true, // 当session快过期时更新session,以避免用户在操作时session过期
  50. secure: process.env.NODE_ENV === 'production', // 仅在HTTPS下发送cookie
  51. sameSite: 'lax', // 跨站点cookie设置,'strict'|'lax'|'none'
  52. };
  53. // 使用session中间件
  54. app.use(session(SessionConfig, app));
  55. //中间件
  56. app.use(decryptUrlMiddle());
  57. // 注册路由
  58. app.use(commonRouter.routes());
  59. app.use(commonRouter.allowedMethods());
  60. app.use(mpsRouter.routes());
  61. app.use(mpsRouter.allowedMethods());
  62. app.use(phonicsRouter.routes());
  63. app.use(phonicsRouter.allowedMethods());
  64. app.use(pinyinRouter.routes());
  65. app.use(pinyinRouter.allowedMethods());
  66. app.use(hanziRouter.routes());
  67. app.use(hanziRouter.allowedMethods());
  68. app.use(mathcalculateRouter.routes());
  69. app.use(mathcalculateRouter.allowedMethods());
  70. app.use(webRouter.routes());
  71. app.use(webRouter.allowedMethods());
  72. // 启动服务器
  73. app.listen(config.port, () => {
  74. console.log('Server IP:', stringUtils.GetServerIP());
  75. console.log(`Server running on port ${config.port}`);
  76. });