web-dev-qa-db-fra.com

comment diffuser des actifs depuis Nest.js et ajouter un middleware pour détecter la demande d'image

J'essaie de diffuser une image à partir du serveur Nest.js et d'ajouter un middleware pour suivre toutes les demandes, mais la seule façon de le faire fonctionner était avec 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();

Comment puis-je l'implémenter en utilisant le contrôleur ou le middleware?

6
user8987378

Le doc nestjs vous explique comment servir des fichiers statiques. En bref, voici comment vous le faites:

Spécifiez le répertoire racine de vos actifs dans votre main.ts

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

Utilisez l'annotation @Res pour pouvoir utiliser la méthode sendFile du framework express

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

Cette solution suppose que votre installation nestjs utilise express sous le capot.


Sources:

14
Upvote