diff options
Diffstat (limited to 'net/http')
-rw-r--r-- | net/http/http_response_headers.cc | 60 | ||||
-rw-r--r-- | net/http/http_response_headers_unittest.cc | 38 |
2 files changed, 78 insertions, 20 deletions
diff --git a/net/http/http_response_headers.cc b/net/http/http_response_headers.cc index fb647ac..7f75466 100644 --- a/net/http/http_response_headers.cc +++ b/net/http/http_response_headers.cc @@ -980,31 +980,39 @@ bool HttpResponseHeaders::GetContentRange(int64* first_byte_position, int64* last_byte_position, int64* instance_length) const { void* iter = NULL; - std::string content_range_val; - if (!EnumerateHeader(&iter, "content-range", &content_range_val)) + std::string content_range_spec; + if (!EnumerateHeader(&iter, "content-range", &content_range_spec)) return false; - if (content_range_val.empty()) + // If the header value is empty, we have an invalid header. + if (content_range_spec.empty()) return false; - size_t space_position = content_range_val.find(' '); + size_t space_position = content_range_spec.find(' '); if (space_position == std::string::npos) return false; - if (!LowerCaseEqualsASCII(content_range_val.begin(), - content_range_val.begin() + space_position, + // Invalid header if it doesn't contain "bytes-unit". + if (!LowerCaseEqualsASCII(content_range_spec.begin(), + content_range_spec.begin() + space_position, "bytes")) { return false; } - size_t slash_position = content_range_val.find('/', space_position + 1); + size_t slash_position = content_range_spec.find('/', space_position + 1); if (slash_position == std::string::npos) return false; + // Obtain the part behind the space and before slash. + std::string::const_iterator byte_range_resp_spec_begin = + content_range_spec.begin() + space_position + 1; + std::string::const_iterator byte_range_resp_spec_end = + content_range_spec.begin() + slash_position; + HttpUtil::TrimLWS(&byte_range_resp_spec_begin, &byte_range_resp_spec_end); + // Parse the byte-range-resp-spec part. - std::string byte_range_resp_spec( - content_range_val.begin() + space_position + 1, - content_range_val.begin() + slash_position); + std::string byte_range_resp_spec(byte_range_resp_spec_begin, + byte_range_resp_spec_end); // If byte-range-resp-spec == "*". if (LowerCaseEqualsASCII(byte_range_resp_spec, "*")) { *first_byte_position = -1; @@ -1013,14 +1021,25 @@ bool HttpResponseHeaders::GetContentRange(int64* first_byte_position, size_t minus_position = byte_range_resp_spec.find('-'); if (minus_position != std::string::npos) { // Obtain first-byte-pos. + std::string::const_iterator first_byte_pos_begin = + byte_range_resp_spec.begin(); + std::string::const_iterator first_byte_pos_end = + byte_range_resp_spec.begin() + minus_position; + HttpUtil::TrimLWS(&first_byte_pos_begin, &first_byte_pos_end); + bool ok = StringToInt64( - std::string(byte_range_resp_spec.begin(), - byte_range_resp_spec.begin() + minus_position), + std::string(first_byte_pos_begin, first_byte_pos_end), first_byte_position); + // Obtain last-byte-pos. + std::string::const_iterator last_byte_pos_begin = + byte_range_resp_spec.begin() + minus_position + 1; + std::string::const_iterator last_byte_pos_end = + byte_range_resp_spec.end(); + HttpUtil::TrimLWS(&last_byte_pos_begin, &last_byte_pos_end); + ok &= StringToInt64( - std::string(byte_range_resp_spec.begin() + minus_position + 1, - byte_range_resp_spec.end()), + std::string(last_byte_pos_begin, last_byte_pos_end), last_byte_position); if (!ok || *first_byte_position < 0 || @@ -1034,13 +1053,16 @@ bool HttpResponseHeaders::GetContentRange(int64* first_byte_position, // Parse the instance-length part. // If instance-length == "*". - if (LowerCaseEqualsASCII(content_range_val.begin() + slash_position + 1, - content_range_val.end(), - "*")) { + std::string::const_iterator instance_length_begin = + content_range_spec.begin() + slash_position + 1; + std::string::const_iterator instance_length_end = + content_range_spec.end(); + HttpUtil::TrimLWS(&instance_length_begin, &instance_length_end); + + if (LowerCaseEqualsASCII(instance_length_begin, instance_length_end, "*")) { *instance_length = -1; } else if (!StringToInt64( - std::string(content_range_val.begin() + slash_position + 1, - content_range_val.end()), + std::string(instance_length_begin, instance_length_end), instance_length)) { return false; } else if (*instance_length < 0 || diff --git a/net/http/http_response_headers_unittest.cc b/net/http/http_response_headers_unittest.cc index 24ca9869..c78c597 100644 --- a/net/http/http_response_headers_unittest.cc +++ b/net/http/http_response_headers_unittest.cc @@ -1109,6 +1109,13 @@ TEST(HttpResponseHeaders, GetContentRange) { 51 }, { "HTTP/1.1 206 Partial Content\n" + "Content-Range: bytes\t0-50/51", + false, + -1, + -1, + -1 + }, + { "HTTP/1.1 206 Partial Content\n" "Content-Range: bytes 0-50/51", true, 0, @@ -1116,7 +1123,22 @@ TEST(HttpResponseHeaders, GetContentRange) { 51 }, { "HTTP/1.1 206 Partial Content\n" - "Content-Range: bytes 0 - 50 / 51", + "Content-Range: bytes 0 - 50 \t / \t51", + true, + 0, + 50, + 51 + }, + { "HTTP/1.1 206 Partial Content\n" + "Content-Range: bytes 0\t-\t50\t/\t51\t", + true, + 0, + 50, + 51 + }, + + { "HTTP/1.1 206 Partial Content\n" + "Content-Range: \t bytes \t 0 - 50 / 5 1", false, -1, -1, @@ -1136,6 +1158,13 @@ TEST(HttpResponseHeaders, GetContentRange) { -1, -1 }, + { "HTTP/1.1 416 Requested range not satisfiable\n" + "Content-Range: bytes * / * ", + true, + -1, + -1, + -1 + }, { "HTTP/1.1 206 Partial Content\n" "Content-Range: bytes 0-50/*", true, @@ -1144,6 +1173,13 @@ TEST(HttpResponseHeaders, GetContentRange) { -1 }, { "HTTP/1.1 206 Partial Content\n" + "Content-Range: bytes 0-50 / * ", + true, + 0, + 50, + -1 + }, + { "HTTP/1.1 206 Partial Content\n" "Content-Range: bytes 0-10000000000/10000000001", true, 0, |