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();
request.res.headers['my-header'] = 'xyz'
response.header('my-header', 'xyz')
response.headers['my-header'] = 'xyz'
response.header['my-header'] = 'xyz'
运气不好。第一个选项说 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 软件包上工作。
我正在尝试在我的拦截器中设置响应 headers,但我发现的任何方法都没有成功。我试过:
const request = context.switchToHttp().getRequest();
const response = context.switchToHttp().getResponse();
<snippet of code from below>
return next.handle();
request.res.headers['my-header'] = 'xyz'
response.header('my-header', 'xyz')
response.headers['my-header'] = 'xyz'
response.header['my-header'] = 'xyz'
运气不好。第一个选项说 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 软件包上工作。