During navigation, Chrome checks the Safe Browsing reputation of each URL and decides whether to show a warning to the user. This document describes how Safe Browsing lookup interacts with navigation and how Safe Browsing lookups affect the speed of navigation.
When a user navigates to a URL, Chrome checks the Safe Browsing reputation of the URL before the URL is loaded. If Safe Browsing believes that the URL is dangerous, Chrome shows a warning to the user:
Chrome can perform two types of Safe Browsing checks during navigation:
Both of these checks are on the blocking path of navigation. Before the check is completed, the navigation is not committed, the page body is not read by the renderer, and the user won’t see any page content in their browser.
NOTE: There is another type of Safe Browsing check called Client Side Phishing Detection (CSD). It also checks the reputation of the page. However, this check is performed after the navigation is committed and it doesn’t block the navigation, so it is out-of-scope for this doc.
Life of a Navigation gives a high level overview of a navigation from the time a URL is typed in the URL bar to the time the web page is completely loaded. It breaks down a frame navigation into two phases:
Navigation Concepts covers a set of important topics to understand navigation, such as:
https://foo.com/1.html#fragment) and using the history.pushState API.As illustrated above, Safe Browsing may block navigation in two phases:
If one of the URLs (initial URL, redirect URLs, subresource URLs) is classified as dangerous, a warning page will be shown and the navigation will be cancelled. Note that some of the subresource URLs may not trigger a full page interstitial. For example, when the threat type is “URL unwanted” (code).
Safe Browsing checks and network requests are performed in parallel. Performing a Safe Browsing check doesn’t block the start of network requests or the fetch of response header and body. It doesn’t block redirects either.
However, completion of the Safe Browsing check does block the browser from reading or parsing the response body. When the response header is received, Safe Browsing will block the navigation if the check is not completed.
Safe Browsing won’t slow down the navigation if it is completed before the response header is received. If Safe Browsing is not completed at this point, the response body will still be fetched but the renderer won’t read or parse it.
We have two metrics to measure the speed of Safe Browsing checks on the browser-side (include both hash-based check and real-time check):
Similarly, we have two metrics to measure the speed of Safe Browsing checks on the renderer-side (only include hash-based check because real-time check is not available on the renderer-side):
Safe Browsing blocks navigation by implementing the URLLoaderThrottle interface. This interface provides several phases to defer URL loading:
WillStartRequest(request, defer)WillRedirectRequest(request, defer)WillProcessResponse(request, defer)The throttle can mark defer as true if it wants to defer the navigation and can call Resume to resume the navigation.
The throttle on the browser side is BrowserUrlLoaderThrottle and the throttle on the render side is RendererUrlLoaderThrottle. The throttles only mark defer as true in WillProcessResponse.
Note that another way of deferring and blocking navigation is by implementing the NavigationThrottle interface. This interface doesn’t fit the Safe Browsing use case because it cannot defer loading subresources.
Safe Browsing doesn’t defer navigation forever. The current timeout is set to 5 seconds. If the check is not completed in 5 seconds, the navigation will resume.