Fastify & NestJS - 如何在拦截器中设置响应 headers

Fastify & NestJS - How to set response headers in interceptor

我正在尝试在我的拦截器中设置响应 headers,但我发现的任何方法都没有成功。我试过:

 const request = context.switchToHttp().getRequest();
 const response = context.switchToHttp().getResponse();
 <snippet of code from below>
 return next.handle();

运气不好。第一个选项说 res 是未定义的,第二个 "Cannot read property 'Symbol(fastify.reply.headers)' of undefined",其他的什么都不做。

我的 main.ts 中的 FastifyAdapter 有以下功能:

HeaderInterceptor

@Injectable()
export class HeaderInterceptor implements NestInterceptor {
  intercept(context: ExecutionContext, next: CallHandler): Observable<any> {
    return next.handle().pipe(
      tap(() => {
        const res = context.switchToHttp().getResponse<FastifyReply<ServerResponse>>();
        res.header('foo', 'bar');
      })
    );
  }
}

使用 .getResponse<FastifyReply<ServerResponse>>() 为我们提供了正确的类型。

应用模块

@Module({
  imports: [],
  controllers: [AppController],
  providers: [
    AppService,
    {
      provide: APP_INTERCEPTOR,
      useClass: HeaderInterceptor,
    },
  ],
})
export class AppModule {}

将拦截器绑定到整个服务器

curl 命令

▶ curl http://localhost:3000 -v
* Rebuilt URL to: http://localhost:3000/
*   Trying 127.0.0.1...
* TCP_NODELAY set
* Connected to localhost (127.0.0.1) port 3000 (#0)
> GET / HTTP/1.1
> Host: localhost:3000
> User-Agent: curl/7.54.0
> Accept: */*
> 
< HTTP/1.1 200 OK
< foo: bar
< content-type: text/plain; charset=utf-8
< content-length: 12
< Date: Thu, 14 May 2020 14:09:22 GMT
< Connection: keep-alive
< 
* Connection #0 to host localhost left intact
Hello World!% 

如您所见,响应返回 header foo: bar,这意味着拦截器添加了预期的内容。

查看您的错误,您的第二次尝试 可能 实际上是 response.headers('my-header', 'xyz)。无论如何,上面的内容对我来说是在 nest new 应用程序和最新版本的 Nest 软件包上工作。