@RequestHeader

您可以使用 @RequestHeader 注解将请求头绑定到控制器中的方法参数。

考虑以下带有请求头的请求:

Host                    localhost:8080
Accept                  text/html,application/xhtml+xml,application/xml;q=0.9
Accept-Language         fr,en-gb;q=0.7,en;q=0.3
Accept-Encoding         gzip,deflate
Accept-Charset          ISO-8859-1,utf-8;q=0.7,*;q=0.7
Keep-Alive              300

以下示例获取 Accept-EncodingKeep-Alive 头的值:

  • Java

@GetMapping("/demo")
public void handle(
    @RequestHeader("Accept-Encoding") String encoding, (1)
    @RequestHeader("Keep-Alive") long keepAlive) { (2)
  //...
}
1 获取 Accept-Encoding 头的值。
2 获取 Keep-Alive 头的值。

如果目标方法参数类型不是 String,则自动应用类型转换。 参见 类型转换

当在 Map<String, String>MultiValueMap<String, String>HttpHeaders 参数上使用 @RequestHeader 注解时, 映射将填充所有头值。

内置支持可用于将逗号分隔的字符串转换为字符串数组或集合,或类型转换系统已知的其他类型。 例如,用 @RequestHeader("Accept") 注解的方法参数可以是 String 类型,也可以是 String[]List<String>