Fix connection close header handling
This commit fixes an issue with the handling of the value "close" on the Connection header in the Netty 4 HTTP implementation. The issue was using the wrong equals method to compare an AsciiString instance and a String instance (they could never be equal). This commit fixes this to use the correct equals method to compare for content equality. Relates #20956
This commit is contained in:
parent
8d602c6692
commit
cd5777593a
|
@ -185,7 +185,7 @@ final class Netty4HttpChannel extends AbstractRestChannel {
|
||||||
// Determine if the request connection should be closed on completion.
|
// Determine if the request connection should be closed on completion.
|
||||||
private boolean isCloseConnection() {
|
private boolean isCloseConnection() {
|
||||||
final boolean http10 = isHttp10();
|
final boolean http10 = isHttp10();
|
||||||
return HttpHeaderValues.CLOSE.equals(nettyRequest.headers().get(HttpHeaderNames.CONNECTION)) ||
|
return HttpHeaderValues.CLOSE.contentEqualsIgnoreCase(nettyRequest.headers().get(HttpHeaderNames.CONNECTION)) ||
|
||||||
(http10 && HttpHeaderValues.KEEP_ALIVE.equals(nettyRequest.headers().get(HttpHeaderNames.CONNECTION)) == false);
|
(http10 && HttpHeaderValues.KEEP_ALIVE.equals(nettyRequest.headers().get(HttpHeaderNames.CONNECTION)) == false);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -30,10 +30,12 @@ import io.netty.channel.ChannelPipeline;
|
||||||
import io.netty.channel.ChannelProgressivePromise;
|
import io.netty.channel.ChannelProgressivePromise;
|
||||||
import io.netty.channel.ChannelPromise;
|
import io.netty.channel.ChannelPromise;
|
||||||
import io.netty.channel.EventLoop;
|
import io.netty.channel.EventLoop;
|
||||||
|
import io.netty.channel.embedded.EmbeddedChannel;
|
||||||
import io.netty.handler.codec.http.DefaultFullHttpRequest;
|
import io.netty.handler.codec.http.DefaultFullHttpRequest;
|
||||||
import io.netty.handler.codec.http.FullHttpRequest;
|
import io.netty.handler.codec.http.FullHttpRequest;
|
||||||
import io.netty.handler.codec.http.FullHttpResponse;
|
import io.netty.handler.codec.http.FullHttpResponse;
|
||||||
import io.netty.handler.codec.http.HttpHeaderNames;
|
import io.netty.handler.codec.http.HttpHeaderNames;
|
||||||
|
import io.netty.handler.codec.http.HttpHeaderValues;
|
||||||
import io.netty.handler.codec.http.HttpMethod;
|
import io.netty.handler.codec.http.HttpMethod;
|
||||||
import io.netty.handler.codec.http.HttpResponse;
|
import io.netty.handler.codec.http.HttpResponse;
|
||||||
import io.netty.handler.codec.http.HttpVersion;
|
import io.netty.handler.codec.http.HttpVersion;
|
||||||
|
@ -212,6 +214,26 @@ public class Netty4HttpChannelTests extends ESTestCase {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void testConnectionClose() throws Exception {
|
||||||
|
final Settings settings = Settings.builder().build();
|
||||||
|
try (Netty4HttpServerTransport httpServerTransport =
|
||||||
|
new Netty4HttpServerTransport(settings, networkService, bigArrays, threadPool)) {
|
||||||
|
httpServerTransport.start();
|
||||||
|
final FullHttpRequest httpRequest = new DefaultFullHttpRequest(HttpVersion.HTTP_1_1, HttpMethod.GET, "/");
|
||||||
|
httpRequest.headers().add(HttpHeaderNames.CONNECTION, HttpHeaderValues.CLOSE);
|
||||||
|
final EmbeddedChannel embeddedChannel = new EmbeddedChannel();
|
||||||
|
final Netty4HttpRequest request = new Netty4HttpRequest(httpRequest, embeddedChannel);
|
||||||
|
|
||||||
|
// send a response, the channel should close
|
||||||
|
assertTrue(embeddedChannel.isOpen());
|
||||||
|
final Netty4HttpChannel channel =
|
||||||
|
new Netty4HttpChannel(httpServerTransport, request, null, randomBoolean(), threadPool.getThreadContext());
|
||||||
|
final TestResponse resp = new TestResponse();
|
||||||
|
channel.sendResponse(resp);
|
||||||
|
assertFalse(embeddedChannel.isOpen());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private FullHttpResponse executeRequest(final Settings settings, final String host) {
|
private FullHttpResponse executeRequest(final Settings settings, final String host) {
|
||||||
return executeRequest(settings, null, host);
|
return executeRequest(settings, null, host);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue