对于最新稳定版本,请使用 Spring Framework 7.0.6spring-doc.cadn.net.cn

ResponseEntity

ResponseEntity 类似于 @ResponseBody,但包含状态码和响应头。例如:spring-doc.cadn.net.cn

@GetMapping("/something")
public ResponseEntity<String> handle() {
	String body = ... ;
	String etag = ... ;
	return ResponseEntity.ok().eTag(etag).body(body);
}
@GetMapping("/something")
fun handle(): ResponseEntity<String> {
	val body: String = ...
	val etag: String = ...
	return ResponseEntity.ok().eTag(etag).build(body)
}

WebFlux 支持使用单值响应式类型来异步生成ResponseEntity,以及使用单值或多值响应式类型作为响应体。这使得可以结合ResponseEntity实现多种异步响应,如下所示:spring-doc.cadn.net.cn

  • ResponseEntity<Mono<T>>ResponseEntity<Flux<T>> 可以立即确定响应状态和响应头,而响应体则在稍后异步提供。 如果响应体包含 0 到 1 个值,请使用 Mono;如果可能产生多个值,请使用 Fluxspring-doc.cadn.net.cn

  • Mono<ResponseEntity<T>> 可在稍后的异步时间点提供全部三项内容——响应状态、响应头和响应体。这使得响应状态和响应头可以根据异步请求处理的结果而变化。spring-doc.cadn.net.cn

  • Mono<ResponseEntity<Mono<T>>>Mono<ResponseEntity<Flux<T>>> 是另一种可能的选择,尽管不太常见。它们首先异步提供响应状态和响应头,然后再次异步提供响应体。spring-doc.cadn.net.cn