diff --git a/Userland/Libraries/LibWeb/Fetch/Fetching/Fetching.cpp b/Userland/Libraries/LibWeb/Fetch/Fetching/Fetching.cpp index dfd834fbe0d02..e290ce8659e0b 100644 --- a/Userland/Libraries/LibWeb/Fetch/Fetching/Fetching.cpp +++ b/Userland/Libraries/LibWeb/Fetch/Fetching/Fetching.cpp @@ -1987,7 +1987,10 @@ WebIDL::ExceptionOr> http_network_or_cache_fet if (response->status() == 401 && http_request->response_tainting() != Infrastructure::Request::ResponseTainting::CORS && include_credentials == IncludeCredentials::Yes - && request->window().has>()) { + && request->window().has>() + // AD-HOC: Require at least one WWW-Authenticate header to be set before automatically retrying an authenticated + // request (see rule 1 below). See: https://github.com/whatwg/fetch/issues/1766 + && request->header_list()->contains("WWW-Authenticate"sv.bytes())) { // 1. Needs testing: multiple `WWW-Authenticate` headers, missing, parsing issues. // (Red box in the spec, no-op)