web-dev-qa-db-ja.com

Nest.jsからアセットを提供し、画像リクエストを検出するミドルウェアを追加する方法

Nest.jsサーバーから画像を提供し、すべてのリクエストを追跡するためのミドルウェアを追加しようとしていますが、それを機能させる唯一の方法はexpress

import { NestFactory } from '@nestjs/core';
import * as bodyParser from "body-parser";
import {AppModule} from "./app.module";
import * as path from "path";
import * as express from 'express';


async function bootstrap() {
  const app = await NestFactory.create(AppModule);
  app.use(bodyParser.json({limit: '50mb'}));

  app.use(function(req, res, next){
    next();
  });
  //
  app.use('/api/track/',express.static(path.join(__dirname, '/public'))); //Serves resources from public folder
  app.use('/api/track/:img', function (req, res, next) {
    console.log('do something');
    next();
  });

  await app.listen(3333);
}

bootstrap();

コントローラまたはミドルウェアを使用してどのように実装できますか?

6
user8987378

nestjs docは、静的ファイルを提供する方法を教えてくれます。 要するに、ここではその方法を示します。

Main.tsでアセットのルートディレクトリを指定します

app.useStaticAssets(path.join(__dirname, '/../public'));

@Resアノテーションを使用して、Express FrameworkのsendFileメソッドを使用できるようにします。

@Get('track/:imgId')
test(@Param('imgId') imgId, @Res() res) {
  const imgPath = getImgPath(imgId);
  return res.sendFile(imgPath, { root: 'public' });
}

このソリューションでは、nestjsのインストールで内部でExpressを使用することを前提としています。


出典:

14
Upvote