前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >手把手搭建koa2后端服务器-日志模块和文件上传

手把手搭建koa2后端服务器-日志模块和文件上传

作者头像
星星在线
发布2022-03-29 17:47:46
7770
发布2022-03-29 17:47:46
举报
文章被收录于专栏:python爬虫实战之路

添加日志模块

日志记录是网站开发必备的模块,方便我们进行线上问题定位。

安装 log4js

代码语言:javascript
复制
yarn add log4js
yarn add -D @types/log4js

配置和使用

  • 配置文件中增加日志配置 src/config/index.ts
代码语言:javascript
复制
log: {
    appenders: {
      out: { type: 'stdout' },
      app: {
        type: 'file',
        filename: 'logs/app.log',
        pattern: '-yyyy-MM-dd',
        maxLogSize: 10485760,
        numBackups: 3,
      },
    },
    categories: {
      default: { appenders: ['out', 'app'], level: 'info' },
    },
  }
  • 创建日志处理文件 src/utils/logger.ts
代码语言:javascript
复制
import { configure, getLogger } from 'log4js';
import config from '../config';

configure(config.log);

export default getLogger();
  • 创建日志记录中间件 src/middlewares/logMiddleWare.ts

统计请求耗时

代码语言:javascript
复制
import type { Context, Next } from 'koa';
import logger from '../utils/logger';

const logMiddleWare = () => {
  return async (ctx: Context, next: Next) => {
    const start = new Date();
    await next();
    const ms = new Date().getTime() - start.getTime();
    logger.info(`${ctx.method} ${ctx.url} - ${ms}ms`);
  };
};

export default logMiddleWare;
  • 注册中间件 src/app.ts
代码语言:javascript
复制
import logMiddleWare from './middlewares/logMiddleWare';

app.use(logMiddleWare());

文件上传

koa-body 配置文件上传

代码语言:javascript
复制
// src/index.ts
KoaBody({
  // 启用表单解析,可以支持文件上传
  multipart: true,
  formidable: {
    // 文件上传路径
    uploadDir: './uploads',

    // 保持文件的扩展名
    keepExtensions: true,

    // 文件上传大小限制,默认5M
    maxFieldsSize: 5 * 1024 * 1024,

    // 保持文件的扩展名
    onFileBegin: (name, file) => {
      // 文件上传前的设置
      // console.log(name, file);
    },
  },
})

文件上传接口 src/controller/common/view.ts

代码语言:javascript
复制
import { Context } from 'koa';
import type { Files, File as FileType } from 'formidable';

class IndexController {
  ......
  async upload(ctx: Context) {
    const files: Files | undefined = ctx.request.files;
    if (files) {
      const data: { url: string; name: string; size: number }[] = [];
      for (const key in files) {
        const file: FileType = files[key] as FileType;
        data.push({
          url: file.path,
          name: file.name!,
          size: file.size,
        });
      }
      response.success(ctx, data, '上传成功');
    } else {
      response.error(ctx, '上传失败');
    }
  }
}

配置路由

代码语言:javascript
复制
// src/controller/common/view.ts
import IndexController from '../controller/common/view';

router.post('/upload', IndexController.upload);
本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2022-01-23,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 python爬虫实战之路 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 安装 log4js
  • 配置和使用
  • 文件上传
  • koa-body 配置文件上传
  • 文件上传接口 src/controller/common/view.ts
  • 配置路由
相关产品与服务
消息队列 TDMQ
消息队列 TDMQ (Tencent Distributed Message Queue)是腾讯基于 Apache Pulsar 自研的一个云原生消息中间件系列,其中包含兼容Pulsar、RabbitMQ、RocketMQ 等协议的消息队列子产品,得益于其底层计算与存储分离的架构,TDMQ 具备良好的弹性伸缩以及故障恢复能力。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档