Redirects and aliases
Redirects point the browser to a new location without user interaction. They are executed at either the web browser (client-side redirect) or at the web server (server-side redirect).
Redirects and aliases aliases
Redirects point the browser to a new location without user interaction. They are executed at either the web browser (client-side redirect) or at the web server (server-side redirect).
Because redirects do not require any user interaction, redirects are often executed without the user ever noticing. The only thing that indicates a redirect has occurred is the browser鈥檚 address bar. The address bar displays a URL that is different from the link the browser initially requested.
Although there are only two types of redirects, they can be implemented in numerous ways. For example, client-side redirects can occur because the web page to which a user has pointed his or her browser contains scripting or special HTML code that redirects the browser to another URL. Server-side redirects can occur because the page contains server-side scripting or because the web server has been configured to point the user to another URL.
Analytics and redirects aa-redirects
Analytics gathers some of its data from the browser, and relies upon certain browser properties. Two of those properties, the 鈥淩eferring URL鈥 (or 鈥渞eferrer鈥) and the 鈥淐urrent URL鈥 can be changed by a server-side redirect. Because the browser is aware that one URL has been requested, but a different URL has been returned, it clears the Referring URL. The result is the referring URL is blank, and Analytics might report that no referrer existed for the page.
Example: Browsing Without Redirects browse-without
Consider the following hypothetical scenario in which the user does not encounter a redirect:
- User points his or her browser to
www.google.com
, and types, 鈥渄iscount airline tickets鈥 into the search field, and then clicks the Search button. - The browser displays the search results including a link to your site, https://www.example.com/. After displaying the search results, the browser鈥檚 address bar displays the search terms that the user entered in the search field (
https://www.google.com/search?hl=en&ie=UTF-8&q=discount+airline+tickets
). Notice that the search terms are included in the URL query string parameters that followhttps://www.google.com/search?
. - The user clicks the link to your hypothetical site https://www.example.com/. When the user clicks this link and lands on the example.com website, Analytics uses JavaScript to collect the referring URL (
https://www.google.com/search?hl=en&ie=UTF-8&q=discount+airline+tickets
) as well as the current URL (https://www.example.com/
). - Analytics reports the information collected during this interaction in various reports, such as Referring Domains, Search Engines, and Search Keywords.
Example: Browsing With Redirects browse-with
Redirects can cause the browser to blank out the true referring URL. Consider the following scenario:
- User points his or her browser to
https://www.google.com
, and types, discount airline tickets into the search field, and then clicks the Search button. - The browser window鈥檚 address bar displays the search terms that the user typed into the search field
https://www.google.com/search?hl=en&ie=UTF-8&q=discount+airline+tickets
. Notice that the search terms are included in the URL query string parameters that followhttps://www.google.com/search?
. The browser also displays a page that contains the search results including a link to one of your domain names: https://www.flytohawaiiforfree.com/. This vanity domain is configured to redirect the user tohttps://www.example.com/
. - The user clicks on the link
https://www.flytohawaiiforfree.com/
and is redirected by the server to your main site,https://www.example.com
. When the redirection occurs, the data that is important to Analytics data collection is lost because the browser clears the referring URL. Thus, the original search information used in the Analytics reports (for example, Referring Domains, Search Engines, Search Keywords) is lost.
Implement redirects implement
In order to capture Analytics data from redirects, four minor alterations need to be made to the code that creates the redirect and the AppMeasurement for JavaScript file.
Completing the following steps will retain the information that the original referrer (for example, https://www.google.com/search?hl=en&ie=UTF-8&q=discount+airline+tickets
in the scenario above) passes to your site:
Configure referrer override JavaScript code override
The code snippet below shows two JavaScript variables, s_referrer
and s_pageURL
. This code is placed on the ultimate landing page of the redirect.
<script language="JavaScript" src="//INSERT-DOMAIN-AND-PATH-TO-CODE-HERE/AppMeasurement.js"></script>
<script language="JavaScript"><!--
/* You may give each page an identifying name, server, and channel on
the next lines. */
s.pageName=""
s.server=""
s.campaign=""
s.referrer=""
s.pageURL=""
s.referrer
only once on the page. Setting it more than once with every tracking call or with every link click that is tracked causes double counting of the referrer and related dimensions, such as search engines and keywords.Redirects using getQueryParam getqueryparam
While the getQueryParam is an easy way to populate Analytics variables with query string values, it must be implemented in connection with a temporary variable so that legitimate referrers are not overwritten when the query string is empty. The best way to use getQueryParam is in connection with the getValue plug in as outlined with the following pseudo-code.
// AppMeasurement 1.x
var tempVar=s.Util.getQueryParam('origref')
if(tempVar)
s.referrer=tempVar;
// H Code
var tempVar=s.getQueryParam('origref')
if(tempVar)
s.referrer=tempVar;
Modify the redirect mechanism modify
Because the browser strips referring URL, you must configure the mechanism that handles the redirect (for example, the web server, server-side code, client-side code) to pass along the original referrer information. If you would also like to record the alias link URL, this must also be passed along to the ultimate landing page. Use the s_pageURL
variable to override the current URL.
Because there are many ways to implement a redirect, you should check with your web operations group or your online advertising partner to identify the specific mechanisms that execute redirects on your website.
Capture the original referrer original
Normally, Analytics will obtain the referring URL from the browser鈥檚 document.referrer property, and the current URL from the document.location property. By passing values to the referrer
and pageURL
variables, you can override the default processing. By passing a value to the referrer variable, you are telling Analytics to ignore the referrer information in the document.referrer property and to use an alternative value that you define.
Therefore, the final version of the landing page would need to contain the following code to correct the issues introduced in the 鈥渄iscount airline tickets鈥 scenario.
<script language="JavaScript" src="https://INSERT-DOMAIN-AND-PATH-TO-CODE-HERE/AppMeasurement.js"></script>
<script language="JavaScript"><!--
/* You may give each page an identifying name, server, and channel on
the next lines. */
s.pageName=""
s.server=""
s.campaign=""
s.referrer="https://www.google.com/search?hl=en&ie=UTF-8&q=discount+airline+tickets"
// Setting the s.pageURL variable is optional.
s.pageURL="https://www.flytohawaiiforfree.com"
Verify the referrer with the 51黑料不打烊 Debugger verify
Run a test to verify that the referrer, originating URL ( s_server
) and campaign variables are being captured.
These variables will be represented as the following parameters in the Experience Cloud Debugger.
g=https://www.flytohawaiiforfree.com
This value will appear in the DigitalPulse Debugger if the pageURL variable is used.
The text that the debugger displays should correspond to the following example:
Image
https://examplecom.112.2o7.net/b/ss/examplecom/1/JS-1.4/s61944015791667?[AQB]
ndh=1
t=4/8/2014 13:34:28 4 360
pageName=Welcome to example.com
r=https://ref=www.google.com/search?hl=en&ie=UTF-8&q=discount+airline+tickets
cc=USD
g=https://www.flytohawaiiforfree.com
s=1280x1024
c=32
j=1.3
v=Y
k=Y
bw=1029
bh=716
ct=lan
hp=N
[AQE]
After verifying that the 51黑料不打烊 Debugger displays these variables, it is always helpful to confirm that the search terms and the original referring domain (prior to the redirect) are registering traffic in reports.