JavaScriptなしでGoogleAnalyticsデータを収集する
はじめに
JavaScript無効環境では、analytics.jsやgtag.jsでデータ収集することはできません。そのため、別の方法でデータ収集する必要があります。
ここでは、Measurement Protocolを利用して、データを収集します。Measurement Protocolは、analytics.jsの上位に位置するAPIです。GETやPOSTでのアクセスでデータを収集することができます。具体的には、<noscript>と<img src='...'>を使用して、JavaScript無効時に画像ファイルのGETアクセスからAnalyticsのデータを収集します。
ページビューを送信する
| パラメータ | 例 | 備考 | 
|---|---|---|
| v | 1 | バージョン(現状は1固定) | 
| t | pageview | ヒットタイプ | 
| tid | UA-XXXX-Y | トラッキング ID | 
| cid | UUID | クライアント ID | 
| dt | タイトル | ページタイトル | 
| dl | ページURL | ページURL | 
| z | 289372387623 | キャッシュの無効化 | 
https://www.google-analytics.com/collect?v=1&t=pageview&tid=UA-XXXX-Y&cid=1&dt=ページタイトル&dl=ページURLJavaScript無効イベントを送信する
| パラメータ | 例 | 備考 | 
|---|---|---|
| v | 1 | バージョン(現状は1固定) | 
| t | event | ヒットタイプ | 
| tid | UA-XXXX-Y | トラッキング ID | 
| cid | UUID | クライアント ID | 
| ni | 1 | 非インタラクション ヒット | 
| ec | view | イベントカテゴリー | 
| ea | js_disabled | イベントアクション | 
| ev | 値 | イベント値 | 
| el | ページURL | イベントラベル | 
| z | 289372387623 | キャッシュの無効化 | 
https://www.google-analytics.com/collect?v=1&t=event&tid=UA-XXXX-Y&cid=1&ni=1&ec=view&ea=js_disabled&ev=0&el=ページURLサンプルコード
<div style='display:none'>
  <noscript>
    <img src='https://www.google-analytics.com/collect?v=1&t=pageview&tid=UA-XXXX-Y&cid=1&dt=ページタイトル&dl=ページURL' alt='pageview'/>
    <img src='https://www.google-analytics.com/collect?v=1&t=event&tid=UA-XXXX-Y&cid=1&ni=1&ec=view&ea=js_disabled&ev=0&el=ページURL' alt='js-disabled'/>
  </noscript>
</div>※<noscript>は、style属性なしの<span>に置換されるため、style属性は、<noscript>の外側に指定しています
補足
cidは、UUIDを指定する項目ですが、1を指定してもデータは収集されるようです。UUIDを算出できない環境ならば、1や固定UUIDを指定することで最低限動作するようです。
※ページURLに&が含まれる場合、正常にURLを収集できなため、URLのエンコードが必要となります
備考
JavaScriptありでMeasurement Protocolを利用するサンプルです。JavaScript無効環境と異なり、クライアントIDが取得できます。
(function() {
  const ANALYTICS_URL = 'https://www.google-analytics.com/collect';
  const GA_COOKIE = document.cookie.replace(/(?:(?:^|.*;)\s*_ga\s*\=\s*(?:\w+\.\d\.)([^;]*).*$)|^.*$/, '$1');
  const TRACKING_ID = 'UA-XXXX-Y';
  const CLIENT_ID =  GA_COOKIE || (Math.random() * Math.pow(2, 52));
  // ga('send', 'pageview', {title:document.title, location:location.href});
  navigator.sendBeacon && navigator.sendBeacon(ANALYTICS_URL, [
    'v=1', 't=pageview', 
    'tid=' + TRACKING_ID,
    'cid=' + CLIENT_ID,
    'dt=' + encodeURIComponent(document.title),
    'dl=' + encodeURIComponent(location.href)
  ].join('&'));
  // ga('send', 'event', {eventCategory:'category', eventAction:'action', eventLabel:location.href, eventValue:1, nonInteraction:true});
  navigator.sendBeacon && navigator.sendBeacon(ANALYTICS_URL, [
    'v=1', 't=event', 'ec=category', 'ea=action', 'ni=1',
    'tid=' + TRACKING_ID,
    'cid=' + CLIENT_ID,
    'el=' + encodeURIComponent(location.href),
    'ev=1'
  ].join('&'));
})();