Vor kurzem wurde ich mit der Frage konfrontiert, was passieren würde, wenn jemand anderer meinen Google Tag Manager Container einfach auf seiner Website installiert. Also quasi “GTM-Container-Kidnapping”. Lies weiter, dann erfährst du es …
Tja, ehrlicherweise war ich mir da auch nicht ganz sicher im Vorfeld. Aber da das durchaus eine sicherheitsrelevante Frage ist, wollte ich dem auf den Grund gehen.
Das erfährst du hier
- Was könnte passieren?
- Was passiert bei Container-Code-Kidnapping? Testszenario.
- Das kannst du gegen Container-Kidnapping tun.
- Fazit
Was könnte bei Container-Code-Kidnapping passieren?
Zunächst einmal hatte ich unmittelbar die Befürchtung, dass alle Tags, die auf meiner “eigentlichen” Seite feuern, nun auch auf der anderen Seite zu finden sein werden. Inklusive Analytics-Tracking, Drittanbieter-Pixel usw. Aber ganz sicher war ich mir da nicht.
Ich fragte bei meinem Podcast-Gast Cem Alkan nach, der sich ebenfalls sehr gut mit dem Google Tag Manager auskennt. Seine Antwort:
Allerdings war da noch das Wort “theoretisch” und dahinter verstecken sich doch diverse Unwägbarkeiten. Ich wollte es also “praktisch” erfahren.
Das passiert wirklich, wenn der Container-Code gekidnappt wird
Ich habe also auf einer meiner Websites den ursprünglichen Google Tag Manager Container Code herausgenommen und einen anderen (von einer anderen Domain) eingebaut, mit allem, was dazu gehörte: GA Tracking, diverse Pixel und Co.
Und was soll ich sagen: Zumindest beim Analytics-Tracking passierte zunächst nichts. Zwar feuerte das Pageview Tag ordnungsgemäß (s. Screenshot im Debug-Modus des Tag Managers) …
… jedoch wurde in Google Analytics in der Echtzeit-Ansicht kein Traffic aufgezeichnet. Bei näherem Hinsehen wurde jedoch klar warum.
Wenn man im Debug-Modus des Tag Managers die einzelnen Tags klickt (s. oben), erfährt man schnell, mit welchen Werten das Tag ausgelöst hat. Beim Klick auf das Pageview-Tag gab es die Erkenntnis: Es wurde keine Tracking-ID/Google Analytics Property zum Absenden genutzt. Dementsprechend wusste das Tag nicht, in welche Analytics-Property es den Pageview schicken sollte.
Aha. Das war ja erstmal gut. Offenbar funktioniert das Kidnapping des Containers nur bedingt.
AAABER!
Meine Konfiguration sieht beinahe immer Suchtabellen vor, die zum Beispiel bei verschiedenen Hosts oder bei Nutzung des Debug-Modes unterschiedliche Property-IDs zurückgeben. Das mache ich, um zu verhindern, dass bei Tests auf der Website die “echten” Analytics-Daten leiden, also durch Falsch-Daten zu ihrem Nachteil verändert werden.
Wenn jetzt die “fremde” Domain nicht in der Suchtabelle zu finden ist, weiß das Tag natürlich nicht, an welche Property die Daten rausgehen. Zumindest dann nicht, wenn kein Haken bei “Standardwert hinzufügen” gesetzt wurde (s. Screenshot).
Sollte der Haken gesetzt sein, wird immer, wenn ein Eingabe-Wert in der Suchtabelle nicht gefunden wurde, ein Standardwert genommen, den man selber definieren kann.
Statt das zu tun, habe ich in der Tag-Konfiguration nun “hart” die Live-Analytics-Property eingebunden, um zu provozieren, dass das Tracking verfälscht wird …
… und dann passierte leider im Analytics-Konto das hier:
Es wurde also mithilfe des gekidnappten Container-Code Analytics-Traffic aufgezeichnet. Das war natürlich “unschön”. Denn das öffnet denen Türen, die manipulieren wollen.
Was kannst du gegen Container-Kidnapping tun?
Tja, ich bin ein lösungsorientierter Mensch, also gibt’s natürlich auch Vorschläge, wie du dein Analytics-Konto gegen so etwas wappnen kannst.
1. Lösung: Mit Filtern in Google Analytics arbeiten
Wenn ein GTM-Container oder ein Google-Analytics-Tracking-Code auf einer anderen Website außer deiner eingebunden wird, entsteht der Traffic nicht auf deiner Domain, sondern auf der fremden. Logisch soweit.
In Google Analytics wird aufgezeichnet, auf welcher Domain, respektive welchem Host der Traffic aufgezeichnet wird. Den dazugehörigen Bericht findest du unter “Zielgruppe” > “Technologie” > “Netzwerk” und dort musst du oberhalb der Tabelle “Hostname” klicken (s. Screenshot):
Die gute Nachricht: Du kannst verhindern, dass Traffic außerhalb deiner eigenen Domain in Analytics aufgezeichnet wird.
Dafür kannst du in der Verwaltung deines GA-Kontos auf Datenansichtsebene einen speziellen Filter setzen, der nur dann Traffic zulässt, wenn er von einem Host kommt, den du gutheißt, meistens der eigenen Domain (manchmal aber auch den Domain, auf denen du freiwillig trackst, etwa Google Übersetzerseiten, Mailchimp usw.).
Die Filterkonfiguration, wenn du ausschließlich auf deiner kompletten eigenen Domain tracken möchtest, könnte also zum Beispiel so aussehen: “Einschließen” > “Filterfeld = Hostname” > “Filtermuster = meinedomain\.de”. Wenn du nur www. und keine andere Subdomain zulassen möchtest: “Filtermuster = www\.meinedomain\.de”. Falls du Google-Übersetzer-Seiten zulassen möchtest UND deine komplette eigene Domain, schreibst du in das Filterfeld einfach “translate\.googleusercontent\.com|meinedomain\.com”. Da gibt es natürlich noch wesentlich mehr Beispiele. Aber du erkennst das Prinzip.
Ganz nebenbei kann man mit dieser Methode auch einem Großteil sonstiger Google-Analytics-Spammern das Handwerk legen (s. auch dieser Beitrag zum Spam verhindern).
2. Lösung: Suchtabelle mit Hostname im Google Tag Manager nutzen
Wer im Google Tag Manager ein Google Analytics Pageview Tag (oder auch jedes andere, wie zum Beispiel Eventtracking und Co.) anlegt, muss an bestimmter Stelle, die Property ID mitteilen.
Wie schon erwähnt, nutze ich an der Stelle meist Suchtabellen, um abhängig vom Host der Seite oder sonstigen Gegebenheiten dem Tag unterschiedliche Property-IDs mitzugeben. So kann ich etwa steuern, dass der Traffic auf www.metrika.de an eine andere Analytics-Property gesendet wird als der Traffic auf hierunddort.metrika.de. Und das mit nur einem einzigen Tag in nur einem Tag Manager Container.
Die Suchtabelle selbst ist eine Variable vom Typ “Suchtabelle”. Wie sie aussieht, hier nochmal als Beispiel.
Ihr einziger Job ist, zu überprüfen: “Auf welchem Host wird das Tag gefeuert?” und dementsprechend wird die entsprechende Analytics-Property-ID zurückgegeben.
Bitte hier im Sinne der Fake-Abwehr aber daran denken: KEINEN HAKEN SETZEN BEI “Standardwert festlegen”! Oder dann zumindest keine Live-Property-ID nutzen.
Denn ansonsten wird Traffic auf jedem Host, den die Tabelle nicht “kennt”, dorthin gemeldet.
3. Lösung: Blocking Trigger im Google Tag Manager
Die gerade genannten Lösungen funktionieren für Google Analytics super. Aber wenn ich jetzt zum Beispiel überhaupt kein Tag auf einem anderen Host feuern möchte?
Standardmäßig wird das Google Analytics Pageview Tag etwa mithilfe des Triggers “All Pages” auf allen Seiten ausgespielt, auf denen der Tag Manager stattfindet.
Du musst jetzt also einen oder mehrere Custom Trigger bauen oder deine bestehenden Trigger ergänzen, die nur auf den gewünschten Hosts auslösen, also auf deiner Website, die bei deinen Tags als Auslöser dient. Hier im Beispiel mal der “All Pages”-Trigger. So geht’s:
Einfach einen neuen Trigger anlegen, der den Systemstandard-Trigger “All Pages” ablösen kann:
- Triggertyp “Seitenaufruf”
- Diesen Trigger auslösen bei “Einige Seitenaufrufe” (klingt erstmal widersinnig, denn es soll ja auf allen Seiten sein, aber wir schränken gleich nur den Host ein)
- Diesen Trigger auslösen, wenn ein Ereignis eintritt und alle diese Bedingungen erfüllt sind: “Page Hostname” > “stimmt mit regulärem Ausdruck überein” > “meinedomain\.de” (Bitte nicht den umgekehrten Schrägstrich/Backslash vergessen) (Wenn die Variable “Page Hostname” bei dir noch nicht verfügbar ist, sie ggf. zuvor aktivieren im Menübereich “Variablen”)
Im Anschluss dann ggf. die Trigger in deinen Tags auf den neuen Trigger umstellen. Oder wie gesagt: Die bestehenden Trigger erweitern.
Und das Ende vom Lied
Was kann da alles passieren, werden jetzt alle Leser gedacht haben. Kann man den Google Tag Manager überhaupt noch sinnvoll einsetzen bei diesen Möglichkeiten?
Aber klar doch. Spammern stehen ungeschützten Tag Manager- und Analytics-Konten von jeher einige Türen offen. Deshalb auf Tracking zu verzichten, halte ich gelinde gesagt für gewagt. Zumal es ja mindestens mal die drei oben genannten Möglichkeiten gibt, das zu verhindern. Insofern bin ich da recht entspannt, wenn ich darauf angesprochen werden.
Aber ich halte es für absolut wichtig zu wissen, was passieren kann, DAMIT du dich eben schützen kannst.
Fazit
Jep, ein Google Tag Manager Container lässt sich kidnappen und damit zum Beispiel Traffic auf ein fremdes Analytics-Konto schicken. Schwer ist das nicht.
Doch es gibt mindestens die drei obigen Lösungen, wie du dagegen etwas tun kannst – und insofern ist Panik unangebracht.
Welche ist deine Lösung? Lass’ uns darüber sprechen. Gerne in den Kommentaren.
- Schneller Lernen, schneller Wachsen: Warum Perfektionismus und Angst-Marketing euer Wachstum aufhalten
- Wachstum beginnt mit Klarheit: Wie Unternehmen auch bei Marktdruck durch klare Ziele und datenbasierte Entscheidungen aus der Stagnation kommen
- Typische Kennzahlen-Fehler: Warum der ROAS kein Schlüssel zum Unternehmenserfolg ist
Julien Coquet hatte vor längerem etwas dazu geschrieben und mit Simo Ahava haben wir auch ein paar Szenarien durchgespielt, z.B. Fake-Umsätze in Millionenhöhe zu generieren. Zu wissen, wie Spamming und Hijacking funktioniert, macht jemanden offen für Überlegungen, sich dagegen zu schützen.
Das ist wichtig, also danke für den Artikel und die Lösungsansätze.
Gerne, Arne.
Vielleicht hast du ja noch einen weiterführenden Link für uns.
Hallo Maik,
es muss ein anderer Autor gewesen sein, ich werde noch suchen. Von Julien war es der Beitrag zum Site bzw. Content ripping (inkl. GTM Container-Code), wodurch interessante Gegenmaßnahmen möglich werden:
https://juliencoquet.com/en/2015/03/24/creative-uses-of-google-tag-manager-site-hacking-ripping/