Skip to content

Commit bd1f34e

Browse files
sokomishalovrstoyanchev
authored andcommitted
Apply adapters to client request headers after committed
See gh-27768
1 parent a490723 commit bd1f34e

File tree

5 files changed

+42
-20
lines changed

5 files changed

+42
-20
lines changed

spring-web/src/main/java/org/springframework/http/client/reactive/AbstractClientHttpRequest.java

+9-2
Original file line numberDiff line numberDiff line change
@@ -74,14 +74,13 @@ public AbstractClientHttpRequest(HttpHeaders headers) {
7474
this.cookies = new LinkedMultiValueMap<>();
7575
}
7676

77-
7877
@Override
7978
public HttpHeaders getHeaders() {
8079
if (this.readOnlyHeaders != null) {
8180
return this.readOnlyHeaders;
8281
}
8382
else if (State.COMMITTED.equals(this.state.get())) {
84-
this.readOnlyHeaders = HttpHeaders.readOnlyHttpHeaders(this.headers);
83+
this.readOnlyHeaders = initReadOnlyHeaders();
8584
return this.readOnlyHeaders;
8685
}
8786
else {
@@ -144,6 +143,14 @@ protected Mono<Void> doCommit(@Nullable Supplier<? extends Publisher<Void>> writ
144143
return Flux.concat(actions).then();
145144
}
146145

146+
/**
147+
* Initialize read-only headers with underlying request headers.
148+
* @return read-only headers
149+
*/
150+
protected HttpHeaders initReadOnlyHeaders() {
151+
return HttpHeaders.readOnlyHttpHeaders(this.headers);
152+
}
153+
147154

148155
/**
149156
* Apply header changes from {@link #getHeaders()} to the underlying request.

spring-web/src/main/java/org/springframework/http/client/reactive/HttpComponentsClientHttpRequest.java

+5
Original file line numberDiff line numberDiff line change
@@ -118,6 +118,11 @@ public Mono<Void> setComplete() {
118118
return doCommit();
119119
}
120120

121+
@Override
122+
protected HttpHeaders initReadOnlyHeaders() {
123+
return HttpHeaders.readOnlyHttpHeaders(new HttpComponentsHeadersAdapter(this.httpRequest));
124+
}
125+
121126
@Override
122127
protected void applyHeaders() {
123128
HttpHeaders headers = getHeaders();

spring-web/src/main/java/org/springframework/http/client/reactive/HttpComponentsHeadersAdapter.java

+18-18
Original file line numberDiff line numberDiff line change
@@ -28,7 +28,7 @@
2828
import java.util.Set;
2929

3030
import org.apache.hc.core5.http.Header;
31-
import org.apache.hc.core5.http.HttpResponse;
31+
import org.apache.hc.core5.http.HttpMessage;
3232

3333
import org.springframework.http.HttpHeaders;
3434
import org.springframework.lang.Nullable;
@@ -44,23 +44,23 @@
4444
*/
4545
class HttpComponentsHeadersAdapter implements MultiValueMap<String, String> {
4646

47-
private final HttpResponse response;
47+
private final HttpMessage message;
4848

4949

50-
HttpComponentsHeadersAdapter(HttpResponse response) {
51-
this.response = response;
50+
HttpComponentsHeadersAdapter(HttpMessage message) {
51+
this.message = message;
5252
}
5353

5454

5555
@Override
5656
public String getFirst(String key) {
57-
Header header = this.response.getFirstHeader(key);
57+
Header header = this.message.getFirstHeader(key);
5858
return (header != null ? header.getValue() : null);
5959
}
6060

6161
@Override
6262
public void add(String key, @Nullable String value) {
63-
this.response.addHeader(key, value);
63+
this.message.addHeader(key, value);
6464
}
6565

6666
@Override
@@ -75,7 +75,7 @@ public void addAll(MultiValueMap<String, String> values) {
7575

7676
@Override
7777
public void set(String key, @Nullable String value) {
78-
this.response.setHeader(key, value);
78+
this.message.setHeader(key, value);
7979
}
8080

8181
@Override
@@ -86,37 +86,37 @@ public void setAll(Map<String, String> values) {
8686
@Override
8787
public Map<String, String> toSingleValueMap() {
8888
Map<String, String> map = CollectionUtils.newLinkedHashMap(size());
89-
this.response.headerIterator().forEachRemaining(h -> map.putIfAbsent(h.getName(), h.getValue()));
89+
this.message.headerIterator().forEachRemaining(h -> map.putIfAbsent(h.getName(), h.getValue()));
9090
return map;
9191
}
9292

9393
@Override
9494
public int size() {
95-
return this.response.getHeaders().length;
95+
return this.message.getHeaders().length;
9696
}
9797

9898
@Override
9999
public boolean isEmpty() {
100-
return (this.response.getHeaders().length == 0);
100+
return (this.message.getHeaders().length == 0);
101101
}
102102

103103
@Override
104104
public boolean containsKey(Object key) {
105-
return (key instanceof String && this.response.containsHeader((String) key));
105+
return (key instanceof String && this.message.containsHeader((String) key));
106106
}
107107

108108
@Override
109109
public boolean containsValue(Object value) {
110110
return (value instanceof String &&
111-
Arrays.stream(this.response.getHeaders()).anyMatch(h -> h.getValue().equals(value)));
111+
Arrays.stream(this.message.getHeaders()).anyMatch(h -> h.getValue().equals(value)));
112112
}
113113

114114
@Nullable
115115
@Override
116116
public List<String> get(Object key) {
117117
List<String> values = null;
118118
if (containsKey(key)) {
119-
Header[] headers = this.response.getHeaders((String) key);
119+
Header[] headers = this.message.getHeaders((String) key);
120120
values = new ArrayList<>(headers.length);
121121
for (Header header : headers) {
122122
values.add(header.getValue());
@@ -138,7 +138,7 @@ public List<String> put(String key, List<String> values) {
138138
public List<String> remove(Object key) {
139139
if (key instanceof String) {
140140
List<String> oldValues = get(key);
141-
this.response.removeHeaders((String) key);
141+
this.message.removeHeaders((String) key);
142142
return oldValues;
143143
}
144144
return null;
@@ -151,13 +151,13 @@ public void putAll(Map<? extends String, ? extends List<String>> map) {
151151

152152
@Override
153153
public void clear() {
154-
this.response.setHeaders();
154+
this.message.setHeaders();
155155
}
156156

157157
@Override
158158
public Set<String> keySet() {
159159
Set<String> keys = new LinkedHashSet<>(size());
160-
for (Header header : this.response.getHeaders()) {
160+
for (Header header : this.message.getHeaders()) {
161161
keys.add(header.getName());
162162
}
163163
return keys;
@@ -166,7 +166,7 @@ public Set<String> keySet() {
166166
@Override
167167
public Collection<List<String>> values() {
168168
Collection<List<String>> values = new ArrayList<>(size());
169-
for (Header header : this.response.getHeaders()) {
169+
for (Header header : this.message.getHeaders()) {
170170
values.add(get(header.getName()));
171171
}
172172
return values;
@@ -196,7 +196,7 @@ public String toString() {
196196

197197
private class EntryIterator implements Iterator<Entry<String, List<String>>> {
198198

199-
private Iterator<Header> iterator = response.headerIterator();
199+
private final Iterator<Header> iterator = message.headerIterator();
200200

201201
@Override
202202
public boolean hasNext() {

spring-web/src/main/java/org/springframework/http/client/reactive/JettyClientHttpRequest.java

+4
Original file line numberDiff line numberDiff line change
@@ -126,6 +126,10 @@ public void failed(Throwable t) {
126126
});
127127
}
128128

129+
@Override
130+
protected HttpHeaders initReadOnlyHeaders() {
131+
return HttpHeaders.readOnlyHttpHeaders(new JettyHeadersAdapter(this.jettyRequest.getHeaders()));
132+
}
129133

130134
@Override
131135
protected void applyCookies() {

spring-web/src/main/java/org/springframework/http/client/reactive/ReactorClientHttpRequest.java

+6
Original file line numberDiff line numberDiff line change
@@ -31,6 +31,7 @@
3131
import org.springframework.core.io.buffer.DataBuffer;
3232
import org.springframework.core.io.buffer.DataBufferFactory;
3333
import org.springframework.core.io.buffer.NettyDataBufferFactory;
34+
import org.springframework.http.HttpHeaders;
3435
import org.springframework.http.HttpMethod;
3536
import org.springframework.http.ZeroCopyHttpOutputMessage;
3637

@@ -121,6 +122,11 @@ public Mono<Void> setComplete() {
121122
return doCommit(this.outbound::then);
122123
}
123124

125+
@Override
126+
protected HttpHeaders initReadOnlyHeaders() {
127+
return HttpHeaders.readOnlyHttpHeaders(new NettyHeadersAdapter(this.request.requestHeaders()));
128+
}
129+
124130
@Override
125131
protected void applyHeaders() {
126132
getHeaders().forEach((key, value) -> this.request.requestHeaders().set(key, value));

0 commit comments

Comments
 (0)