Nest.js Controller 解析:探索路由和请求处理的强大功能

2023-11-03 10:47:46 浏览数 (2)

Controller  它 主要是负责 特定路由请求处理并将响应结果返回给客户端。

每个控制器 它会有多个路由,不同路由对应不同的业务请求处理。

Nest  中, 创建一个 控制器,应该使用类 和 装饰器 , 装饰器会使类相关联的数据的关联起来,将请求绑定到相应的控制器。

可以使用Nest-cli 提供的指令 快速创建一个 CURD

代码语言:txt复制
nest g resource [name]

1.3.1  路由

@Controller  是 Nest 的基本控制器,通过修饰器 @Controller  可以将路由分组,模块化进行路由的管理,并最大限度的减少了代码重复性。

路由的 形成 :

  • 控制器装饰器前缀@Controller('user')    
  • 请求方法装饰器结合 @Get('getDeatil')

将形成路由映射user/getDeatail

如何进行路由分组呢?

  • @Controller 接受一个参数,这可参数可选,默认如果不传,  就是 /
  • @Controller(分组名)
代码语言:txt复制
import { Controller, Get, Param, Post } from '@nestjs/common';
import { UserService } from '../service/index';

const result: Object = {
  code: 200,
  data: {
    str: '微信公众号:前端自学社区',
    arrList: [1, 2, 3, 4],
  },
};

@Controller('user')
export class UserController {
  // 使用依赖注入的方式注入一个类
  constructor(private readonly userService: UserService) {}
  @Get('getUserInfo') // 定义http的请求方式为get请求
  getUserInfo(): object {
    // 函数名可以随便定义
    return this.userService.getUserInfo(result); // 控制层调用服务层的getHello()方法
  }
}

通过 访问 http://localhost:3000/user/getUserInfo  就可以访问到响应数据。

@Controller 装饰器 修饰 类,该类就拥有和装饰器关联的属性和功能,传递了一个参数  user ,  说明当前路由分组名称为 user , 当前类下的所有基准路由都是 /user/  开头了。

通过 HTTP 请求方法装饰器  修饰方法,它会方法告诉 Nest 为 HTTP 请求的特定端点创建处理程序。

栗子中,getUserInfo  方法被 @Get 所修饰,所以它是一个 Get 请求。

1.3.2 请求参数装饰器

通过对客户端发起的请求参数做解析处理,Nest 提供的访问请求对象 默认方式为 express .

Nest

express

备注

@Request(), @Req()

req

@Response(), @Res()*

res

@Next()

next

@Session()

req.session

请求携带的session

@Param(key?: string)常用

req.params/  req.params[key]

获取请求携带的动态参数  eg: /user/adxin    daxin 就是动态参数

@Body(key?: string)常用

req.body/  req.body[key]

获取请求体参数

@Query(key?: string)常用

req.query/  req.query[key]

获取 url?id=   携带的参数, 通常是get

@Headers(name?: string)常用

req.headers/  req.headers[name]

获取请求头内容

@Ip()

req.ip

@HostParam()

req.hosts

代码语言:txt复制
  @Get('getQueryUser:id')
  getQueryUser(@Param() params) {
    return this.userService.getQueryUser(params);
  }

Nest 为所有标准 HTTP 方法提供装饰器:

@Get(),  @Post(),  @Put(),  @Delete(),  @Patch(),  @Options(), 和 @Head().  此外, @All()定义处理所有这些的端点。

1.3.3 路由通配符

支持基于模式的路由。  例如,星号用作通配符,将匹配任何字符组合。

代码语言:txt复制
@Get('ab*cd')
findAll() {
  return 'This route uses a wildcard';
}

'ab*cd'路由路径将匹配 abcd,  ab_cd,  abecd, 等等

1.3.4 请求状态码

响应状态码默认为 200 , POST201 , 我们可以通过添加 @HttpCode(...)处理程序级别的装饰器。   指定请求 Code

代码语言:txt复制
@Post()
@HttpCode(204)
create() {
  return 'This action adds a new cat';
}

1.3.5 自定义响应头

可以通过使用 @Header()装饰器或特定于库的响应对象(并调用 res.header()直接地)。

代码语言:txt复制
@Post()
@Header('Cache-Control', 'none')
create() {
  return 'This action adds a new cat';
}

1.3.6 重定向

响应重定向到特定 URL,响应重定向到特定 URL 来重定向,@Redirect()需要两个参数, urlstatusCode,两者都是可选的。  默认值为 statusCode302 ( Found) 如果省略。

代码语言:txt复制
@Get('docs')
@Redirect('https://docs.nestjs.com', 302)
getDocs(@Query('version') version) {
  if (version && version === '5') {
    return { url: 'https://docs.nestjs.com/v5/' };
  }

1.3.7 路由参数

当获取某个文章或数据时,需要动态传递id,那么我们可以使用 Get 请求,或拼接动态 id 来获取,在Nest  中,可以使用 @Param()装饰器,

它用于修饰方法参数,我们可以通过 params  获取请求动态id  .

两种写法:

代码语言:txt复制
@Get(':id')
findOne(@Param() params): string {
  console.log(params.id);
  return `This action returns a #${params.id} cat`;
}
代码语言:txt复制
@Get(':id')
findOne(@Param('id') id: string): string {
  return `This action returns a #${id} cat`;
}

0 人点赞