diff --git a/spring-web/src/main/java/org/springframework/http/client/ClientHttpRequestInitializer.java b/spring-web/src/main/java/org/springframework/http/client/ClientHttpRequestInitializer.java new file mode 100644 index 00000000000..d2d06e4981e --- /dev/null +++ b/spring-web/src/main/java/org/springframework/http/client/ClientHttpRequestInitializer.java @@ -0,0 +1,45 @@ +/* + * 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. + * You may obtain a copy of the License at + * + * https://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package org.springframework.http.client; + +import org.springframework.http.client.support.HttpAccessor; + +/** + * Callback interface for initializing a {@link ClientHttpRequest} prior to it + * being used. + * + *
Typically used with {@link HttpAccessor} and subclasses such as + * {@link org.springframework.web.client.RestTemplate RestTemplate} to apply + * consistent settings or headers to each request. + * + *
Unlike {@link ClientHttpRequestInterceptor}, this interface can apply
+ * customizations without needing to read the entire request body into memory.
+ *
+ * @author Phillip Webb
+ * @since 5.2
+ * @see HttpAccessor#getClientHttpRequestInitializers()
+ */
+@FunctionalInterface
+public interface ClientHttpRequestInitializer {
+
+ /**
+ * Initialize the given client HTTP request.
+ * @param request the request to configure
+ */
+ void initialize(ClientHttpRequest request);
+
+}
diff --git a/spring-web/src/main/java/org/springframework/http/client/support/HttpAccessor.java b/spring-web/src/main/java/org/springframework/http/client/support/HttpAccessor.java
index 895fde9ef05..bd1fec8235b 100644
--- a/spring-web/src/main/java/org/springframework/http/client/support/HttpAccessor.java
+++ b/spring-web/src/main/java/org/springframework/http/client/support/HttpAccessor.java
@@ -1,5 +1,5 @@
/*
- * Copyright 2002-2018 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.
@@ -18,13 +18,17 @@ package org.springframework.http.client.support;
import java.io.IOException;
import java.net.URI;
+import java.util.ArrayList;
+import java.util.List;
import org.apache.commons.logging.Log;
+import org.springframework.core.annotation.AnnotationAwareOrderComparator;
import org.springframework.http.HttpLogging;
import org.springframework.http.HttpMethod;
import org.springframework.http.client.ClientHttpRequest;
import org.springframework.http.client.ClientHttpRequestFactory;
+import org.springframework.http.client.ClientHttpRequestInitializer;
import org.springframework.http.client.SimpleClientHttpRequestFactory;
import org.springframework.util.Assert;
@@ -49,6 +53,8 @@ public abstract class HttpAccessor {
private ClientHttpRequestFactory requestFactory = new SimpleClientHttpRequestFactory();
+ private List The initializers will get sorted according to their order
+ * before the {@link ClientHttpRequest} is initialized.
+ */
+ public void setClientHttpRequestInitializers(
+ List The returned {@link List} is active and may get appended to.
+ */
+ public List