mirror of https://github.com/nodejs/node.git
src: make Sec-WebSocket-Key check case-insensitive
Current case sensitive comparison is breaking netty-based WS clients. replace strncmp with strncasecmp Fixes: https://github.com/nodejs/node/issues/7247 PR-URL: https://github.com/nodejs/node/pull/7248 Reviewed-By: Colin Ihrig <cjihrig@gmail.com> Reviewed-By: Ali Ijaz Sheikh <ofrobots@google.com> Reviewed-By: Ben Noordhuis <info@bnoordhuis.nl>
This commit is contained in:
parent
08ea9ee56d
commit
f1d1071361
|
@ -1,4 +1,6 @@
|
|||
#include "inspector_socket.h"
|
||||
#include "util.h"
|
||||
#include "util-inl.h"
|
||||
|
||||
#define NODE_WANT_INTERNALS 1
|
||||
#include "base64.h"
|
||||
|
@ -445,9 +447,10 @@ static int header_value_cb(http_parser* parser, const char* at, size_t length) {
|
|||
struct http_parsing_state_s* state = (struct http_parsing_state_s*)
|
||||
(reinterpret_cast<inspector_socket_t*>(parser->data))->http_parsing_state;
|
||||
state->parsing_value = true;
|
||||
if (state->current_header && strncmp(state->current_header,
|
||||
SEC_WEBSOCKET_KEY_HEADER,
|
||||
sizeof(SEC_WEBSOCKET_KEY_HEADER)) == 0) {
|
||||
if (state->current_header &&
|
||||
node::StringEqualNoCaseN(state->current_header,
|
||||
SEC_WEBSOCKET_KEY_HEADER,
|
||||
sizeof(SEC_WEBSOCKET_KEY_HEADER))) {
|
||||
append(&state->ws_key, at, length);
|
||||
}
|
||||
return 0;
|
||||
|
|
|
@ -219,6 +219,16 @@ bool StringEqualNoCase(const char* a, const char* b) {
|
|||
return false;
|
||||
}
|
||||
|
||||
bool StringEqualNoCaseN(const char* a, const char* b, size_t length) {
|
||||
for (size_t i = 0; i < length; i++) {
|
||||
if (ToLower(a[i]) != ToLower(b[i]))
|
||||
return false;
|
||||
if (a[i] == '\0')
|
||||
return true;
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
} // namespace node
|
||||
|
||||
#endif // defined(NODE_WANT_INTERNALS) && NODE_WANT_INTERNALS
|
||||
|
|
|
@ -206,6 +206,9 @@ inline char ToLower(char c);
|
|||
// strcasecmp() is locale-sensitive. Use StringEqualNoCase() instead.
|
||||
inline bool StringEqualNoCase(const char* a, const char* b);
|
||||
|
||||
// strncasecmp() is locale-sensitive. Use StringEqualNoCaseN() instead.
|
||||
inline bool StringEqualNoCaseN(const char* a, const char* b, size_t length);
|
||||
|
||||
// Allocates an array of member type T. For up to kStackStorageSize items,
|
||||
// the stack is used, otherwise malloc().
|
||||
template <typename T, size_t kStackStorageSize = 1024>
|
||||
|
|
|
@ -68,6 +68,21 @@ TEST(UtilTest, StringEqualNoCase) {
|
|||
EXPECT_FALSE(StringEqualNoCase("equals", "equal"));
|
||||
}
|
||||
|
||||
TEST(UtilTest, StringEqualNoCaseN) {
|
||||
using node::StringEqualNoCaseN;
|
||||
EXPECT_FALSE(StringEqualNoCaseN("a", "b", strlen("a")));
|
||||
EXPECT_TRUE(StringEqualNoCaseN("", "", strlen("")));
|
||||
EXPECT_TRUE(StringEqualNoCaseN("equal", "equal", strlen("equal")));
|
||||
EXPECT_TRUE(StringEqualNoCaseN("equal", "EQUAL", strlen("equal")));
|
||||
EXPECT_TRUE(StringEqualNoCaseN("EQUAL", "EQUAL", strlen("equal")));
|
||||
EXPECT_TRUE(StringEqualNoCaseN("equal", "equals", strlen("equal")));
|
||||
EXPECT_FALSE(StringEqualNoCaseN("equal", "equals", strlen("equals")));
|
||||
EXPECT_TRUE(StringEqualNoCaseN("equals", "equal", strlen("equal")));
|
||||
EXPECT_FALSE(StringEqualNoCaseN("equals", "equal", strlen("equals")));
|
||||
EXPECT_TRUE(StringEqualNoCaseN("abc\0abc", "abc\0efg", strlen("abcdefgh")));
|
||||
EXPECT_FALSE(StringEqualNoCaseN("abc\0abc", "abcd\0efg", strlen("abcdefgh")));
|
||||
}
|
||||
|
||||
TEST(UtilTest, ToLower) {
|
||||
using node::ToLower;
|
||||
EXPECT_EQ('0', ToLower('0'));
|
||||
|
|
Loading…
Reference in New Issue