Multi-value headers in ResponseStatusException
Closes gh-24261
This commit is contained in:
parent
f9c1565f4e
commit
ea6d2ea1ce
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
* Copyright 2002-2019 the original author or authors.
|
* Copyright 2002-2020 the original author or authors.
|
||||||
*
|
*
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
* you may not use this file except in compliance with the License.
|
* you may not use this file except in compliance with the License.
|
||||||
|
@ -22,12 +22,12 @@ import java.util.HashSet;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
|
||||||
|
import org.springframework.http.HttpHeaders;
|
||||||
import org.springframework.http.HttpMethod;
|
import org.springframework.http.HttpMethod;
|
||||||
import org.springframework.http.HttpStatus;
|
import org.springframework.http.HttpStatus;
|
||||||
import org.springframework.lang.Nullable;
|
import org.springframework.lang.Nullable;
|
||||||
import org.springframework.util.Assert;
|
import org.springframework.util.Assert;
|
||||||
import org.springframework.util.CollectionUtils;
|
import org.springframework.util.CollectionUtils;
|
||||||
import org.springframework.util.StringUtils;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Exception for errors that fit response status 405 (method not allowed).
|
* Exception for errors that fit response status 405 (method not allowed).
|
||||||
|
@ -62,11 +62,24 @@ public class MethodNotAllowedException extends ResponseStatusException {
|
||||||
* Return a Map with an "Allow" header.
|
* Return a Map with an "Allow" header.
|
||||||
* @since 5.1.11
|
* @since 5.1.11
|
||||||
*/
|
*/
|
||||||
|
@SuppressWarnings("deprecation")
|
||||||
@Override
|
@Override
|
||||||
public Map<String, String> getHeaders() {
|
public Map<String, String> getHeaders() {
|
||||||
return !CollectionUtils.isEmpty(this.httpMethods) ?
|
return getResponseHeaders().toSingleValueMap();
|
||||||
Collections.singletonMap("Allow", StringUtils.collectionToDelimitedString(this.httpMethods, ", ")) :
|
}
|
||||||
Collections.emptyMap();
|
|
||||||
|
/**
|
||||||
|
* Return HttpHeaders with an "Allow" header.
|
||||||
|
* @since 5.1.13
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public HttpHeaders getResponseHeaders() {
|
||||||
|
if (CollectionUtils.isEmpty(this.httpMethods)) {
|
||||||
|
return HttpHeaders.EMPTY;
|
||||||
|
}
|
||||||
|
HttpHeaders headers = new HttpHeaders();
|
||||||
|
headers.setAllow(this.httpMethods);
|
||||||
|
return headers;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
* Copyright 2002-2019 the original author or authors.
|
* Copyright 2002-2020 the original author or authors.
|
||||||
*
|
*
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
* you may not use this file except in compliance with the License.
|
* you may not use this file except in compliance with the License.
|
||||||
|
@ -20,6 +20,7 @@ import java.util.Collections;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
|
import org.springframework.http.HttpHeaders;
|
||||||
import org.springframework.http.HttpStatus;
|
import org.springframework.http.HttpStatus;
|
||||||
import org.springframework.http.MediaType;
|
import org.springframework.http.MediaType;
|
||||||
import org.springframework.util.CollectionUtils;
|
import org.springframework.util.CollectionUtils;
|
||||||
|
@ -57,11 +58,24 @@ public class NotAcceptableStatusException extends ResponseStatusException {
|
||||||
* Return a Map with an "Accept" header.
|
* Return a Map with an "Accept" header.
|
||||||
* @since 5.1.11
|
* @since 5.1.11
|
||||||
*/
|
*/
|
||||||
|
@SuppressWarnings("deprecation")
|
||||||
@Override
|
@Override
|
||||||
public Map<String, String> getHeaders() {
|
public Map<String, String> getHeaders() {
|
||||||
return !CollectionUtils.isEmpty(this.supportedMediaTypes) ?
|
return getResponseHeaders().toSingleValueMap();
|
||||||
Collections.singletonMap("Accept", MediaType.toString(this.supportedMediaTypes)) :
|
}
|
||||||
Collections.emptyMap();
|
|
||||||
|
/**
|
||||||
|
* Return HttpHeaders with an "Accept" header, or an empty instance.
|
||||||
|
* @since 5.1.13
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public HttpHeaders getResponseHeaders() {
|
||||||
|
if (CollectionUtils.isEmpty(this.supportedMediaTypes)) {
|
||||||
|
return HttpHeaders.EMPTY;
|
||||||
|
}
|
||||||
|
HttpHeaders headers = new HttpHeaders();
|
||||||
|
headers.setAccept(this.supportedMediaTypes);
|
||||||
|
return headers;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
* Copyright 2002-2019 the original author or authors.
|
* Copyright 2002-2020 the original author or authors.
|
||||||
*
|
*
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
* you may not use this file except in compliance with the License.
|
* you may not use this file except in compliance with the License.
|
||||||
|
@ -21,6 +21,7 @@ import java.util.Map;
|
||||||
|
|
||||||
import org.springframework.core.NestedExceptionUtils;
|
import org.springframework.core.NestedExceptionUtils;
|
||||||
import org.springframework.core.NestedRuntimeException;
|
import org.springframework.core.NestedRuntimeException;
|
||||||
|
import org.springframework.http.HttpHeaders;
|
||||||
import org.springframework.http.HttpStatus;
|
import org.springframework.http.HttpStatus;
|
||||||
import org.springframework.lang.Nullable;
|
import org.springframework.lang.Nullable;
|
||||||
import org.springframework.util.Assert;
|
import org.springframework.util.Assert;
|
||||||
|
@ -82,14 +83,33 @@ public class ResponseStatusException extends NestedRuntimeException {
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Return response headers associated with the exception, possibly required
|
* Return headers associated with the exception that should be added to the
|
||||||
* for the given status code (e.g. "Allow", "Accept").
|
* error response, e.g. "Allow", "Accept", etc.
|
||||||
|
* <p>The default implementation in this class returns an empty map.
|
||||||
* @since 5.1.11
|
* @since 5.1.11
|
||||||
|
* @deprecated as of 5.1.13 in favor of {@link #getResponseHeaders()}
|
||||||
*/
|
*/
|
||||||
|
@Deprecated
|
||||||
public Map<String, String> getHeaders() {
|
public Map<String, String> getHeaders() {
|
||||||
return Collections.emptyMap();
|
return Collections.emptyMap();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return headers associated with the exception that should be added to the
|
||||||
|
* error response, e.g. "Allow", "Accept", etc.
|
||||||
|
* <p>The default implementation in this class returns empty headers.
|
||||||
|
* @since 5.1.13
|
||||||
|
*/
|
||||||
|
public HttpHeaders getResponseHeaders() {
|
||||||
|
Map<String, String> headers = getHeaders();
|
||||||
|
if (headers.isEmpty()) {
|
||||||
|
return HttpHeaders.EMPTY;
|
||||||
|
}
|
||||||
|
HttpHeaders result = new HttpHeaders();
|
||||||
|
getHeaders().forEach(result::add);
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The reason explaining the exception (potentially {@code null} or empty).
|
* The reason explaining the exception (potentially {@code null} or empty).
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
* Copyright 2002-2019 the original author or authors.
|
* Copyright 2002-2020 the original author or authors.
|
||||||
*
|
*
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
* you may not use this file except in compliance with the License.
|
* you may not use this file except in compliance with the License.
|
||||||
|
@ -92,8 +92,9 @@ public class ResponseStatusExceptionHandler implements WebExceptionHandler {
|
||||||
if (status != null) {
|
if (status != null) {
|
||||||
if (response.setStatusCode(status)) {
|
if (response.setStatusCode(status)) {
|
||||||
if (ex instanceof ResponseStatusException) {
|
if (ex instanceof ResponseStatusException) {
|
||||||
((ResponseStatusException) ex).getHeaders()
|
((ResponseStatusException) ex).getResponseHeaders()
|
||||||
.forEach((name, value) -> response.getHeaders().add(name, value));
|
.forEach((name, values) ->
|
||||||
|
values.forEach(value -> response.getHeaders().add(name, value)));
|
||||||
}
|
}
|
||||||
result = true;
|
result = true;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue