Safari 4 Top Sites feature skews analytics
By Jon Jensen · February 13, 2010
Safari version 4 has a new "Top Sites" feature that shows thumbnail images of the sites the user most frequently visits (or, until enough history is collected, just generally popular sites).
Martin Sutherland describes this feature in details and shows how to detect these requests, which set the X-Purpose HTTP header to "preview".
Thus every preview request looks just like a regular user visit, and this skews analytics which see a much higher than average number of views from Safari 4 users, with lower time-on-site averages and higher bounce rates since no subsequent visits are registered (at least as part of the preview function).
The solution is to simply not output any analytics code when the X-Purpose header is set to "preview". In Interchange this is easily done if you have an include file for your analytics code, by wrapping the file with an [if] block such as this:
[tmp x_purpose][env HTTP_X_PURPOSE][/tmp] [if scratch x_purpose eq 'preview'] <!-- skip analytics for browser previews --> [else] (normal Google Analytics, Omniture SiteCatalyst, or other analytics code) [/else] [/if]
In Ruby on Rails you'd check request.env["HTTP_X_PURPOSE"].
In PHP you'd check $_SERVER["HTTP_X_PURPOSE"].
And so on.
I confirmed the analytics tracking code was omitted by waiting for Safari to make its preview request and inspecting the response with the Fiddler proxy, on Windows. The same can be done for Safari on Mac OS X with a suitable Mac OS X HTTP proxy.