commit
450cd712c9
|
@ -63,6 +63,11 @@ public class NettyWebServerFactoryCustomizer
|
|||
map.from(nettyProperties::getIdleTimeout).to((idleTimeout) -> customizeIdleTimeout(factory, idleTimeout));
|
||||
map.from(nettyProperties::getMaxKeepAliveRequests)
|
||||
.to((maxKeepAliveRequests) -> customizeMaxKeepAliveRequests(factory, maxKeepAliveRequests));
|
||||
if (this.serverProperties.getHttp2() != null && this.serverProperties.getHttp2().isEnabled()) {
|
||||
map.from(this.serverProperties.getMaxHttpRequestHeaderSize())
|
||||
.whenNonNull()
|
||||
.to((size) -> customizeHttp2MaxHeaderSize(factory, size.toBytes()));
|
||||
}
|
||||
customizeRequestDecoder(factory, map);
|
||||
}
|
||||
|
||||
|
@ -112,4 +117,9 @@ public class NettyWebServerFactoryCustomizer
|
|||
factory.addServerCustomizers((httpServer) -> httpServer.maxKeepAliveRequests(maxKeepAliveRequests));
|
||||
}
|
||||
|
||||
private void customizeHttp2MaxHeaderSize(NettyReactiveWebServerFactory factory, long size) {
|
||||
factory.addServerCustomizers(
|
||||
((httpServer) -> httpServer.http2Settings((settings) -> settings.maxHeaderListSize(size))));
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -26,6 +26,7 @@ import org.junit.jupiter.api.extension.ExtendWith;
|
|||
import org.mockito.ArgumentCaptor;
|
||||
import org.mockito.Captor;
|
||||
import org.mockito.junit.jupiter.MockitoExtension;
|
||||
import reactor.netty.http.Http2SettingsSpec;
|
||||
import reactor.netty.http.server.HttpRequestDecoderSpec;
|
||||
import reactor.netty.http.server.HttpServer;
|
||||
|
||||
|
@ -126,9 +127,20 @@ class NettyWebServerFactoryCustomizerTests {
|
|||
verifyMaxKeepAliveRequests(factory, 100);
|
||||
}
|
||||
|
||||
@Test
|
||||
void setHttp2MaxRequestHeaderSize() {
|
||||
DataSize headerSize = DataSize.ofKilobytes(24);
|
||||
this.serverProperties.getHttp2().setEnabled(true);
|
||||
this.serverProperties.setMaxHttpRequestHeaderSize(headerSize);
|
||||
NettyReactiveWebServerFactory factory = mock(NettyReactiveWebServerFactory.class);
|
||||
this.customizer.customize(factory);
|
||||
verifyHttp2MaxHeaderSize(factory, headerSize.toBytes());
|
||||
}
|
||||
|
||||
@Test
|
||||
void configureHttpRequestDecoder() {
|
||||
ServerProperties.Netty nettyProperties = this.serverProperties.getNetty();
|
||||
this.serverProperties.setMaxHttpRequestHeaderSize(DataSize.ofKilobytes(24));
|
||||
nettyProperties.setValidateHeaders(false);
|
||||
nettyProperties.setInitialBufferSize(DataSize.ofBytes(512));
|
||||
nettyProperties.setH2cMaxContentLength(DataSize.ofKilobytes(1));
|
||||
|
@ -136,10 +148,11 @@ class NettyWebServerFactoryCustomizerTests {
|
|||
NettyReactiveWebServerFactory factory = mock(NettyReactiveWebServerFactory.class);
|
||||
this.customizer.customize(factory);
|
||||
then(factory).should().addServerCustomizers(this.customizerCaptor.capture());
|
||||
NettyServerCustomizer serverCustomizer = this.customizerCaptor.getValue();
|
||||
NettyServerCustomizer serverCustomizer = this.customizerCaptor.getAllValues().get(0);
|
||||
HttpServer httpServer = serverCustomizer.apply(HttpServer.create());
|
||||
HttpRequestDecoderSpec decoder = httpServer.configuration().decoder();
|
||||
assertThat(decoder.validateHeaders()).isFalse();
|
||||
assertThat(decoder.maxHeaderSize()).isEqualTo(this.serverProperties.getMaxHttpRequestHeaderSize().toBytes());
|
||||
assertThat(decoder.initialBufferSize()).isEqualTo(nettyProperties.getInitialBufferSize().toBytes());
|
||||
assertThat(decoder.h2cMaxContentLength()).isEqualTo(nettyProperties.getH2cMaxContentLength().toBytes());
|
||||
assertThat(decoder.maxInitialLineLength()).isEqualTo(nettyProperties.getMaxInitialLineLength().toBytes());
|
||||
|
@ -177,4 +190,12 @@ class NettyWebServerFactoryCustomizerTests {
|
|||
assertThat(maxKeepAliveRequests).isEqualTo(expected);
|
||||
}
|
||||
|
||||
private void verifyHttp2MaxHeaderSize(NettyReactiveWebServerFactory factory, long expected) {
|
||||
then(factory).should(times(2)).addServerCustomizers(this.customizerCaptor.capture());
|
||||
NettyServerCustomizer serverCustomizer = this.customizerCaptor.getAllValues().get(0);
|
||||
HttpServer httpServer = serverCustomizer.apply(HttpServer.create());
|
||||
Http2SettingsSpec decoder = httpServer.configuration().http2SettingsSpec();
|
||||
assertThat(decoder.maxHeaderListSize()).isEqualTo(expected);
|
||||
}
|
||||
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue