Browse Source

Merge pull request #23764 from ask4gilles/23738

pull/23931/head
Rossen Stoyanchev 5 years ago
parent
commit
88ec452dee
  1. 19
      spring-web/src/main/java/org/springframework/web/client/RestClientResponseException.java

19
spring-web/src/main/java/org/springframework/web/client/RestClientResponseException.java

@ -1,5 +1,5 @@ @@ -1,5 +1,5 @@
/*
* Copyright 2002-2017 the original author or authors.
* Copyright 2002-2019 the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
@ -33,7 +33,7 @@ public class RestClientResponseException extends RestClientException { @@ -33,7 +33,7 @@ public class RestClientResponseException extends RestClientException {
private static final long serialVersionUID = -8803556342728481792L;
private static final Charset DEFAULT_CHARSET = StandardCharsets.ISO_8859_1;
private static final Charset DEFAULT_CHARSET = StandardCharsets.UTF_8;
private final int rawStatusCode;
@ -99,11 +99,22 @@ public class RestClientResponseException extends RestClientException { @@ -99,11 +99,22 @@ public class RestClientResponseException extends RestClientException {
}
/**
* Return the response body as a string.
* Return the response body converted to String. The charset used is that
* of the response "Content-Type" or otherwise {@code "UTF-8"}.
*/
public String getResponseBodyAsString() {
return getResponseBodyAsString(DEFAULT_CHARSET);
}
/**
* Return the response body converted to String. The charset used is that
* of the response "Content-Type" or otherwise the one given.
* @param fallbackCharset the charset to use on if the response doesn't specify.
* @since 5.1.11
*/
public String getResponseBodyAsString(Charset fallbackCharset) {
if (this.responseCharset == null) {
return new String(this.responseBody, DEFAULT_CHARSET);
return new String(this.responseBody, fallbackCharset);
}
try {
return new String(this.responseBody, this.responseCharset);

Loading…
Cancel
Save