Per hybi list, adding no-cache to outgoing client request to prevent bad

intermediaries from attempting to cache the upgrade response.
This commit is contained in:
Joakim Erdfelt 2012-10-15 07:18:35 -07:00
parent a4050aa40f
commit 57abd6fded
1 changed files with 9 additions and 0 deletions

View File

@ -57,6 +57,8 @@ public class ClientUpgradeRequest implements UpgradeRequest
FORBIDDEN_HEADERS.add("sec-websocket-accept"); FORBIDDEN_HEADERS.add("sec-websocket-accept");
FORBIDDEN_HEADERS.add("sec-websocket-protocol"); FORBIDDEN_HEADERS.add("sec-websocket-protocol");
FORBIDDEN_HEADERS.add("sec-websocket-version"); FORBIDDEN_HEADERS.add("sec-websocket-version");
FORBIDDEN_HEADERS.add("pragma");
FORBIDDEN_HEADERS.add("cache-control");
} }
private final String key; private final String key;
@ -121,6 +123,13 @@ public class ClientUpgradeRequest implements UpgradeRequest
request.append("Sec-WebSocket-Key: ").append(key).append("\r\n"); request.append("Sec-WebSocket-Key: ").append(key).append("\r\n");
request.append("Sec-WebSocket-Version: 13\r\n"); // RFC-6455 specified version request.append("Sec-WebSocket-Version: 13\r\n"); // RFC-6455 specified version
// (Per the hybi list): Add no-cache headers to avoid compatibility issue.
// There are some proxies that rewrite "Connection: upgrade"
// to "Connection: close" in the response if a request doesn't contain
// these headers.
request.append("Pragma: no-cache\r\n");
request.append("Cache-Control: no-cache\r\n");
// Extensions // Extensions
if (!getExtensions().isEmpty()) if (!getExtensions().isEmpty())
{ {