diff --git a/codec-http/src/main/java/io/netty/handler/codec/http/HttpServerUpgradeHandler.java b/codec-http/src/main/java/io/netty/handler/codec/http/HttpServerUpgradeHandler.java index 38e45e2595..9266a8ef77 100644 --- a/codec-http/src/main/java/io/netty/handler/codec/http/HttpServerUpgradeHandler.java +++ b/codec-http/src/main/java/io/netty/handler/codec/http/HttpServerUpgradeHandler.java @@ -169,6 +169,7 @@ public class HttpServerUpgradeHandler extends HttpObjectAggregator { private final SourceCodec sourceCodec; private final UpgradeCodecFactory upgradeCodecFactory; + private final boolean validateHeaders; private boolean handlingUpgrade; /** @@ -199,10 +200,25 @@ public class HttpServerUpgradeHandler extends HttpObjectAggregator { */ public HttpServerUpgradeHandler( SourceCodec sourceCodec, UpgradeCodecFactory upgradeCodecFactory, int maxContentLength) { + this(sourceCodec, upgradeCodecFactory, maxContentLength, true); + } + + /** + * Constructs the upgrader with the supported codecs. + * + * @param sourceCodec the codec that is being used initially + * @param upgradeCodecFactory the factory that creates a new upgrade codec + * for one of the requested upgrade protocols + * @param maxContentLength the maximum length of the content of an upgrade request + * @param validateHeaders validate the header names and values of the upgrade response. + */ + public HttpServerUpgradeHandler(SourceCodec sourceCodec, UpgradeCodecFactory upgradeCodecFactory, + int maxContentLength, boolean validateHeaders) { super(maxContentLength); this.sourceCodec = requireNonNull(sourceCodec, "sourceCodec"); this.upgradeCodecFactory = requireNonNull(upgradeCodecFactory, "upgradeCodecFactory"); + this.validateHeaders = validateHeaders; } @Override @@ -349,9 +365,9 @@ public class HttpServerUpgradeHandler extends HttpObjectAggregator { /** * Creates the 101 Switching Protocols response message. */ - private static FullHttpResponse createUpgradeResponse(CharSequence upgradeProtocol) { - DefaultFullHttpResponse res = new DefaultFullHttpResponse(HTTP_1_1, SWITCHING_PROTOCOLS, - Unpooled.EMPTY_BUFFER, false); + private FullHttpResponse createUpgradeResponse(CharSequence upgradeProtocol) { + DefaultFullHttpResponse res = new DefaultFullHttpResponse( + HTTP_1_1, SWITCHING_PROTOCOLS, Unpooled.EMPTY_BUFFER, validateHeaders); res.headers().add(HttpHeaderNames.CONNECTION, HttpHeaderValues.UPGRADE); res.headers().add(HttpHeaderNames.UPGRADE, upgradeProtocol); return res;