如何在NestJS响应中设置标头字段?

时间:2020-05-09 13:49:32

标签: typescript nestjs fastify

我正在尝试:

    @Post('login')
    async login(@Body() body: AuthDto, @Res() res: Response) {
        const loginResponse = await this.authService.login(body);
        console.log('loginResponse', loginResponse)
        res.headers.set('x-access-token', loginResponse.access_token)
        return loginResponse
    }

但没有骰子。我收到错误消息:

TypeError: Cannot read property 'set' of undefined

3 个答案:

答案 0 :(得分:2)

并非最优雅的方式:return res.set({ 'x-access-token': loginResponse.access_token }).json(loginResponse);

我将此逻辑分离为一个拦截器,检查响应对于路径/ login是否有效,如果是,则返回正确的标头(使用loginResponse中的某些值)

import { Controller, Get, Response } from '@nestjs/common';
import { Response as Res } from 'express';
import { AppService } from './app.service';

@Controller()
export class AppController {
  constructor(private readonly appService: AppService) {}

  @Get()
  getHello(@Response() res: Res): Res {
    return res.set({ 'x-access-token': 1 }).json({ hello: 'world' });
  }

  @Get()
  getHelloAlt(@Response() res) {
    return res.set({ 'x-access-token': 1 }).json({ hello: 'world' });
  }
}

这是我的工作版本,请注意Express Response,而不是Nest.js。

编辑:从Nest.js / common导入的类型是装饰器函数,而不使用任何类型,从Express.js导入响应。

答案 1 :(得分:1)

<块引用>

要指定自定义响应标头,您可以使用 @Header() 装饰器或特定于库的响应对象(并直接调用 res.header())。

@nestjs/common package 导入标题。

@Post()
@Header('Cache-Control', 'none')
create() {
  return 'This action adds a new cat';
}

答案 2 :(得分:0)

我使用拦截器。由于我想在响应的标头中添加一个字段来指示我的服务,因此我也将其设置为全局拦截器,但您也可以通过路由使用它。

response-add-access-token-to-header.interceptor.ts

import { CallHandler, ExecutionContext, Injectable, NestInterceptor } from '@nestjs/common';
import { Observable } from 'rxjs';

import { Response as ExpressResponse } from 'express';

@Injectable()
export class ResponseAddAccessTokenToHeaderInterceptor implements NestInterceptor {
    intercept(context:ExecutionContext, next:CallHandler): Observable<any> {

        const ResponseObj:ExpressResponse = context.switchToHttp().getResponse();
        ResponseObj.setHeader('x-access-token', 'Your Data' );
        return next.handle();
    }
}

要全局添加,调整 main.ts:

async function bootstrap() {
    const app = await NestFactory.create(AppModule);
    app.useGlobalInterceptors(new ResponseAddAccessTokenToHeaderInterceptor());
    await app.listen(8080);
}
bootstrap();