Scan-Fakten als JSON anzeigen
{
"schema": "https://saferpage.de/schemas/public-scan-facts.v1",
"claim_boundary": "Öffentliche Rohdaten enthalten nur Scan-Fakten, Statuswerte, Evidence-Grenzen und feste Detail-/Hintergrund-Links. Betreiber-Hintergrund, Planungen, Checklisten, Code und allgemeine Empfehlungen stehen auf separaten Seiten.",
"current_evidence_policy": {
"schema": "https://saferpage.de/schemas/public-scan-current-evidence-policy.v1",
"status": "current_scan_fields_only",
"summary": "Der Fakten-JSON exportiert nur Felder, die im gespeicherten aktuellen Scan wirklich vorhanden sind. Fehlende neue Evidence wird nicht aus alten Testergebnisformaten nachgebaut.",
"guardrails": [
"Keine synthetischen Boundary-Fallbacks fuer alte Scans",
"Keine Nachbewertung alter Testergebnisse im Fakten-JSON",
"Keine Betreiber-Empfehlung im Report-JSON"
]
},
"host": "gfz.de",
"normalized_url": "https://gfz.de/",
"score": 66,
"verdict": {
"color": "yellow",
"label": "unklar",
"score": 66
},
"scan_id": "ba01ef78-e624-4b54-92d9-119c369ff3f6",
"created_at": "2026-06-19 08:19:30.687016+02",
"evidence": {
"dns": {
"ok": true,
"addresses": [
"139.17.229.15"
],
"duration_ms": 2
},
"tls": {
"ok": true,
"cipher": "TLS_AES_256_GCM_SHA384",
"issuer": [
[
[
"countryName",
"GR"
]
],
[
[
"organizationName",
"Hellenic Academic and Research Institutions CA"
]
],
[
[
"commonName",
"GEANT TLS ECC 1"
]
]
],
"subject": [
[
[
"countryName",
"DE"
]
],
[
[
"stateOrProvinceName",
"Brandenburg"
]
],
[
[
"organizationName",
"GFZ Helmholtz-Zentrum fuer Geoforschung"
]
],
[
[
"commonName",
"www.gfz-potsdam.de"
]
]
],
"version": "TLSv1.3",
"not_after": "Nov 14 23:58:34 2026 GMT",
"hostname_matches": true,
"days_until_expiry": 148,
"subject_alt_names": [
"www.gfz-potsdam.de",
"www-prod3.gfz-potsdam.de",
"gfz-potsdam.de",
"www-prod5.gfz.de",
"www.gfz.de",
"gfz.de",
"www-prod6.gfz.de",
"www-prod1.gfz-potsdam.de",
"www-prod4.gfz.de",
"www-prod2.gfz-potsdam.de"
],
"issuer_common_name": "GEANT TLS ECC 1"
},
"http": {
"ok": true,
"status": 200,
"headers": {
"date": "Fri, 19 Jun 2026 06:19:03 GMT",
"vary": "Accept-Encoding",
"pragma": "public",
"server": "Apache/2.4.58 (Ubuntu)",
"expires": "Fri, 19 Jun 2026 22:00:00 GMT",
"upgrade": "h2",
"connection": "Upgrade, close",
"set-cookie": "PHPSESSID=dsm6llfmkhvdh05ujs76fuu347; path=/",
"content-type": "text/html; charset=utf-8",
"cache-control": "max-age=56457",
"x-ua-compatible": "IE=edge",
"content-language": "de-DE",
"transfer-encoding": "chunked",
"x-content-type-options": "nosniff"
},
"body_size": 107573,
"final_url": "https://www.gfz.de/",
"duration_ms": 313
},
"scanner": {
"bot_url": "https://saferpage.de/bot",
"context": "crawler",
"user_agent": "SaferPageCrawler/0.3 (+https://saferpage.de/bot; schedules passive DACH website checks; report examples: https://saferpage.de/tests; kostenloser Report: <a href=\"https://saferpage.de/gfz.de\">https://saferpage.de/gfz.de</a>)",
"default_user_agent": "SaferPageBot/0.2 (+https://saferpage.de/bot; passive website safety check; no attack tests)"
},
"domain_records": {
"mx": true,
"caa": true,
"spf": true,
"dmarc": true,
"dnssec": false,
"records": {
"mx": [
"10 c1791.mx.srv.dfn.de.",
"10 a1791.mx.srv.dfn.de.",
"10 b1791.mx.srv.dfn.de."
],
"ns": [
"deneb.dfn.de.",
"zrt7b.gfz-potsdam.de."
],
"caa": [
"0 issue \"pki.dfn.de",
"0 issue \"harica.gr",
"0 issue \"sectigo.com"
],
"txt": [
"ZOOM_verify_WMcZHMblRpm62qSZoQBMGt",
"openai-domain-verification=dv-9tE5pBQ3FyUnoOmhgRwTtFq2",
"google-site-verification=5DbFz1OqPjnkQBkd3L4S0nfb9_uVY9PyhjzaA1tVqls",
"google-site-verification=xZys4ru3dIHJgPjigJsVn4lxGuWDLkVhMt8pI5-UhcE",
"google-site-verification=PBmbfc0roQUVqC9JRR5CG3I8Dde-BsCDpxsdcOSSVi4",
"brevo-code:6fad695b8997745705f7bded854ca36f",
"v=spf1 a:mail.gfz.de a:otc-de-spf.mms.t-systems-service.com a:gfz-potsdam.managed-otrs.com ~all",
"HARICA-daixckcDu6hTgkCM3hk",
"HARICA-Atmb6pR6Dtv9DZMiMY7",
"apple-domain-verification=x4FbNnccJGQzMTnS"
],
"cname": [],
"dmarc": [
"v=DMARC1; p=quarantine;"
],
"dnskey_present": false
},
"spf_includes": [],
"verifications": [
"google",
"apple"
]
},
"googlebot_http": {
"ok": true,
"status": 200,
"headers": {
"date": "Fri, 19 Jun 2026 06:19:03 GMT",
"vary": "Accept-Encoding",
"pragma": "public",
"server": "Apache/2.4.58 (Ubuntu)",
"expires": "Fri, 19 Jun 2026 22:00:00 GMT",
"upgrade": "h2",
"connection": "Upgrade, close",
"set-cookie": "PHPSESSID=jpnshbd9bdql1186her4v4vi7f; path=/",
"content-type": "text/html; charset=utf-8",
"cache-control": "max-age=56457",
"x-ua-compatible": "IE=edge",
"content-language": "de-DE",
"transfer-encoding": "chunked",
"x-content-type-options": "nosniff"
},
"body_size": 107573,
"final_url": "https://www.gfz.de/",
"duration_ms": 312
},
"ai_search_policy_evidence": {
"files": [
{
"id": "robots_txt",
"url": "https://www.gfz.de/robots.txt",
"label": "robots.txt",
"reason": "",
"status": "found",
"body_size": 392,
"truncated": false,
"body_sha256": "520d3c7563ffc443fd37a96d8336ab233471b0283b75a10219d3c7f0599a8c96",
"duration_ms": 194,
"http_status": 200,
"ai_bot_policy": {
"bot_directives": [],
"explicit_ai_bots": [],
"explicit_ai_bot_count": 0,
"wildcard_directive_count": 9,
"wildcard_directives_sample": [
{
"value": "/",
"directive": "allow"
},
{
"value": "/typo3/",
"directive": "disallow"
},
{
"value": "/typo3conf/",
"directive": "disallow"
},
{
"value": "/typo3conf/ext/",
"directive": "allow"
},
{
"value": "/typo3temp/",
"directive": "allow"
},
{
"value": "/*?id=*",
"directive": "disallow"
},
{
"value": "/*cHash",
"directive": "disallow"
},
{
"value": "/*tx_powermail_pi1",
"directive": "disallow"
}
]
},
"relevant_lines": [
"User-agent: *",
"Allow: /",
"Disallow: /typo3/",
"Disallow: /typo3conf/",
"Allow: /typo3conf/ext/",
"Allow: /typo3temp/",
"Disallow: /*?id=* # non speaking URLs",
"Disallow: /*cHash # no cHash",
"Disallow: /*tx_powermail_pi1 # no powermail thanks pages",
"Disallow: /*tx_form_formframework # no forms",
"# sitemap",
"Sitemap: https://www.gfz-potsdam.de/sitemap.xml"
]
},
{
"id": "llms_txt",
"url": "https://www.gfz.de/llms.txt",
"label": "llms.txt",
"reason": "http_error",
"status": "missing",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 196,
"http_status": 404,
"relevant_lines": []
},
{
"id": "ai_txt",
"url": "https://www.gfz.de/.well-known/ai.txt",
"label": "AI Policy",
"reason": "http_error",
"status": "missing",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 143,
"http_status": 404,
"relevant_lines": []
},
{
"id": "ai_policy_txt",
"url": "https://www.gfz.de/.well-known/ai-policy.txt",
"label": "AI Policy",
"reason": "http_error",
"status": "missing",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 130,
"http_status": 404,
"relevant_lines": []
},
{
"id": "ward_txt",
"url": "https://www.gfz.de/.well-known/ward.txt",
"label": "WARD Policy",
"reason": "http_error",
"status": "missing",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 125,
"http_status": 404,
"relevant_lines": []
}
],
"origin": "https://www.gfz.de",
"schema": "https://saferpage.de/schemas/ai-search-policy-evidence.v1",
"status": "checked",
"metrics": {
"file_count": 5,
"found_file_count": 1,
"policy_file_count": 0,
"explicit_ai_bot_count": 0
},
"summary": "1 von 5 Policy-Datei(en) gefunden; 0 explizite KI-Bot-Regel(n) in robots.txt.",
"available": true,
"guardrails": [
"Nur feste Same-Origin-Policy-Dateien",
"Keine Off-Host-Redirects",
"64-KB-Body-Limit",
"Öffentlich nur Hash, Status und kurze relevante Zeilen"
],
"known_ai_bots": [
"GPTBot",
"ChatGPT-User",
"Google-Extended",
"ClaudeBot",
"PerplexityBot",
"CCBot"
],
"explicit_ai_bots": [],
"policy_file_count": 0,
"llms_ward_policy_status": "not_publicly_verified",
"robots_ai_policy_status": "generic_robots_policy"
},
"adtech_transparency_evidence": {
"files": [
{
"id": "ads_txt",
"url": "https://www.gfz.de/ads.txt",
"label": "ads.txt",
"reason": "http_error",
"status": "missing",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 270,
"http_status": 404,
"ads_txt_policy": [],
"relevant_lines": [],
"sellers_json_policy": []
},
{
"id": "app_ads_txt",
"url": "https://www.gfz.de/app-ads.txt",
"label": "app-ads.txt",
"reason": "http_error",
"status": "missing",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 195,
"http_status": 404,
"ads_txt_policy": [],
"relevant_lines": [],
"sellers_json_policy": []
},
{
"id": "sellers_json",
"url": "https://www.gfz.de/sellers.json",
"label": "sellers.json",
"reason": "http_error",
"status": "missing",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 120,
"http_status": 404,
"ads_txt_policy": [],
"relevant_lines": [],
"sellers_json_policy": []
}
],
"origin": "https://www.gfz.de",
"schema": "https://saferpage.de/schemas/adtech-transparency-evidence.v1",
"status": "checked",
"metrics": {
"file_count": 3,
"direct_count": 0,
"reseller_count": 0,
"found_file_count": 0,
"ads_txt_entry_count": 0,
"exchange_domain_count": 0,
"app_ads_txt_entry_count": 0,
"sellers_json_seller_count": 0
},
"summary": "0 von 3 AdTech-Transparenzdatei(en) gefunden; 0 DIRECT- und 0 RESELLER-Zeile(n).",
"available": true,
"guardrails": [
"Nur feste Same-Origin-AdTech-Dateien",
"Keine Off-Host-Redirects",
"64-KB-Body-Limit",
"Öffentlich nur Hash, Status, Zähler und kurze relevante Zeilen"
],
"direct_count": 0,
"ads_txt_found": false,
"reseller_count": 0,
"app_ads_txt_found": false,
"sellers_json_found": false,
"ads_txt_entry_count": 0,
"exchange_domain_count": 0,
"sellers_json_parse_ok": false,
"app_ads_txt_entry_count": 0,
"sellers_json_seller_count": 0
},
"security_trust_policy_evidence": {
"files": [
{
"id": "security_txt",
"url": "https://www.gfz.de/.well-known/security.txt",
"label": "security.txt",
"reason": "http_error",
"status": "missing",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 269,
"http_status": 404,
"relevant_lines": [],
"security_txt_policy": []
},
{
"id": "security_txt_legacy",
"url": "https://www.gfz.de/security.txt",
"label": "security.txt legacy",
"reason": "http_error",
"status": "missing",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 195,
"http_status": 404,
"relevant_lines": [],
"security_txt_policy": []
}
],
"origin": "https://www.gfz.de",
"schema": "https://saferpage.de/schemas/security-trust-policy-evidence.v1",
"status": "checked",
"metrics": {
"file_count": 2,
"field_count": 0,
"contact_count": 0,
"found_file_count": 0,
"preferred_well_known_found": 0
},
"summary": "0 von 2 security.txt-Ziel(en) gefunden; 0 Kontaktfeld(er), 0 strukturierte Feld(er).",
"available": true,
"guardrails": [
"Nur feste Same-Origin-security.txt-Ziele",
"Keine Off-Host-Redirects",
"64-KB-Body-Limit",
"Öffentlich nur Hash, Status und kurze relevante Zeilen"
],
"field_count": 0,
"contact_count": 0,
"fields_present": [],
"policy_present": false,
"expires_present": false,
"encryption_present": false,
"security_txt_found": false,
"preferred_well_known_found": false
}
},
"findings": [
{
"id": "known_vulnerability_advisory",
"title": "CVE-2026-24072: An escalation of privilege bug in various modules in Apache HTTP 2.4.66 and earlier allows local .htaccess authors to read files with the privileges of the httpd user",
"public": true,
"version": "2.4.58",
"audience": "nutzer",
"category": "vulnerability",
"severity": "critical",
"confirmed": true,
"technology": "Apache",
"advisory_id": "CVE-2026-24072",
"user_importance": 135,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "known_vulnerability_advisory",
"title": "CVE-2026-28780: Heap-based Buffer Overflow vulnerability in mod_proxy_ajp of Apache HTTP Server",
"public": true,
"version": "2.4.58",
"audience": "nutzer",
"category": "vulnerability",
"severity": "critical",
"confirmed": true,
"technology": "Apache",
"advisory_id": "CVE-2026-28780",
"user_importance": 135,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "known_vulnerability_advisory",
"title": "CVE-2026-29168: Allocation of Resources Without Limits or Throttling vulnerability in Apache HTTP Server's mod_md via OCSP response data",
"public": true,
"version": "2.4.58",
"audience": "nutzer",
"category": "vulnerability",
"severity": "critical",
"confirmed": true,
"technology": "Apache",
"advisory_id": "CVE-2026-29168",
"user_importance": 135,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "known_vulnerability_advisory",
"title": "CVE-2026-29169: A NULL pointer dereference in mod_dav_lock in Apache HTTP Server 2.4.66 and earlier may allow an attacker to crash the server with a malicious request.mod_dav_lock is not used inte",
"public": true,
"version": "2.4.58",
"audience": "nutzer",
"category": "vulnerability",
"severity": "critical",
"confirmed": true,
"technology": "Apache",
"advisory_id": "CVE-2026-29169",
"user_importance": 135,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "known_vulnerability_advisory",
"title": "CVE-2026-33006: A timing attack against mod_auth_digest in Apache HTTP Server 2.4.66 allows a bypass of Digest authentication by a remote attacker",
"public": true,
"version": "2.4.58",
"audience": "nutzer",
"category": "vulnerability",
"severity": "warning",
"confirmed": true,
"technology": "Apache",
"advisory_id": "CVE-2026-33006",
"user_importance": 135,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "known_vulnerability_advisory",
"title": "CVE-2026-33007: A NULL pointer dereference in the mod_authn_socache in Apache HTTP Server 2.4.66 and earlier allows an unauthenticated remote user to crash a child process in a caching forward pro",
"public": true,
"version": "2.4.58",
"audience": "nutzer",
"category": "vulnerability",
"severity": "warning",
"confirmed": true,
"technology": "Apache",
"advisory_id": "CVE-2026-33007",
"user_importance": 135,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "known_vulnerability_advisory",
"title": "CVE-2026-33523: HTTP response splitting vulnerability in multiple Apache HTTP Server modules with untrusted or compromised backend servers",
"public": true,
"version": "2.4.58",
"audience": "nutzer",
"category": "vulnerability",
"severity": "warning",
"confirmed": true,
"technology": "Apache",
"advisory_id": "CVE-2026-33523",
"user_importance": 135,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "known_vulnerability_advisory",
"title": "CVE-2026-33857: Out-of-bounds Read vulnerability in mod_proxy_ajp of Apache HTTP Server",
"public": true,
"version": "2.4.58",
"audience": "nutzer",
"category": "vulnerability",
"severity": "warning",
"confirmed": true,
"technology": "Apache",
"advisory_id": "CVE-2026-33857",
"user_importance": 135,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "known_vulnerability_advisory",
"title": "CVE-2026-34032: Improper Null Termination, Out-of-bounds Read vulnerability in Apache HTTP Server",
"public": true,
"version": "2.4.58",
"audience": "nutzer",
"category": "vulnerability",
"severity": "warning",
"confirmed": true,
"technology": "Apache",
"advisory_id": "CVE-2026-34032",
"user_importance": 135,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "known_vulnerability_advisory",
"title": "CVE-2026-34059: Buffer Over-read vulnerability in Apache HTTP Server",
"public": true,
"version": "2.4.58",
"audience": "nutzer",
"category": "vulnerability",
"severity": "critical",
"confirmed": true,
"technology": "Apache",
"advisory_id": "CVE-2026-34059",
"user_importance": 135,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "browser_consent_accept_only",
"title": "Consent-Banner wirkt im Browser wie Akzeptieren-only",
"public": true,
"audience": "nutzer",
"category": "privacy",
"severity": "warning",
"user_importance": 123,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "tracking_pixel_detected",
"count": 1,
"title": "Tracking-Pixel oder pixelnahe Requests erkannt",
"public": true,
"audience": "nutzer",
"category": "privacy",
"severity": "info",
"evidence_items": [
"https://webstats.gfz.de/matomo.php?idsite=1&rec=1"
],
"user_importance": 119,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "external_canonical",
"title": "Canonical zeigt auf fremde Domain",
"public": true,
"audience": "nutzer",
"category": "seo",
"severity": "warning",
"canonical_url": "https://www.gfz.de/",
"evidence_items": [
"https://www.gfz.de/"
],
"user_importance": 118,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "cookie_missing_secure",
"title": "Cookie ohne Secure-Flag",
"public": true,
"cookies": [
"PHPSESSID"
],
"audience": "nutzer",
"category": "privacy",
"severity": "warning",
"evidence_items": [
"PHPSESSID"
],
"user_importance": 102,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "cookie_missing_samesite",
"title": "Cookie ohne SameSite-Attribut",
"public": true,
"cookies": [
"PHPSESSID"
],
"audience": "nutzer",
"category": "privacy",
"severity": "info",
"evidence_items": [
"PHPSESSID"
],
"user_importance": 98,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "privacy_policy_update_date_missing",
"title": "Stand der Datenschutzerklärung nicht klar erkennbar",
"public": true,
"audience": "nutzer",
"category": "privacy",
"severity": "info",
"user_importance": 94,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "browser_consent_settings_missing",
"title": "Keine sichtbaren Cookie-Einstellungen im Banner",
"public": true,
"audience": "nutzer",
"category": "privacy",
"severity": "info",
"user_importance": 86,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "image_alt_missing",
"count": 8,
"title": "Bilder ohne Alternativtext",
"public": true,
"audience": "nutzer",
"category": "accessibility",
"severity": "info",
"evidence_items": [
"/fileadmin/_processed_/4/5/csm_6368d3f292da3baaad130806775d8824_ebef3607df.jpeg",
"/fileadmin/_processed_/e/f/csm_T1_Foto_Original_he_2ed984f6c7.png",
"/fileadmin/_processed_/3/a/csm_T2_Foto_final_lower_resolution_a61f96669a.jpeg",
"/fileadmin/_processed_/5/6/csm_T3_Foto_Maule_Beben_final_24922bdf4f.jpeg",
"/fileadmin/_processed_/3/d/csm_T5_Foto_Original_e2cd7de54c.png",
"/fileadmin/_processed_/d/9/csm_Kachel_Publikationen_842201dc23.png",
"/fileadmin/_processed_/b/6/csm_grimm-z-19_a7345e09e6.jpeg",
"https://webstats.gfz.de/matomo.php?idsite=1&rec=1"
],
"user_importance": 82,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "missing_hsts",
"title": "HSTS fehlt",
"public": true,
"audience": "betreiber",
"category": "security_headers",
"severity": "warning",
"evidence_items": [
"HTTP-Header „Strict-Transport-Security\" fehlt in der Antwort der Startseite"
],
"user_importance": 78,
"importance_label": "Technischer Hinweis"
},
{
"id": "missing_csp",
"title": "Content-Security-Policy fehlt",
"public": true,
"audience": "betreiber",
"category": "security_headers",
"severity": "warning",
"evidence_items": [
"HTTP-Header „Content-Security-Policy\" fehlt in der Antwort der Startseite"
],
"user_importance": 72,
"importance_label": "Technischer Hinweis"
},
{
"id": "missing_x_frame_options",
"title": "X-Frame-Options fehlt",
"public": true,
"audience": "betreiber",
"category": "security_headers",
"severity": "warning",
"evidence_items": [
"HTTP-Header „X-Frame-Options\" fehlt in der Antwort der Startseite"
],
"user_importance": 70,
"importance_label": "Technischer Hinweis"
},
{
"id": "missing_cross_origin_embedder_policy",
"title": "Cross-Origin-Embedder-Policy fehlt",
"public": true,
"audience": "betreiber",
"category": "security_headers",
"severity": "info",
"evidence_items": [
"HTTP-Header „Cross-Origin-Embedder-Policy\" fehlt in der Antwort der Startseite"
],
"user_importance": 68,
"importance_label": "Technischer Hinweis"
},
{
"id": "missing_cross_origin_opener_policy",
"title": "Cross-Origin-Opener-Policy fehlt",
"public": true,
"audience": "betreiber",
"category": "security_headers",
"severity": "info",
"evidence_items": [
"HTTP-Header „Cross-Origin-Opener-Policy\" fehlt in der Antwort der Startseite"
],
"user_importance": 66,
"importance_label": "Technischer Hinweis"
},
{
"id": "missing_cross_origin_resource_policy",
"title": "Cross-Origin-Resource-Policy fehlt",
"public": true,
"audience": "betreiber",
"category": "security_headers",
"severity": "info",
"evidence_items": [
"HTTP-Header „Cross-Origin-Resource-Policy\" fehlt in der Antwort der Startseite"
],
"user_importance": 64,
"importance_label": "Technischer Hinweis"
},
{
"id": "consent_banner_dark_pattern_risk",
"count": 1,
"title": "Consent-Banner mit Dark-Pattern-/UX-Risiko",
"public": true,
"audience": "betreiber",
"category": "privacy",
"severity": "warning",
"evidence_items": [
"Banner-UX: Akzeptieren 2 vs. Ablehnen 0 – Ablehnen weniger prominent/gleichwertig"
],
"user_importance": 60,
"importance_label": "Technischer Hinweis"
},
{
"id": "missing_referrer_policy",
"title": "Referrer-Policy fehlt",
"public": true,
"audience": "betreiber",
"category": "security_headers",
"severity": "info",
"evidence_items": [
"HTTP-Header „Referrer-Policy\" fehlt in der Antwort der Startseite"
],
"user_importance": 40,
"importance_label": "Technischer Hinweis"
},
{
"id": "missing_permissions_policy",
"title": "Permissions-Policy fehlt",
"public": true,
"audience": "betreiber",
"category": "security_headers",
"severity": "info",
"evidence_items": [
"HTTP-Header „Permissions-Policy\" fehlt in der Antwort der Startseite"
],
"user_importance": 40,
"importance_label": "Technischer Hinweis"
}
],
"audit_modules": [
{
"id": "security_tls",
"color": "red",
"score": 46,
"title": "Sicherheit, TLS & Header",
"source": "DNS, TLS, HTTP-Status, Zertifikat und Security-Header",
"status": "kritisch",
"evidence": "0 Infrastruktur-Hinweis(e), Security-Header: 1/9 vorhanden, 8 fehlen, externe Skript-Hosts: 0."
},
{
"id": "accessibility_usability",
"color": "yellow",
"score": 76,
"title": "Barrierefreiheit & Usability",
"source": "Passives HTML-Sample: Bilder, Formulare, Buttons, Sprache, Headings und Viewport",
"status": "prüfen",
"evidence": "8 Bild(er) ohne alt, 0 Formularfeld(er) ohne Beschriftung, 0 Button(s) ohne Namen."
},
{
"id": "privacy_consent",
"color": "yellow",
"score": 78,
"title": "Datenschutz, Cookies & Consent",
"source": "Browser, HTTP-Header, HTML und Consent-/Cookie-Heuristik",
"status": "prüfen",
"evidence": "0 Tracking-Script(s), 1 Cookie(s) vor Einwilligung, 0 Tracking-Cookie(s), Ablehnen-Option: ja, Consent-Audit: 78."
},
{
"id": "seo_integrity",
"color": "yellow",
"score": 82,
"title": "SEO-Integrität & Cloaking",
"source": "HTML-Inhalt, strukturierte Daten, Links und Googlebot-Vergleich",
"status": "prüfen",
"evidence": "1 SEO-Spam-Hinweis(e), 0 Cloaking-Hinweis(e)."
},
{
"id": "browser_evidence",
"color": "green",
"score": 90,
"title": "Browser-Nachweis",
"source": "Headless Chromium mit Screenshot- und Request-Telemetrie",
"status": "unauffällig",
"evidence": "51 Request(s), 0 Drittanbieter-Domain(s), davon 0 datenschutzrelevant, 1 Browser-Cookie(s), Transfer-Prüfbedarf: 0, Referrer-/URL-Leaks: 0, Fingerprinting-/Replay-Hinweise: 0."
},
{
"id": "tracking_pixels_beacons",
"color": "green",
"score": 90,
"title": "Tracking-Pixel & Beacons",
"source": "HTML-Pixel, Link-Ping-Attribute, Chromium-Requests und Browser-API-Instrumentierung",
"status": "unauffällig",
"evidence": "1 Pixel-/Bildtracking-Hinweis(e), 0 Beacon-/Telemetry-Hinweis(e), 0 Link-Ping(s)."
},
{
"id": "cookie_inventory",
"color": "green",
"score": 95,
"title": "Cookie-Inventar",
"source": "HTTP-Set-Cookie und Chromium-Cookies beim ersten Seitenaufruf",
"status": "unauffällig",
"evidence": "1 Cookie(s), 0 Tracking-/Werbe-Cookie(s), 0 Drittanbieter-Cookie(s), 0 langlebig, 0 sehr lang."
},
{
"id": "consent_journey",
"color": "green",
"score": 100,
"title": "Consent-Journey-Matrix",
"source": "Chromium-Zustände: Erstaufruf, Reject, Accept und GPC",
"status": "unauffällig",
"evidence": "Consent-Journey: 0 neue Datenschutz-Domain(s) nach Ablehnen, 0 nach Akzeptieren, 0 im GPC-Aufruf."
},
{
"id": "embedded_content",
"color": "green",
"score": 100,
"title": "Externe Inhalte & Widgets",
"source": "HTML-Embeds und Chromium-Drittanbieter-Requests",
"status": "unauffällig",
"evidence": "0 externe Embed-/Widget-Dienst(e), 0 davon im ersten Browseraufruf geladen."
},
{
"id": "script_supply_chain",
"color": "green",
"score": 100,
"title": "Externe Skripte & SRI",
"source": "HTML-Script-Tags, Anbieterklassifikation und SRI-Attribute",
"status": "unauffällig",
"evidence": "0 externe Skript(e) von 0 Host(s), 0 ohne SRI, 0 Tracking-/Tag-nahe Skript(e)."
},
{
"id": "forms_payments",
"color": "green",
"score": 100,
"title": "Formulare, Login & Zahlung",
"source": "HTML-Formulare, Eingabefelder, Zahlungsanbieter und Kontextlinks",
"status": "unauffällig",
"evidence": "Die Seite kann Kontaktformular abfragen."
},
{
"id": "google_third_parties",
"color": "green",
"score": 100,
"title": "Google-Dienste & Drittanbieter",
"source": "Chromium-Requests, Anbieterklassifikation und Google Consent Mode Heuristik",
"status": "unauffällig",
"evidence": "Keine Google-Domain, keine Google-Tracking-ID und keine datenschutzrelevanten Drittanbieter im passiven Check erkannt."
},
{
"id": "operator_transparency",
"color": "green",
"score": 100,
"title": "Impressum, Kontakt & Datenschutzerklärung",
"source": "Deutschsprachige Betreiber- und Datenschutzhinweis-Erkennung",
"status": "unauffällig",
"evidence": "Impressum: ja, Datenschutz: ja, Kontakt: ja."
},
{
"id": "pii_exposure",
"color": "green",
"score": 100,
"title": "PII, URL-Parameter & Datenleck-Schutz",
"source": "URL-Parameter, interne Links, HTML-Formulare, Browser-Drittanbieter und Dateneingabe-Kontext",
"status": "unauffällig",
"evidence": "0 PII-/Datenleck-Hinweis(e) aus URL-, Formular- und Browserkontext."
},
{
"id": "performance_mobile",
"color": "green",
"score": 100,
"title": "Performance & mobile Nutzbarkeit",
"source": "HTTP-Antwort, HTML-Größe, Komprimierung und mobile Basis",
"status": "unauffällig",
"evidence": "Performance-Score 100, Antwortzeit 313 ms."
},
{
"id": "referrer_url_leaks",
"color": "green",
"score": 100,
"title": "Referrer & URL-Leaks",
"source": "Chromium-Request-Telemetrie ohne gespeicherte Parameterwerte",
"status": "unauffällig",
"evidence": "0 Drittanbieter-Domain(s) mit Referrer-/URL-Leak-Prüfbedarf, 0 sensible Query-Kontexte."
},
{
"id": "site_coverage",
"color": "green",
"score": 100,
"title": "Seitenabdeckung & Crawl",
"source": "Startseiten-Links, Compliance-Links und begrenzter interner Zusatzabruf",
"status": "unauffällig",
"evidence": "30 interne Linkziele erkannt, 4 priorisierte Unterseite(n) abgerufen."
}
],
"ai_search_policy_evidence": {
"files": [
{
"id": "robots_txt",
"url": "https://www.gfz.de/robots.txt",
"label": "robots.txt",
"reason": "",
"status": "found",
"body_size": 392,
"truncated": false,
"body_sha256": "520d3c7563ffc443fd37a96d8336ab233471b0283b75a10219d3c7f0599a8c96",
"duration_ms": 194,
"http_status": 200,
"ai_bot_policy": {
"bot_directives": [],
"explicit_ai_bots": [],
"explicit_ai_bot_count": 0,
"wildcard_directive_count": 9,
"wildcard_directives_sample": [
{
"value": "/",
"directive": "allow"
},
{
"value": "/typo3/",
"directive": "disallow"
},
{
"value": "/typo3conf/",
"directive": "disallow"
},
{
"value": "/typo3conf/ext/",
"directive": "allow"
},
{
"value": "/typo3temp/",
"directive": "allow"
},
{
"value": "/*?id=*",
"directive": "disallow"
},
{
"value": "/*cHash",
"directive": "disallow"
},
{
"value": "/*tx_powermail_pi1",
"directive": "disallow"
}
]
},
"relevant_lines": [
"User-agent: *",
"Allow: /",
"Disallow: /typo3/",
"Disallow: /typo3conf/",
"Allow: /typo3conf/ext/",
"Allow: /typo3temp/",
"Disallow: /*?id=* # non speaking URLs",
"Disallow: /*cHash # no cHash",
"Disallow: /*tx_powermail_pi1 # no powermail thanks pages",
"Disallow: /*tx_form_formframework # no forms",
"# sitemap",
"Sitemap: https://www.gfz-potsdam.de/sitemap.xml"
]
},
{
"id": "llms_txt",
"url": "https://www.gfz.de/llms.txt",
"label": "llms.txt",
"reason": "http_error",
"status": "missing",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 196,
"http_status": 404,
"relevant_lines": []
},
{
"id": "ai_txt",
"url": "https://www.gfz.de/.well-known/ai.txt",
"label": "AI Policy",
"reason": "http_error",
"status": "missing",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 143,
"http_status": 404,
"relevant_lines": []
},
{
"id": "ai_policy_txt",
"url": "https://www.gfz.de/.well-known/ai-policy.txt",
"label": "AI Policy",
"reason": "http_error",
"status": "missing",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 130,
"http_status": 404,
"relevant_lines": []
},
{
"id": "ward_txt",
"url": "https://www.gfz.de/.well-known/ward.txt",
"label": "WARD Policy",
"reason": "http_error",
"status": "missing",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 125,
"http_status": 404,
"relevant_lines": []
}
],
"origin": "https://www.gfz.de",
"schema": "https://saferpage.de/schemas/ai-search-policy-evidence.v1",
"status": "checked",
"metrics": {
"file_count": 5,
"found_file_count": 1,
"policy_file_count": 0,
"explicit_ai_bot_count": 0
},
"summary": "1 von 5 Policy-Datei(en) gefunden; 0 explizite KI-Bot-Regel(n) in robots.txt.",
"available": true,
"guardrails": [
"Nur feste Same-Origin-Policy-Dateien",
"Keine Off-Host-Redirects",
"64-KB-Body-Limit",
"Öffentlich nur Hash, Status und kurze relevante Zeilen"
],
"known_ai_bots": [
"GPTBot",
"ChatGPT-User",
"Google-Extended",
"ClaudeBot",
"PerplexityBot",
"CCBot"
],
"explicit_ai_bots": [],
"policy_file_count": 0,
"llms_ward_policy_status": "not_publicly_verified",
"robots_ai_policy_status": "generic_robots_policy"
},
"adtech_transparency_evidence": {
"files": [
{
"id": "ads_txt",
"url": "https://www.gfz.de/ads.txt",
"label": "ads.txt",
"reason": "http_error",
"status": "missing",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 270,
"http_status": 404,
"ads_txt_policy": [],
"relevant_lines": [],
"sellers_json_policy": []
},
{
"id": "app_ads_txt",
"url": "https://www.gfz.de/app-ads.txt",
"label": "app-ads.txt",
"reason": "http_error",
"status": "missing",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 195,
"http_status": 404,
"ads_txt_policy": [],
"relevant_lines": [],
"sellers_json_policy": []
},
{
"id": "sellers_json",
"url": "https://www.gfz.de/sellers.json",
"label": "sellers.json",
"reason": "http_error",
"status": "missing",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 120,
"http_status": 404,
"ads_txt_policy": [],
"relevant_lines": [],
"sellers_json_policy": []
}
],
"origin": "https://www.gfz.de",
"schema": "https://saferpage.de/schemas/adtech-transparency-evidence.v1",
"status": "checked",
"metrics": {
"file_count": 3,
"direct_count": 0,
"reseller_count": 0,
"found_file_count": 0,
"ads_txt_entry_count": 0,
"exchange_domain_count": 0,
"app_ads_txt_entry_count": 0,
"sellers_json_seller_count": 0
},
"summary": "0 von 3 AdTech-Transparenzdatei(en) gefunden; 0 DIRECT- und 0 RESELLER-Zeile(n).",
"available": true,
"guardrails": [
"Nur feste Same-Origin-AdTech-Dateien",
"Keine Off-Host-Redirects",
"64-KB-Body-Limit",
"Öffentlich nur Hash, Status, Zähler und kurze relevante Zeilen"
],
"direct_count": 0,
"ads_txt_found": false,
"reseller_count": 0,
"app_ads_txt_found": false,
"sellers_json_found": false,
"ads_txt_entry_count": 0,
"exchange_domain_count": 0,
"sellers_json_parse_ok": false,
"app_ads_txt_entry_count": 0,
"sellers_json_seller_count": 0
},
"security_trust_policy_evidence": {
"files": [
{
"id": "security_txt",
"url": "https://www.gfz.de/.well-known/security.txt",
"label": "security.txt",
"reason": "http_error",
"status": "missing",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 269,
"http_status": 404,
"relevant_lines": [],
"security_txt_policy": []
},
{
"id": "security_txt_legacy",
"url": "https://www.gfz.de/security.txt",
"label": "security.txt legacy",
"reason": "http_error",
"status": "missing",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 195,
"http_status": 404,
"relevant_lines": [],
"security_txt_policy": []
}
],
"origin": "https://www.gfz.de",
"schema": "https://saferpage.de/schemas/security-trust-policy-evidence.v1",
"status": "checked",
"metrics": {
"file_count": 2,
"field_count": 0,
"contact_count": 0,
"found_file_count": 0,
"preferred_well_known_found": 0
},
"summary": "0 von 2 security.txt-Ziel(en) gefunden; 0 Kontaktfeld(er), 0 strukturierte Feld(er).",
"available": true,
"guardrails": [
"Nur feste Same-Origin-security.txt-Ziele",
"Keine Off-Host-Redirects",
"64-KB-Body-Limit",
"Öffentlich nur Hash, Status und kurze relevante Zeilen"
],
"field_count": 0,
"contact_count": 0,
"fields_present": [],
"policy_present": false,
"expires_present": false,
"encryption_present": false,
"security_txt_found": false,
"preferred_well_known_found": false
},
"site_coverage_analysis": {
"color": "green",
"pages": [
{
"url": "https://www.gfz.de/datenschutz",
"path": "/datenschutz",
"text": "Datenschutz",
"source": "homepage_link",
"category": "datenschutz",
"priority": 100
},
{
"url": "https://www.gfz.de/impressum",
"path": "/impressum",
"text": "Impressum",
"source": "homepage_link",
"category": "impressum",
"priority": 96
},
{
"url": "https://www.gfz.de/kontakt",
"path": "/kontakt",
"text": "Kontakt",
"source": "homepage_link",
"category": "kontakt",
"priority": 90
},
{
"url": "https://www.gfz.de/presse/gfz-schuelerlabor",
"path": "/presse/gfz-schuelerlabor",
"text": "GFZ-Schülerlabor",
"source": "homepage_link",
"category": "newsletter",
"priority": 64
},
{
"url": "https://www.gfz.de/ueber-uns/preise-und-auszeichnungen/rolf-emmermann-medaille",
"path": "/ueber-uns/preise-und-auszeichnungen/rolf-emmermann-medaille",
"text": "Preise und Auszeichnungen",
"source": "homepage_link",
"category": "preise",
"priority": 58
},
{
"url": "https://www.gfz.de/departments",
"path": "/departments",
"text": "Departments",
"source": "homepage_link",
"category": "unterseite",
"priority": 20
},
{
"url": "https://www.gfz.de/departments/geochemie",
"path": "/departments/geochemie",
"text": "Geochemie",
"source": "homepage_link",
"category": "unterseite",
"priority": 20
},
{
"url": "https://www.gfz.de/departments/geodaesie",
"path": "/departments/geodaesie",
"text": "Geodäsie",
"source": "homepage_link",
"category": "unterseite",
"priority": 20
},
{
"url": "https://www.gfz.de/departments/geosysteme",
"path": "/departments/geosysteme",
"text": "Geosysteme",
"source": "homepage_link",
"category": "unterseite",
"priority": 20
},
{
"url": "https://www.gfz.de/en",
"path": "/en",
"text": "English",
"source": "homepage_link",
"category": "unterseite",
"priority": 20
},
{
"url": "https://www.gfz.de/erklaerung-zur-barrierefreiheit",
"path": "/erklaerung-zur-barrierefreiheit",
"text": "Barrierefreiheit",
"source": "homepage_link",
"category": "unterseite",
"priority": 20
},
{
"url": "https://www.gfz.de/fernlern",
"path": "/fernlern",
"text": "FERN.Lern - Fernerkundung Lernen",
"source": "homepage_link",
"category": "unterseite",
"priority": 20
}
],
"score": 100,
"status": "unauffällig",
"summary": "30 interne Linkziele erkannt (0 aus Sitemap), 4 priorisierte Unterseite(n) zusätzlich abgerufen.",
"findings": [
{
"id": "privacy_policy_update_date_missing",
"title": "Stand der Datenschutzerklärung nicht klar erkennbar",
"public": true,
"category": "privacy",
"severity": "info"
}
],
"robots_ok": true,
"categories": {
"preise": 1,
"kontakt": 1,
"impressum": 1,
"newsletter": 1,
"unterseite": 25,
"datenschutz": 1
},
"sample_limit": 4,
"sampled_count": 4,
"sampled_pages": [
{
"ok": true,
"url": "https://www.gfz.de/datenschutz",
"path": "/datenschutz",
"audit": {
"form_count": 0,
"finding_ids": [
"cookie_missing_secure",
"cookie_missing_samesite"
],
"cookie_count": 1,
"imprint_found": true,
"consent_hint_found": true,
"reject_option_found": true,
"privacy_policy_found": true,
"tracking_script_count": 0,
"pre_consent_cookie_count": 1,
"pre_consent_tracking_cookie_count": 0
},
"forms": 0,
"title": "Datenschutz: GFZ",
"status": 200,
"category": "datenschutz",
"duration_ms": 125,
"privacy_hint": true,
"privacy_policy_audit": {
"url": "https://www.gfz.de/datenschutz",
"color": "yellow",
"found": [
"Verantwortlicher / Anbieter",
"Kontakt / Datenschutzkontakt",
"Zwecke der Verarbeitung",
"Rechtsgrundlagen",
"Betroffenenrechte",
"Speicherfrist / Löschung",
"Empfänger / Auftragsverarbeiter",
"Cookies / Tracking",
"Widerruf / Opt-out",
"Beschwerde bei Aufsichtsbehörde",
"Datenschutzkontakt / DPO-Hinweis",
"Verständliche Satzlänge"
],
"score": 86,
"checks": [
{
"id": "controller_identity",
"found": true,
"label": "Verantwortlicher / Anbieter"
},
{
"id": "contact",
"found": true,
"label": "Kontakt / Datenschutzkontakt"
},
{
"id": "purposes",
"found": true,
"label": "Zwecke der Verarbeitung"
},
{
"id": "legal_basis",
"found": true,
"label": "Rechtsgrundlagen"
},
{
"id": "rights",
"found": true,
"label": "Betroffenenrechte"
},
{
"id": "retention",
"found": true,
"label": "Speicherfrist / Löschung"
},
{
"id": "recipients",
"found": true,
"label": "Empfänger / Auftragsverarbeiter"
},
{
"id": "cookies_tracking",
"found": true,
"label": "Cookies / Tracking"
},
{
"id": "withdrawal",
"found": true,
"label": "Widerruf / Opt-out"
},
{
"id": "complaint_authority",
"found": true,
"label": "Beschwerde bei Aufsichtsbehörde"
},
{
"id": "third_country_transfer",
"found": false,
"label": "Drittlandtransfer"
},
{
"id": "update_date",
"found": false,
"label": "Stand / Aktualitätsdatum",
"detail": ""
},
{
"id": "dpo_contact",
"found": true,
"label": "Datenschutzkontakt / DPO-Hinweis"
},
{
"id": "readability",
"found": true,
"label": "Verständliche Satzlänge",
"detail": "13.9 Wörter/Satz"
}
],
"status": "prüfen",
"missing": [
"Drittlandtransfer",
"Stand / Aktualitätsdatum"
],
"summary": "12 von 14 zentralen Datenschutz-Bausteinen erkannt.",
"findings": [
{
"id": "privacy_policy_update_date_missing",
"title": "Stand der Datenschutzerklärung nicht klar erkennbar",
"public": true,
"category": "privacy",
"severity": "info"
}
],
"available": true,
"freshness": {
"stale": false,
"age_days": null,
"last_updated": "",
"update_date_found": false
},
"word_count": 3272,
"readability": {
"hard_to_read": false,
"sentence_count": 236,
"avg_sentence_words": 13.9
},
"missing_count": 2,
"dpo_contact_found": true
}
},
{
"ok": true,
"url": "https://www.gfz.de/impressum",
"path": "/impressum",
"audit": {
"form_count": 0,
"finding_ids": [
"cookie_missing_secure",
"cookie_missing_samesite",
"privacy_policy_too_thin"
],
"cookie_count": 1,
"imprint_found": true,
"consent_hint_found": false,
"reject_option_found": false,
"privacy_policy_found": true,
"tracking_script_count": 0,
"pre_consent_cookie_count": 1,
"pre_consent_tracking_cookie_count": 0
},
"forms": 0,
"title": "Impressum: GFZ",
"status": 200,
"category": "impressum",
"duration_ms": 118,
"privacy_hint": true,
"privacy_policy_audit": []
},
{
"ok": true,
"url": "https://www.gfz.de/kontakt",
"path": "/kontakt",
"audit": {
"form_count": 0,
"finding_ids": [
"cookie_missing_secure",
"cookie_missing_samesite",
"privacy_policy_too_thin"
],
"cookie_count": 1,
"imprint_found": true,
"consent_hint_found": false,
"reject_option_found": false,
"privacy_policy_found": true,
"tracking_script_count": 0,
"pre_consent_cookie_count": 1,
"pre_consent_tracking_cookie_count": 0
},
"forms": 0,
"title": "Kontakt: GFZ",
"status": 200,
"category": "kontakt",
"duration_ms": 103,
"privacy_hint": true,
"privacy_policy_audit": []
},
{
"ok": true,
"url": "https://www.gfz.de/presse/gfz-schuelerlabor",
"path": "/presse/gfz-schuelerlabor",
"audit": {
"form_count": 0,
"finding_ids": [
"cookie_missing_secure",
"cookie_missing_samesite",
"operator_identity_unclear",
"privacy_policy_too_thin"
],
"cookie_count": 1,
"imprint_found": true,
"consent_hint_found": false,
"reject_option_found": false,
"privacy_policy_found": true,
"tracking_script_count": 0,
"pre_consent_cookie_count": 1,
"pre_consent_tracking_cookie_count": 0
},
"forms": 0,
"title": "GFZ-Schülerlabor - das GFZ als außerschulischer Lernort: GFZ",
"status": 200,
"category": "newsletter",
"duration_ms": 121,
"privacy_hint": true,
"privacy_policy_audit": []
}
],
"robots_checked": true,
"sitemap_sources": [
"https://www.gfz.de/sitemap.xml"
],
"sitemap_available": true,
"sitemap_url_count": 0,
"homepage_link_count": 144,
"internal_link_count": 30,
"privacy_policy_audit": {
"url": "https://www.gfz.de/datenschutz",
"color": "yellow",
"found": [
"Verantwortlicher / Anbieter",
"Kontakt / Datenschutzkontakt",
"Zwecke der Verarbeitung",
"Rechtsgrundlagen",
"Betroffenenrechte",
"Speicherfrist / Löschung",
"Empfänger / Auftragsverarbeiter",
"Cookies / Tracking",
"Widerruf / Opt-out",
"Beschwerde bei Aufsichtsbehörde",
"Datenschutzkontakt / DPO-Hinweis",
"Verständliche Satzlänge"
],
"score": 86,
"checks": [
{
"id": "controller_identity",
"found": true,
"label": "Verantwortlicher / Anbieter"
},
{
"id": "contact",
"found": true,
"label": "Kontakt / Datenschutzkontakt"
},
{
"id": "purposes",
"found": true,
"label": "Zwecke der Verarbeitung"
},
{
"id": "legal_basis",
"found": true,
"label": "Rechtsgrundlagen"
},
{
"id": "rights",
"found": true,
"label": "Betroffenenrechte"
},
{
"id": "retention",
"found": true,
"label": "Speicherfrist / Löschung"
},
{
"id": "recipients",
"found": true,
"label": "Empfänger / Auftragsverarbeiter"
},
{
"id": "cookies_tracking",
"found": true,
"label": "Cookies / Tracking"
},
{
"id": "withdrawal",
"found": true,
"label": "Widerruf / Opt-out"
},
{
"id": "complaint_authority",
"found": true,
"label": "Beschwerde bei Aufsichtsbehörde"
},
{
"id": "third_country_transfer",
"found": false,
"label": "Drittlandtransfer"
},
{
"id": "update_date",
"found": false,
"label": "Stand / Aktualitätsdatum",
"detail": ""
},
{
"id": "dpo_contact",
"found": true,
"label": "Datenschutzkontakt / DPO-Hinweis"
},
{
"id": "readability",
"found": true,
"label": "Verständliche Satzlänge",
"detail": "13.9 Wörter/Satz"
}
],
"status": "prüfen",
"missing": [
"Drittlandtransfer",
"Stand / Aktualitätsdatum"
],
"summary": "12 von 14 zentralen Datenschutz-Bausteinen erkannt.",
"findings": [
{
"id": "privacy_policy_update_date_missing",
"title": "Stand der Datenschutzerklärung nicht klar erkennbar",
"public": true,
"category": "privacy",
"severity": "info"
}
],
"available": true,
"freshness": {
"stale": false,
"age_days": null,
"last_updated": "",
"update_date_found": false
},
"word_count": 3272,
"readability": {
"hard_to_read": false,
"sentence_count": 236,
"avg_sentence_words": 13.9
},
"missing_count": 2,
"dpo_contact_found": true
},
"sitemap_source_count": 1,
"provider_disclosure_audit": {
"found": [],
"checks": [],
"reason": "no_detected_services",
"missing": [],
"available": false
},
"important_categories_found": [
"datenschutz",
"impressum",
"kontakt"
],
"sampled_tracking_page_count": 0,
"sampled_form_privacy_gap_count": 0,
"sitemap_candidate_source_count": 1
},
"page_analysis": {
"h1": [
"Startseite"
],
"h2": [
"Am Puls der Erde,",
"Aktuelles",
"Forschung",
"Informationen & Services",
"Lernen & Lehrmaterialien"
],
"title": "Startseite: GFZ",
"keywords": [
[
"erde",
9
],
[
"forschung",
5
],
[
"infrastruktur",
4
],
[
"innovation",
4
],
[
"erfahren",
4
],
[
"fokus",
4
],
[
"startseite",
3
],
[
"helmholtz-zentrum",
3
],
[
"geoforschung",
3
],
[
"erforschung",
3
]
],
"language": "de",
"description": "Das GFZ Helmholtz-Zentrum für Geoforschung ist das nationale Zentrum für die Erforschung der festen Erde. Wir untersuchen die Geosphäre im hochkomplexen System Erde mit den weiteren Teilsystemen und ihren ineinandergreifenden Kreisläufen und weitverzweigten Ursache-Wirkungs-Ketten.",
"favicon_url": "https://www.gfz.de/_assets/e65b0b3eb46043468cd13f8d0b6e97da/Images/v1.4.2/logos/gfz/favicon_simple_blue_darkmode_white.svg",
"link_counts": {
"external": 19,
"internal": 125
},
"preview_image": "/cache/screenshots/gfz.de-160x150-b263ec32cec12e3d94.png",
"screenshot_url": "/cache/screenshots/gfz.de-160x150-b263ec32cec12e3d94.png",
"external_scripts": [],
"browser_final_url": "https://www.gfz.de/",
"meta_preview_image": "",
"screenshot_renderer": "playwright-chromium",
"external_link_targets": [
{
"host": "research-infrastructure.gfz.de",
"count": 6,
"examples": [
{
"href": "https://research-infrastructure.gfz.de/de/infrastrukturen?filter_options=47",
"text": "Satellitensysteme"
},
{
"href": "https://research-infrastructure.gfz.de/de/infrastrukturen?filter_options=56",
"text": "Globale Messnetze"
},
{
"href": "https://research-infrastructure.gfz.de/de/infrastrukturen?filter_options=57",
"text": "Regionale Observatorien"
}
],
"nofollow": 0,
"strength": "strong",
"follow_count": 6
},
{
"host": "rifs-potsdam.de",
"count": 2,
"examples": [
{
"href": "https://www.rifs-potsdam.de/de/news/energiegemeinschaften-staerken-die-energiewende-wenn-die-rahmenbedingungen-stimmen",
"text": ""
},
{
"href": "https://www.rifs-potsdam.de/de/news/energiegemeinschaften-staerken-die-energiewende-wenn-die-rahmenbedingungen-stimmen",
"text": "Energiegemeinschaften stärken die Energiewende – wenn die Rahmenbedingungen stimmen"
}
],
"nofollow": 0,
"strength": "strong",
"follow_count": 2
},
{
"host": "api.whatsapp.com",
"count": 1,
"examples": [
{
"href": "https://api.whatsapp.com/send?text=https://www.gfz.de/",
"text": "Whatsapp"
}
],
"nofollow": 0,
"strength": "strong",
"follow_count": 1
},
{
"host": "bsky.app",
"count": 1,
"examples": [
{
"href": "https://bsky.app/profile/gfz.bsky.social",
"text": "Das GFZ auf Bluesky"
}
],
"nofollow": 0,
"strength": "strong",
"follow_count": 1
},
{
"host": "de.linkedin.com",
"count": 1,
"examples": [
{
"href": "https://de.linkedin.com/company/gfz-helmholtz-zentrum-fuer-geoforschung",
"text": "Das GFZ auf LinkedIn"
}
],
"nofollow": 0,
"strength": "strong",
"follow_count": 1
},
{
"host": "facebook.com",
"count": 1,
"examples": [
{
"href": "https://www.facebook.com/sharer/sharer.php?u=https://www.gfz.de/",
"text": "Facebook"
}
],
"nofollow": 0,
"strength": "strong",
"follow_count": 1
},
{
"host": "gfz-friends.de",
"count": 1,
"examples": [
{
"href": "https://www.gfz-friends.de/",
"text": "GFZ Förderverein"
}
],
"nofollow": 0,
"strength": "strong",
"follow_count": 1
},
{
"host": "globalwaterstorage.info",
"count": 1,
"examples": [
{
"href": "https://www.globalwaterstorage.info/datenmonitor-grace-globus",
"text": "Globale Wasserspeicher"
}
],
"nofollow": 0,
"strength": "strong",
"follow_count": 1
},
{
"host": "instagram.com",
"count": 1,
"examples": [
{
"href": "https://www.instagram.com/gfz_potsdam/",
"text": "Das GFZ auf Instragram"
}
],
"nofollow": 0,
"strength": "strong",
"follow_count": 1
},
{
"host": "linkedin.com",
"count": 1,
"examples": [
{
"href": "https://www.linkedin.com/shareArticle?mini=true&url=https://www.gfz.de/",
"text": "LinkedIn"
}
],
"nofollow": 0,
"strength": "strong",
"follow_count": 1
},
{
"host": "spaceweather.gfz.de",
"count": 1,
"examples": [
{
"href": "https://spaceweather.gfz.de/de/",
"text": "Weltraumwetter"
}
],
"nofollow": 0,
"strength": "strong",
"follow_count": 1
},
{
"host": "telegram.me",
"count": 1,
"examples": [
{
"href": "https://telegram.me/share/url?url=https://www.gfz.de/",
"text": "Telegram"
}
],
"nofollow": 0,
"strength": "strong",
"follow_count": 1
},
{
"host": "youtube.com",
"count": 1,
"examples": [
{
"href": "https://www.youtube.com/user/GFZvideos",
"text": "Das GFZ auf YouTube"
}
],
"nofollow": 0,
"strength": "strong",
"follow_count": 1
}
]
},
"browser_analysis": {
"cookies": {
"items": [
{
"name": "PHPSESSID",
"domain": "www.gfz.de",
"secure": false,
"expires": -1,
"http_only": false,
"same_site": "Lax"
}
],
"total": 1,
"third_party": 0
},
"storage": {
"total": 0,
"local_storage_keys": [],
"tracking_key_hints": [],
"local_storage_total": 0,
"session_storage_keys": [],
"session_storage_total": 0
},
"findings": [
{
"id": "browser_consent_accept_only",
"title": "Consent-Banner wirkt im Browser wie Akzeptieren-only",
"public": true,
"category": "privacy",
"severity": "warning"
},
{
"id": "browser_consent_settings_missing",
"title": "Keine sichtbaren Cookie-Einstellungen im Banner",
"public": true,
"category": "privacy",
"severity": "info"
},
{
"id": "tracking_pixel_detected",
"count": 1,
"title": "Tracking-Pixel oder pixelnahe Requests erkannt",
"public": true,
"category": "privacy",
"severity": "info"
}
],
"renderer": "playwright-chromium",
"final_url": "https://www.gfz.de/",
"consent_ui": {
"accept_controls": [
{
"tag": "button",
"top": 870,
"area": 7511,
"left": 229,
"text": "NICHT ZUSTIMMEN",
"color": "rgb(51, 83, 131)",
"width": 186,
"height": 40,
"background": "rgba(0, 0, 0, 0)",
"font_weight": "400"
},
{
"tag": "button",
"top": 870,
"area": 5568,
"left": 657,
"text": "ZUSTIMMEN",
"color": "rgb(255, 255, 255)",
"width": 138,
"height": 40,
"background": "rgb(40, 167, 69)",
"font_weight": "400"
}
],
"accept_max_area": 7511,
"reject_controls": [],
"reject_max_area": 0,
"settings_controls": [],
"first_layer_summary": "Akzeptieren 2 / Ablehnen 0 / Einstellungen 0",
"cookie_context_found": true,
"reject_less_prominent": false,
"visible_control_count": 27,
"reject_prominence_ratio": 0
},
"gpc_signal": {
"error": "",
"enabled": true,
"storage": {
"total": 0,
"tracking_key_hints": [],
"local_storage_total": 0,
"session_storage_total": 0
},
"cookie_count": 1,
"request_count": 50,
"sec_gpc_header": true,
"navigator_value": true,
"contacted_domains": [
{
"host": "gfz.de",
"count": 50,
"category": "other",
"provider": "gfz.de",
"third_party": false,
"category_label": "Sonstige",
"resource_types": {
"font": 8,
"image": 37,
"script": 1,
"document": 1,
"stylesheet": 3
}
}
],
"contacted_domain_count": 1,
"privacy_relevant_domains": [],
"third_party_cookie_count": 0,
"third_party_domain_count": 0,
"privacy_relevant_domain_count": 0
},
"screenshot": {
"fit": "contain",
"width": 160,
"height": 150,
"source_width": 1024,
"source_height": 960,
"source_capture": "full_page",
"capture_version": "contain-v4-viewport-transparency-160x150"
},
"consent_apis": {
"cmpapi": false,
"tcfapi": false,
"onetrust": false,
"cookiebot": false,
"data_layer": false,
"cmp_detected": false,
"usercentrics": false,
"google_tag_data": false
},
"accept_signal": {
"error": "",
"enabled": true,
"storage": {
"total": 0,
"tracking_key_hints": [],
"local_storage_total": 0,
"session_storage_total": 0
},
"clicked_text": "NICHT ZUSTIMMEN",
"accept_clicked": true,
"accept_available": true,
"contacted_domains": [
{
"host": "gfz.de",
"count": 50,
"category": "other",
"provider": "gfz.de",
"third_party": false,
"category_label": "Sonstige",
"resource_types": {
"font": 8,
"image": 37,
"script": 1,
"document": 1,
"stylesheet": 3
}
}
],
"contacted_domain_count": 1,
"new_domains_after_accept": [],
"privacy_relevant_domains": [],
"third_party_domain_count": 0,
"cookie_count_after_accept": 2,
"cookie_count_before_accept": 1,
"request_count_after_accept": 50,
"storage_count_after_accept": 0,
"request_count_before_accept": 50,
"new_cookie_count_after_accept": 1,
"privacy_relevant_domain_count": 0,
"new_request_count_after_accept": 0,
"third_party_cookie_count_after_accept": 0,
"storage_tracking_hint_count_after_accept": 0,
"new_privacy_relevant_domains_after_accept": [],
"new_privacy_relevant_domain_count_after_accept": 0
},
"request_count": 51,
"top_providers": [],
"request_samples": [],
"cmp_consent_state": {
"tcf": {
"api_found": false,
"vendor_li": [],
"cmp_loaded": false,
"cmp_status": "",
"purpose_li": [],
"event_status": "",
"gdpr_applies": null,
"ping_success": false,
"policy_version": "",
"vendor_consents": [],
"vendor_li_count": 0,
"purpose_consents": [],
"purpose_li_count": 0,
"tc_string_length": 0,
"tc_string_present": false,
"vendor_consent_count": 0,
"purpose_consent_count": 0
},
"onetrust": {
"found": false,
"active_groups": [],
"active_group_count": 0
},
"cookiebot": {
"found": false,
"declined": false,
"consented": false,
"has_response": false,
"consent_marketing": null,
"consent_statistics": null,
"consent_preferences": null
},
"usercentrics": {
"found": false,
"has_response": false,
"services_count": 0,
"accepted_services_count": 0
}
},
"contacted_domains": [
{
"host": "gfz.de",
"count": 51,
"category": "other",
"provider": "gfz.de",
"third_party": false,
"category_label": "Sonstige",
"resource_types": {
"font": 8,
"image": 38,
"script": 1,
"document": 1,
"stylesheet": 3
}
}
],
"privacy_api_metrics": {
"api_calls": {
"keyboard_input_listener_count": 4
},
"beacon_count": 0,
"webgl_read_count": 0,
"canvas_read_count": 0,
"audio_context_count": 0,
"canvas_export_count": 0,
"fetch_keepalive_count": 0,
"webgl_parameter_count": 0,
"mutation_observer_count": 0,
"keyboard_input_listener_count": 4
},
"tcf_consent_analysis": {
"color": "green",
"score": 100,
"status": "unauffällig",
"summary": "TCF-Decoder: 0 Zweck(e) mit Consent/LI-Signal, 0 Vendor-Consent(s), 0 Vendor-LI-Signal(e).",
"findings": [],
"api_found": false,
"available": false,
"cmp_loaded": false,
"cmp_status": "",
"event_status": "",
"gdpr_applies": null,
"ping_success": false,
"purpose_rows": [
{
"id": 1,
"label": "Informationen auf einem Gerät speichern und/oder abrufen",
"status": "nicht_erlaubt",
"risk_level": "niedrig",
"consent_granted": false,
"legitimate_interest_granted": false
},
{
"id": 2,
"label": "Einfache Anzeigen auswählen",
"status": "nicht_erlaubt",
"risk_level": "niedrig",
"consent_granted": false,
"legitimate_interest_granted": false
},
{
"id": 3,
"label": "Personalisiertes Anzeigen-Profil erstellen",
"status": "nicht_erlaubt",
"risk_level": "niedrig",
"consent_granted": false,
"legitimate_interest_granted": false
},
{
"id": 4,
"label": "Personalisierte Anzeigen auswählen",
"status": "nicht_erlaubt",
"risk_level": "niedrig",
"consent_granted": false,
"legitimate_interest_granted": false
},
{
"id": 5,
"label": "Personalisiertes Inhalts-Profil erstellen",
"status": "nicht_erlaubt",
"risk_level": "niedrig",
"consent_granted": false,
"legitimate_interest_granted": false
},
{
"id": 6,
"label": "Personalisierte Inhalte auswählen",
"status": "nicht_erlaubt",
"risk_level": "niedrig",
"consent_granted": false,
"legitimate_interest_granted": false
},
{
"id": 7,
"label": "Anzeigen-Leistung messen",
"status": "nicht_erlaubt",
"risk_level": "niedrig",
"consent_granted": false,
"legitimate_interest_granted": false
},
{
"id": 8,
"label": "Inhalte-Leistung messen",
"status": "nicht_erlaubt",
"risk_level": "niedrig",
"consent_granted": false,
"legitimate_interest_granted": false
},
{
"id": 9,
"label": "Marktforschung zur Generierung von Erkenntnissen nutzen",
"status": "nicht_erlaubt",
"risk_level": "niedrig",
"consent_granted": false,
"legitimate_interest_granted": false
},
{
"id": 10,
"label": "Produkte entwickeln und verbessern",
"status": "nicht_erlaubt",
"risk_level": "niedrig",
"consent_granted": false,
"legitimate_interest_granted": false
},
{
"id": 11,
"label": "Begrenzte Daten zur Anzeigen-Auswahl verwenden",
"status": "nicht_erlaubt",
"risk_level": "niedrig",
"consent_granted": false,
"legitimate_interest_granted": false
}
],
"vendor_li_ids": [],
"policy_version": "",
"vendor_li_count": 0,
"purpose_li_count": 0,
"tc_string_length": 0,
"tc_string_present": false,
"vendor_consent_ids": [],
"granted_purpose_rows": [],
"vendor_consent_count": 0,
"purpose_consent_count": 0,
"high_risk_purpose_count": 0,
"medium_risk_purpose_count": 0
},
"viewport_transparency": {
"samples": [
{
"tag": "a",
"top": 8,
"href": "/kontakt",
"left": 767,
"text": "Kontakt",
"width": 86,
"height": 26,
"category": "contact"
},
{
"tag": "div",
"top": 556,
"href": "",
"left": 212,
"text": "Einstellungen zum Datenschutz Wir verwenden Cookies, die für die grundlegende Funktionalit",
"width": 600,
"height": 372,
"category": "privacy_notice"
},
{
"tag": "a",
"top": 798,
"href": "/datenschutz",
"left": 296,
"text": "Datenschutzerklärung",
"width": 186,
"height": 20,
"category": "privacy_notice"
}
],
"available": true,
"sample_count": 3,
"claim_boundary": "Sichtbarkeits-Evidence aus dem ersten Headless-Chromium-Viewport; keine Aussage ueber Footer nach Scrollen, Loginbereiche oder rechtliche Vollstaendigkeit.",
"viewport_width": 1024,
"category_counts": {
"contact": 1,
"privacy_notice": 2
},
"contact_visible": true,
"imprint_visible": false,
"viewport_height": 960,
"cookie_consent_visible": false,
"privacy_notice_visible": true
},
"consent_journey_matrix": {
"color": "green",
"items": [],
"score": 100,
"states": [
{
"id": "default",
"label": "Erstaufruf",
"description": "Kontakte ohne Nutzeraktion",
"domain_count": 0,
"request_count": 0,
"privacy_relevant_domain_count": 0
},
{
"id": "reject_new",
"label": "Nach Ablehnen neu",
"description": "Neue Kontakte nach Ablehnen-Klick",
"domain_count": 0,
"request_count": 0,
"privacy_relevant_domain_count": 0
},
{
"id": "accept_new",
"label": "Nach Akzeptieren neu",
"description": "Neue Kontakte nach Akzeptieren-Klick",
"domain_count": 0,
"request_count": 0,
"privacy_relevant_domain_count": 0
},
{
"id": "gpc",
"label": "GPC-Aufruf",
"description": "Kontakte bei Global Privacy Control",
"domain_count": 0,
"request_count": 0,
"privacy_relevant_domain_count": 0
}
],
"status": "unauffällig",
"summary": "Consent-Journey: 0 neue Datenschutz-Domain(s) nach Ablehnen, 0 nach Akzeptieren, 0 im GPC-Aufruf.",
"gpc_privacy_relevant_domain_count": 0,
"accept_privacy_relevant_domain_count": 0,
"reject_privacy_relevant_domain_count": 0
},
"consent_state_evidence": {
"rows": [
{
"id": "default",
"label": "Erstaufruf",
"status": "ohne Nutzeraktion",
"evidence": "Baseline aus erstem Chromium-Aufruf ohne Banner-Interaktion.",
"risk_level": "niedrig",
"cookie_count": 1,
"domain_count": 1,
"request_count": 51,
"storage_total": 0,
"new_cookie_count": 1,
"third_party_cookie_count": 0,
"storage_tracking_hint_count": 0,
"privacy_relevant_domain_count": 0
},
{
"id": "reject",
"label": "Nach Ablehnen",
"status": "nicht verfügbar",
"evidence": "",
"risk_level": "niedrig",
"cookie_count": 1,
"domain_count": 0,
"request_count": 0,
"storage_total": 0,
"new_cookie_count": 0,
"third_party_cookie_count": 0,
"storage_tracking_hint_count": 0,
"privacy_relevant_domain_count": 0
},
{
"id": "accept",
"label": "Nach Akzeptieren",
"status": "geklickt",
"evidence": "NICHT ZUSTIMMEN",
"risk_level": "info",
"cookie_count": 2,
"domain_count": 1,
"request_count": 50,
"storage_total": 0,
"new_cookie_count": 1,
"third_party_cookie_count": 0,
"storage_tracking_hint_count": 0,
"privacy_relevant_domain_count": 0
},
{
"id": "gpc",
"label": "GPC-Aufruf",
"status": "aktiv",
"evidence": "Navigator-GPC und Sec-GPC wurden im gesonderten Browserlauf gesetzt.",
"risk_level": "niedrig",
"cookie_count": 1,
"domain_count": 1,
"request_count": 50,
"storage_total": 0,
"new_cookie_count": 0,
"third_party_cookie_count": 0,
"storage_tracking_hint_count": 0,
"privacy_relevant_domain_count": 0
}
],
"color": "green",
"score": 100,
"status": "unauffällig",
"summary": "Consent-State-Evidence: 4 Zustände verglichen, 0 hoch auffällig, 0 mittel auffällig.",
"findings": [],
"available": true,
"high_count": 0,
"medium_count": 0
},
"contacted_domain_count": 1,
"fingerprinting_analysis": {
"color": "green",
"score": 100,
"checks": [
{
"id": "canvas",
"ok": true,
"count": 0,
"label": "Canvas-Auslese",
"detail": "0 Pixel-Lesezugriff(e), 0 Export(e)."
},
{
"id": "webgl",
"ok": true,
"count": 0,
"label": "WebGL-Merkmale",
"detail": "0 Parameterzugriff(e), 0 Pixel-Lesezugriff(e)."
},
{
"id": "audio",
"ok": true,
"count": 0,
"label": "AudioContext",
"detail": "0 AudioContext/OfflineAudioContext-Aufruf(e)."
},
{
"id": "session_replay",
"ok": true,
"count": 0,
"label": "Session-Replay-Anbieter",
"detail": "Keine bekannten Anbieter erkannt."
},
{
"id": "input_listeners",
"ok": true,
"count": 4,
"label": "Tastatur-/Eingabe-Listener",
"detail": "4 Tastatur-/Input-Listener, 25 Interaktions-Listener, 0 MutationObserver."
}
],
"status": "unauffällig",
"metrics": {
"webgl_read_count": 0,
"canvas_read_count": 0,
"audio_context_count": 0,
"canvas_export_count": 0,
"webgl_parameter_count": 0,
"mutation_observer_count": 0,
"keyboard_input_listener_count": 4
},
"summary": "0 Fingerprinting-/Session-Replay-Hinweis(e) aus dem Browserlauf.",
"findings": [],
"finding_count": 0,
"session_replay_domains": []
},
"privacy_relevant_domains": [],
"provider_category_counts": [],
"provider_category_labels": [],
"third_party_domain_count": 0,
"embedded_content_analysis": {
"color": "green",
"items": [],
"score": 100,
"status": "unauffällig",
"summary": "0 externe Embed-/Widget-Dienst(e), 0 davon im ersten Browseraufruf geladen.",
"findings": [],
"map_count": 0,
"total_count": 0,
"video_count": 0,
"captcha_count": 0,
"category_counts": [],
"social_widget_count": 0,
"loaded_pre_consent_count": 0,
"request_count_by_provider": []
},
"referrer_leakage_analysis": {
"color": "green",
"items": [],
"score": 100,
"status": "unauffällig",
"summary": "0 Drittanbieter-Domain(s) mit Referrer-/URL-Leak-Prüfbedarf, 0 sensible Query-Kontexte.",
"findings": [],
"sample_count": 0,
"full_referrer_count": 0,
"page_url_param_count": 0,
"affected_domain_count": 0,
"sensitive_query_count": 0
},
"third_party_contact_matrix": {
"color": "green",
"items": [],
"score": 100,
"status": "unauffällig",
"summary": "0 Drittanbieter-Domain(s) beim ersten Browseraufruf, davon 0 datenschutzrelevant.",
"category_counts": [],
"total_domain_count": 0,
"total_request_count": 0,
"privacy_relevant_count": 0,
"transfer_risk_analysis": {
"color": "green",
"items": [],
"score": 100,
"status": "unauffällig",
"summary": "0 Drittanbieter für Transfer-/Jurisdiktionsprüfung, 0 mit hohem Prüfbedarf, 0 unklar.",
"findings": [],
"unknown_count": 0,
"high_risk_count": 0,
"total_vendor_count": 0,
"third_country_count": 0
}
},
"privacy_relevant_domain_count": 0,
"tracking_pixel_beacon_analysis": {
"color": "green",
"items": [
{
"url": "https://webstats.gfz.de/matomo.php?idsite=1&rec=1",
"host": "webstats.gfz.de",
"kind": "tracking_pixel",
"reason": "Tracking-nahe URL",
"source": "html_img",
"category": "other",
"provider": "webstats.gfz.de",
"third_party": true,
"resource_type": "image",
"category_label": "Sonstige"
}
],
"score": 90,
"status": "unauffällig",
"summary": "1 Pixel-/Bildtracking-Hinweis(e), 0 Beacon-/Telemetry-Hinweis(e), 0 Link-Ping(s).",
"findings": [
{
"id": "tracking_pixel_detected",
"count": 1,
"title": "Tracking-Pixel oder pixelnahe Requests erkannt",
"public": true,
"category": "privacy",
"severity": "info"
}
],
"pixel_count": 1,
"link_ping_count": 0,
"telemetry_count": 0,
"beacon_api_count": 0,
"third_party_count": 1,
"fetch_keepalive_count": 0,
"privacy_relevant_count": 0,
"beacon_code_reference_count": 0,
"fetch_keepalive_reference_count": 0
}
},
"privacy_analysis": {
"cookies": {
"items": [
{
"name": "PHPSESSID",
"secure": false,
"samesite": false,
"tracking": false,
"pre_consent": true,
"likely_essential": true
}
],
"total": 1,
"tracking": [],
"pre_consent": [
"PHPSESSID"
],
"missing_secure": [
"PHPSESSID"
],
"missing_samesite": [
"PHPSESSID"
],
"pre_consent_tracking": [],
"pre_consent_nonessential": []
},
"findings": [
{
"id": "cookie_missing_secure",
"title": "Cookie ohne Secure-Flag",
"public": true,
"cookies": [
"PHPSESSID"
],
"category": "privacy",
"severity": "warning"
},
{
"id": "cookie_missing_samesite",
"title": "Cookie ohne SameSite-Attribut",
"public": true,
"cookies": [
"PHPSESSID"
],
"category": "privacy",
"severity": "info"
}
],
"tracking_ids": [],
"tracking_scripts": [],
"consent_hint_found": false,
"privacy_policy_hint_found": true
},
"consent_audit": {
"color": "yellow",
"score": 78,
"checks": [
{
"id": "banner_visible",
"ok": true,
"label": "Cookie-/Consent-Hinweis sichtbar",
"detail": "Ein Hinweis mit Cookie-/Einwilligungsbezug wurde im sichtbaren Text erkannt."
},
{
"id": "reject_visible",
"ok": true,
"label": "Ablehnen gleichwertig erreichbar",
"detail": "Ablehnen oder nur notwendige Cookies wurde im Text oder Browser erkannt. Browser-Buttons: 0."
},
{
"id": "settings_visible",
"ok": true,
"label": "Einstellungen oder Auswahl vorhanden",
"detail": "Eine Einstellungs- oder Auswahlmoeglichkeit wurde im Text oder Browser erkannt. Browser-Buttons: 0."
},
{
"id": "browser_reject_visible",
"ok": false,
"label": "Ablehnen im sichtbaren Banner",
"detail": "Sichtbare Banner-Controls: Akzeptieren 2, Ablehnen 0, Einstellungen 0."
},
{
"id": "browser_settings_visible",
"ok": false,
"label": "Einstellungen im sichtbaren Banner",
"detail": "Sichtbare Banner-Controls: Akzeptieren 2, Ablehnen 0, Einstellungen 0."
},
{
"id": "reject_equally_prominent",
"ok": true,
"label": "Ablehnen nicht deutlich schwaecher dargestellt",
"detail": "Groessen-Verhältnis Ablehnen/Akzeptieren: nicht messbar."
},
{
"id": "reject_button_clickable",
"ok": true,
"label": "Ablehnen technisch klickbar",
"detail": "Wenn ein Ablehnen-Button sichtbar ist, klickt SaferPage ihn im Chromium-Browser einmal an."
},
{
"id": "no_new_cookies_after_reject",
"ok": true,
"label": "Keine neuen Cookies nach Ablehnen",
"detail": "0 neue Cookie(s) nach dem Ablehnen-Klick."
},
{
"id": "no_tracking_storage_after_reject",
"ok": true,
"label": "Kein Tracking-Storage nach Ablehnen",
"detail": "0 Tracking-Hinweis(e) im Web Storage nach Ablehnen."
},
{
"id": "no_privacy_domains_after_reject",
"ok": true,
"label": "Keine neuen Tracking-Kontakte nach Ablehnen",
"detail": "0 neue datenschutzrelevante Domain(s) nach Ablehnen."
},
{
"id": "gpc_signal_respected",
"ok": true,
"label": "GPC-Signal ohne Tracking-Hinweise",
"detail": "GPC-Aufruf: 0 datenschutzrelevante Domain(s), 0 Drittanbieter-Cookie(s), 0 Storage-Hinweis(e)."
},
{
"id": "no_tracking_cookies_before_consent",
"ok": true,
"label": "Keine Tracking-Cookies vor Einwilligung",
"detail": "0 Tracking-Cookie(s) im Erstaufruf."
},
{
"id": "no_nonessential_cookies_before_consent",
"ok": true,
"label": "Keine nicht notwendigen Cookies vor Einwilligung",
"detail": "0 moeglicherweise nicht notwendige Cookie(s) im Erstaufruf."
},
{
"id": "third_parties_explained",
"ok": true,
"label": "Drittanbieter begrenzt und erklaerbar",
"detail": "0 datenschutzrelevante Drittanbieter-Domain(s), 0 Drittanbieter insgesamt."
},
{
"id": "storage_without_tracking_hints",
"ok": true,
"label": "Web Storage ohne Tracking-Hinweise",
"detail": "0 Storage-Key(s), 0 Tracking-Hinweis(e)."
},
{
"id": "cmp_api_detected_when_needed",
"ok": true,
"label": "CMP-/TCF-Signal bei Tracking erkennbar",
"detail": "Gängige CMP-/TCF-Indikatoren: __tcfapi, __cmp, Cookiebot, OneTrust oder Usercentrics."
},
{
"id": "accept_click_documented",
"ok": true,
"label": "Akzeptieren-Klick nachvollziehbar",
"detail": "Accept-Test: geklickt, neue Requests 0, neue Cookies 1, neue Datenschutz-Domains 0."
},
{
"id": "cmp_state_readable",
"ok": true,
"label": "CMP-/TCF-Zustand auslesbar",
"detail": "TCF TC-String: nein, Cookiebot: nein, OneTrust: nein, Usercentrics: nein."
},
{
"id": "cmp_default_restrictive",
"ok": true,
"label": "CMP-Default wirkt restriktiv",
"detail": "TCF Purposes erlaubt: 0, TCF Vendors erlaubt: 0, Cookiebot Statistik/Marketing: nein."
}
],
"status": "prüfen",
"summary": "Consent ist teilweise erkennbar; einzelne Punkte bleiben Betreiberkontext.",
"evidence": [
"1 Cookie(s) beim ersten Aufruf aus HTTP-Headern und Chromium",
"0 Tracking-Script(s) im HTML",
"0 datenschutzrelevante Drittanbieter-Domain(s)",
"0 Storage-Key(s), 0 Tracking-Hinweis(e)",
"Consent-Banner-Controls: Akzeptieren 2, Ablehnen 0, Einstellungen 0",
"Ablehnen/Akzeptieren-Prominenz: nicht messbar",
"Reject-Test: nicht ausgefuehrt, neue Cookies 0, Tracking-Storage 0, neue Datenschutz-Domains 0",
"Accept-Test: geklickt, neue Requests 0, neue Cookies 1, neue Datenschutz-Domains 0, Drittanbieter-Cookies 0",
"CMP-State: TCF-String nein, TCF Purposes 0, TCF Vendors 0, Cookiebot nein, OneTrust-Gruppen 0, Usercentrics-Services 0",
"GPC-Test: aktiv, Datenschutz-Domains 0, Drittanbieter-Cookies 0, Storage-Hinweise 0",
"CMP-/TCF-Signal: nein",
"Google Consent Default: nein"
],
"gpc_enabled": true,
"cmp_detected": false,
"blocking_plan": {
"items": [],
"summary": "Kein Google-Tag und keine Google-Domain erkannt; kein Google-spezifischer Pre-Consent-Blockierplan aus dieser Evidenz erforderlich.",
"available": false,
"high_count": 0,
"total_count": 0,
"type_counts": [],
"medium_count": 0
},
"tcf_api_found": false,
"cookiebot_found": false,
"accept_test_enabled": true,
"browser_cookie_count": 1,
"accept_button_clicked": true,
"browser_storage_count": 0,
"reject_button_clicked": false,
"reject_less_prominent": false,
"tcf_tc_string_present": false,
"tracking_script_count": 0,
"accept_button_available": true,
"reject_button_available": false,
"reject_prominence_ratio": 0,
"pre_consent_cookie_count": 1,
"pre_consent_cookie_names": [
"PHPSESSID"
],
"tcf_vendor_consent_count": 0,
"third_party_domain_count": 0,
"tcf_purpose_consent_count": 0,
"onetrust_active_group_count": 0,
"usercentrics_services_count": 0,
"browser_accept_control_count": 2,
"browser_cookie_context_found": true,
"browser_reject_control_count": 0,
"gpc_third_party_cookie_count": 0,
"post_accept_new_cookie_count": 1,
"post_reject_new_cookie_count": 0,
"post_accept_new_request_count": 0,
"browser_settings_control_count": 0,
"gpc_storage_tracking_hint_count": 0,
"cookiebot_marketing_or_statistics": false,
"gpc_privacy_relevant_domain_count": 0,
"pre_consent_tracking_cookie_count": 0,
"pre_consent_tracking_cookie_names": [],
"privacy_relevant_third_party_count": 0,
"browser_storage_tracking_hint_count": 0,
"post_accept_third_party_cookie_count": 0,
"pre_consent_nonessential_cookie_count": 0,
"pre_consent_nonessential_cookie_names": [],
"post_accept_storage_tracking_hint_count": 0,
"post_reject_storage_tracking_hint_count": 0,
"post_accept_privacy_relevant_domain_count": 0,
"post_reject_privacy_relevant_domain_count": 0
},
"cookie_inventory": {
"color": "green",
"items": [
{
"name": "PHPSESSID",
"domain": "gfz.de",
"secure": false,
"sources": [
"http_set_cookie",
"browser_first_load"
],
"category": "necessary",
"provider": "gfz.de",
"tracking": false,
"http_only": false,
"same_site": "Lax",
"expires_at": "",
"long_lived": false,
"persistent": false,
"first_party": true,
"origin_host": "gfz.de",
"pre_consent": true,
"source_label": "HTTP Set-Cookie, Chromium-Erstaufruf",
"category_label": "Notwendig",
"retention_risk": "niedrig",
"expires_in_days": null,
"origin_evidence": "51 Browser-Request(s) · document:1, font:8, image:38, script:1",
"origin_provider": "gfz.de",
"retention_class": "session",
"retention_label": "Session",
"likely_essential": true,
"origin_script_url": "",
"origin_resource_type": ""
}
],
"score": 95,
"total": 1,
"status": "unauffällig",
"summary": "1 Cookie(s) inventarisiert: 0 Tracking-/Werbe-Cookie(s), 0 Drittanbieter-Cookie(s), 0 langlebige Cookie(s), 0 sehr lange Laufzeit(en).",
"findings": [],
"categories": {
"necessary": 1
},
"tracking_count": 0,
"category_labels": {
"consent": "Consent",
"payment": "Zahlung",
"unknown": "Unklar",
"security": "Sicherheit",
"analytics": "Analytics",
"necessary": "Notwendig",
"functional": "Funktional",
"advertising": "Werbung"
},
"long_lived_count": 0,
"persistent_count": 0,
"first_party_count": 1,
"pre_consent_count": 1,
"retention_classes": {
"session": 1
},
"third_party_count": 0,
"missing_secure_count": 1,
"retention_risk_count": 0,
"retention_risk_items": [],
"very_long_lived_count": 0,
"missing_samesite_count": 0,
"persistent_unknown_count": 0,
"long_lived_tracking_count": 0
},
"security_header_analysis": {
"color": "red",
"score": 46,
"checks": [
{
"ok": false,
"note": "Fehlt in der HTTP-Antwort.",
"label": "HSTS",
"value": "",
"header": "strict-transport-security",
"present": false,
"purpose": "Erzwingt HTTPS nach dem ersten sicheren Aufruf.",
"severity": "warning"
},
{
"ok": false,
"note": "Fehlt in der HTTP-Antwort.",
"label": "Content-Security-Policy",
"value": "",
"header": "content-security-policy",
"present": false,
"purpose": "Begrenzt Skript-, Frame- und Ressourcenquellen im Browser.",
"severity": "warning"
},
{
"ok": false,
"note": "Fehlt in der HTTP-Antwort.",
"label": "X-Frame-Options",
"value": "",
"header": "x-frame-options",
"present": false,
"purpose": "Reduziert Clickjacking-Risiken bei älteren Browsern.",
"severity": "warning"
},
{
"ok": true,
"note": "",
"label": "X-Content-Type-Options",
"value": "nosniff",
"header": "x-content-type-options",
"present": true,
"purpose": "Verhindert MIME-Sniffing bei Skripten und Stylesheets.",
"severity": "warning"
},
{
"ok": false,
"note": "Fehlt in der HTTP-Antwort.",
"label": "Referrer-Policy",
"value": "",
"header": "referrer-policy",
"present": false,
"purpose": "Begrenzt, welche URL-Informationen an Zielseiten weitergegeben werden.",
"severity": "info"
},
{
"ok": false,
"note": "Fehlt in der HTTP-Antwort.",
"label": "Permissions-Policy",
"value": "",
"header": "permissions-policy",
"present": false,
"purpose": "Begrenzt sensible Browser-Funktionen pro Seite.",
"severity": "info"
},
{
"ok": false,
"note": "Fehlt in der HTTP-Antwort.",
"label": "Cross-Origin-Opener-Policy",
"value": "",
"header": "cross-origin-opener-policy",
"present": false,
"purpose": "Isoliert Top-Level-Fenster und reduziert Cross-Origin-Seiteneffekte.",
"severity": "info"
},
{
"ok": false,
"note": "Fehlt in der HTTP-Antwort.",
"label": "Cross-Origin-Resource-Policy",
"value": "",
"header": "cross-origin-resource-policy",
"present": false,
"purpose": "Begrenzt, welche fremden Seiten Ressourcen einbetten dürfen.",
"severity": "info"
},
{
"ok": false,
"note": "Fehlt in der HTTP-Antwort.",
"label": "Cross-Origin-Embedder-Policy",
"value": "",
"header": "cross-origin-embedder-policy",
"present": false,
"purpose": "Erzwingt kontrollierte Cross-Origin-Einbettungen und kann Cross-Origin Isolation ermöglichen.",
"severity": "info"
}
],
"status": "kritisch",
"missing": [
"HSTS",
"Content-Security-Policy",
"X-Frame-Options",
"Referrer-Policy",
"Permissions-Policy",
"Cross-Origin-Opener-Policy",
"Cross-Origin-Resource-Policy",
"Cross-Origin-Embedder-Policy"
],
"summary": "1 von 9 wichtigen Security-Headern vorhanden, 1 korrekt bewertet. Keine Content-Security-Policy gefunden.",
"findings": [],
"ok_count": 1,
"weak_count": 0,
"csp_analysis": {
"color": "red",
"score": 0,
"status": "fehlt",
"summary": "Keine Content-Security-Policy gefunden.",
"enforced": false,
"findings": [],
"available": false,
"directives": [],
"report_only": false,
"finding_count": 0,
"warning_count": 0
},
"missing_count": 8,
"present_count": 1,
"missing_info_count": 5,
"missing_warning_count": 3
},
"infrastructure_analysis": {
"signals": {
"caa": true,
"dnssec": false,
"final_https": true,
"tls_version": "TLSv1.3",
"hsts_enabled": false,
"address_count": 1,
"ipv6_available": false,
"email_protection": {
"mx": true,
"spf": true,
"dmarc": true
},
"certificate_valid": true,
"certificate_issuer": "GEANT TLS ECC 1",
"certificate_alt_names": [
"www.gfz-potsdam.de",
"www-prod3.gfz-potsdam.de",
"gfz-potsdam.de",
"www-prod5.gfz.de",
"www.gfz.de",
"gfz.de",
"www-prod6.gfz.de",
"www-prod1.gfz-potsdam.de",
"www-prod4.gfz.de",
"www-prod2.gfz-potsdam.de"
],
"multiple_ip_addresses": false,
"certificate_expires_at": "Nov 14 23:58:34 2026 GMT",
"certificate_days_remaining": 148,
"certificate_hostname_matches": true
},
"findings": [],
"risk_level": "low",
"positive_signals": [
"Moderne TLS-Version aktiv: TLSv1.3.",
"DMARC ist für die Domain vorhanden.",
"CAA-Records begrenzen Zertifikatsaussteller."
]
},
"performance_analysis": {
"score": 100,
"signals": {
"compressed": false,
"duration_ms": 313,
"image_count": 40,
"script_count": 1,
"cache_control": "max-age=56457",
"content_length": 0,
"viewport_found": true,
"stylesheet_count": 3
},
"findings": [],
"risk_level": "low"
},
"accessibility_analysis": {
"color": "yellow",
"score": 76,
"status": "prüfen",
"signals": {
"h1_count": 1,
"image_count": 40,
"button_count": 4,
"heading_count": 33,
"viewport_found": true,
"html_lang_found": true,
"form_field_count": 0,
"image_missing_alt_count": 8,
"buttons_without_name_count": 0,
"form_fields_without_label_count": 0
},
"summary": "40 Bild(er), 0 Formularfeld(er), 4 Button(s) im passiven HTML-Sample auf Basis-Barrierefreiheit geprüft.",
"findings": [
{
"id": "image_alt_missing",
"count": 8,
"title": "Bilder ohne Alternativtext",
"public": true,
"category": "accessibility",
"severity": "info",
"evidence_items": [
"/fileadmin/_processed_/4/5/csm_6368d3f292da3baaad130806775d8824_ebef3607df.jpeg",
"/fileadmin/_processed_/e/f/csm_T1_Foto_Original_he_2ed984f6c7.png",
"/fileadmin/_processed_/3/a/csm_T2_Foto_final_lower_resolution_a61f96669a.jpeg",
"/fileadmin/_processed_/5/6/csm_T3_Foto_Maule_Beben_final_24922bdf4f.jpeg",
"/fileadmin/_processed_/3/d/csm_T5_Foto_Original_e2cd7de54c.png",
"/fileadmin/_processed_/d/9/csm_Kachel_Publikationen_842201dc23.png",
"/fileadmin/_processed_/b/6/csm_grimm-z-19_a7345e09e6.jpeg",
"https://webstats.gfz.de/matomo.php?idsite=1&rec=1"
]
}
],
"wcag_matrix": {
"rows": [
{
"id": "wcag_non_text_content",
"ok": false,
"wcag": "WCAG 1.1.1 Non-text Content",
"title": "Alternativtexte für Bilder",
"impact": "mittel",
"status": "prüfen",
"evidence": "8 von 40 Bild(er) ohne alt-Text im HTML-Sample."
},
{
"id": "wcag_form_labels",
"ok": true,
"wcag": "WCAG 1.3.1 Info and Relationships / 3.3.2 Labels or Instructions",
"title": "Formularfelder beschriften",
"impact": "niedrig",
"status": "ok",
"evidence": "0 von 0 Formularfeld(er) ohne erkennbare Beschriftung."
},
{
"id": "wcag_button_names",
"ok": true,
"wcag": "WCAG 4.1.2 Name, Role, Value",
"title": "Buttons mit Namen versehen",
"impact": "niedrig",
"status": "ok",
"evidence": "0 von 4 Button(s) ohne erkennbaren Namen."
},
{
"id": "wcag_page_language",
"ok": true,
"wcag": "WCAG 3.1.1 Language of Page",
"title": "Seitensprache auszeichnen",
"impact": "niedrig",
"status": "ok",
"evidence": "HTML-lang-Attribut gefunden."
},
{
"id": "wcag_heading_structure",
"ok": true,
"wcag": "WCAG 1.3.1 Info and Relationships / 2.4.6 Headings and Labels",
"title": "Überschriftenstruktur",
"impact": "niedrig",
"status": "ok",
"evidence": "1 H1 und 33 Überschrift(en) im HTML-Sample."
},
{
"id": "wcag_mobile_reflow",
"ok": true,
"wcag": "WCAG 1.4.10 Reflow",
"title": "Mobile Viewport-Basis",
"impact": "niedrig",
"status": "ok",
"evidence": "Viewport-Meta-Tag gefunden."
}
],
"summary": "1 WCAG-/EAA-Prüfpunkt(e) auffällig, davon 0 mit hoher Auswirkung.",
"standard": "WCAG 2.2 orientierte Basisprüfung",
"available": true,
"issue_count": 1,
"high_impact_count": 0
}
},
"domain_history": {
"status": [
"active"
],
"summary": "RDAP liefert kein klares Registrierungsdatum.",
"age_days": null,
"findings": [],
"available": true,
"registrar": "",
"expires_at": "",
"risk_level": "unknown",
"registered_at": "",
"expires_in_days": null,
"last_changed_at": "2025-01-15T14:19:19+00:00"
},
"data_entry_analysis": {
"forms": [],
"score": 100,
"summary": "Die Seite kann Kontaktformular abfragen.",
"findings": [],
"form_count": 0,
"risk_level": "low",
"field_count": 0,
"asks_for_data": true,
"payment_providers": [],
"detected_data_types": [
{
"id": "contact",
"count": 1,
"label": "Kontaktformular"
}
],
"privacy_context_found": true,
"operator_context_found": true
},
"pii_exposure_analysis": {
"color": "green",
"score": 100,
"checks": [
{
"id": "current_url",
"ok": true,
"count": 0,
"label": "Aktuelle URL",
"detail": "Keine sensiblen Query-Parameter erkannt."
},
{
"id": "link_queries",
"ok": true,
"count": 0,
"label": "Link-Parameter",
"detail": "Keine sensiblen Link-Querys erkannt."
},
{
"id": "get_forms",
"ok": true,
"count": 0,
"label": "GET-Formulare",
"detail": "Keine personenbezogenen GET-Formulare erkannt."
},
{
"id": "external_forms",
"ok": true,
"count": 0,
"label": "Externe Formularziele",
"detail": "Keine externen Formularziele mit personenbezogenen Feldern erkannt."
},
{
"id": "tracking_context",
"ok": true,
"count": 0,
"label": "Tracking neben Dateneingabe",
"detail": "Keine Kombination aus Dateneingabe und datenschutzrelevanten Drittanbietern erkannt."
}
],
"status": "unauffällig",
"summary": "0 PII-/Datenleck-Hinweis(e) aus URL-, Formular- und Browserkontext.",
"findings": [],
"link_hits": [],
"finding_count": 0,
"current_url_hits": [],
"tracking_context": false,
"sensitive_get_forms": []
},
"scan_history_analysis": {
"available": false,
"summary": "Noch kein früherer gespeicherter Scan für diese Domain vorhanden.",
"total_scan_count": 1,
"previous_scan_count": 0,
"history": [
{
"scan_id": "ba01ef78-e624-4b54-92d9-119c369ff3f6",
"created_at": "2026-06-19 08:19:30.687016+02",
"score": 0,
"verdict": "riskant",
"finding_count": 27,
"integrity_root_hash": "615315414ec28d4dfd160bf7af02f8a24ec83727ac186d37c6902900e0879910",
"integrity_available_hash_count": 9,
"current": true
}
],
"new_findings": [],
"resolved_findings": [],
"technical_changes": {
"available": false,
"summary": "Noch kein früherer Scan für technische Änderungen vorhanden."
}
},
"benchmark_analysis": {
"host": "gfz.de",
"rank": 1,
"score": 0,
"status": "unter_durchschnitt",
"summary": "gfz.de liegt mit 0 Punkten unter dem gespeicherten Durchschnitt von 51.3.",
"available": true,
"peer_count": 4020,
"percentile": 0,
"query_mode": "php_ttl_cache_refresh",
"distribution": {
"0_39": 709,
"40_59": 1757,
"60_79": 1546,
"80_100": 8
},
"median_score": 57,
"average_score": 51.3,
"comparison_basis": "Neuester gespeicherter SaferPage-Scan je Domain; überwiegend deutschsprachige gespeicherte Checks.",
"same_score_count": 0,
"better_than_count": 0,
"qualified_peer_count": 3893,
"zero_score_count": 127,
"top_quartile_score": 64,
"top_decile_score": 67,
"qualified_average_score": 53,
"qualified_median_score": 57,
"qualified_top_quartile_score": 64,
"qualified_top_decile_score": 67,
"thresholds": [
{
"id": "critical",
"label": "Kritisch",
"range": "0-39",
"met": true
},
{
"id": "basic",
"label": "Basis stabilisieren",
"range": "40-59",
"met": false
},
{
"id": "managed",
"label": "Gesteuert",
"range": "60-79",
"met": false
},
{
"id": "strong",
"label": "Stark",
"range": "80-100",
"met": false
}
],
"risk_tier": "kritisch",
"target_score": 40,
"aspirational_target_score": 67,
"gap_to_target": 40,
"gap_to_top_quartile": 64,
"gap_to_strong": 80,
"cache_ttl_seconds": 300
},
"audit_receipt": {
"url": "https://gfz.de/",
"host": "gfz.de",
"status": "verfügbar",
"bot_url": "https://saferpage.de/bot",
"summary": "Prüfbeleg für gfz.de: kontrollierter HTTP-/Browser-Kurzcheck mit 51 Request(s), 4 Consent-Zustand/Zuständen und 7 Artefakt(en).",
"renderer": "playwright-chromium",
"artifacts": [
{
"label": "Öffentlicher Kurzreport",
"detail": "https://saferpage.de/gfz.de",
"status": "verfügbar"
},
{
"label": "JSON-Export",
"detail": "Maschinenlesbarer Report mit Modulen, Nachweisen und Tabellen.",
"status": "verfügbar"
},
{
"label": "CSV-Export",
"detail": "Tabellarische Prüfzeilen für Betreiber, Datenschutz und Technik.",
"status": "verfügbar"
},
{
"label": "160x150 Seitenvorschau",
"detail": "/cache/screenshots/gfz.de-160x150-b263ec32cec12e3d94.png",
"status": "verfügbar"
},
{
"label": "Cookie-Erklärung",
"detail": "1 Cookie-/Storage-Eintrag/Einträge.",
"status": "unauffällig"
},
{
"label": "Empfänger-/Anbieterinventar",
"detail": "0 Anbieterzeile(n), 0 AVV-/Rollenprüfung(en).",
"status": "unauffällig"
},
{
"label": "Barrierefreiheitserklärung-Entwurf",
"detail": "1 bekannte Barrierefreiheits-Punkt(e).",
"status": "Teilweise konform im automatischen Basischeck"
}
],
"available": true,
"final_url": "https://www.gfz.de/",
"checked_at": "2026-06-19T06:19:30+00:00",
"share_text": "SaferPage Prüfbeleg gfz.de: 51 Browser-Request(s), 0 Drittanbieter, 1 Cookie-/Storage-Einträge, geprüft am 2026-06-19T06:19:30.",
"user_agent": "SaferPageCrawler/0.3 (+https://saferpage.de/bot; schedules passive DACH website checks; report examples: https://saferpage.de/tests; kostenloser Report: <a href=\"https://saferpage.de/gfz.de\">https://saferpage.de/gfz.de</a>)",
"limitations": [
"Öffentliche Nachweise enthalten keine Cookie-Werte und keine vollständigen Request-URLs.",
"Der Scan ist ein passiver Browser- und HTTP-Kurzcheck; rechtliche Bewertung bleibt Betreiberaufgabe.",
"Dynamische Inhalte können sich je nach Region, Zeit, Gerät und Consent-Auswahl ändern."
],
"scan_context": "crawler",
"coverage_items": [
{
"label": "HTTP/DNS/TLS",
"value": "HTTP 200 · DNS ok · TLS ok"
},
{
"label": "Browserlauf",
"value": "51 Request(s), 0 Drittanbieter-Domain(s), 1 Browser-Cookie(s)."
},
{
"label": "Consent-Zustände",
"value": "4 Zustand/Zustände: Default, Ablehnen, Akzeptieren und GPC soweit verfügbar."
},
{
"label": "Seitenabdeckung",
"value": "8 priorisierte Unterseite(n) im Nachweispack."
},
{
"label": "Drittanbieter-Auszug",
"value": "0 Anbieterzeile(n) im öffentlichen Nachweis."
},
{
"label": "Cookie-Auszug",
"value": "1 Cookie-Zeile(n) im öffentlichen Nachweis."
}
],
"confidence_score": 88,
"browser_final_url": "https://www.gfz.de/"
},
"evidence_integrity_manifest": {
"host": "gfz.de",
"status": "verfügbar",
"summary": "Integritätsmanifest für gfz.de: 9/9 Nachweisbereich(e) mit SHA-256-Hash dokumentiert.",
"sections": [
{
"id": "audit_receipt",
"hash": "53fabff0fdaa0c21cb04db745e308a79cd37adabffe01bdc3ebb9387b3aea4e3",
"count": 18,
"label": "Prüfbeleg",
"detail": "Kanonischer JSON-Hash des kompakten Prüfbelegs.",
"status": "verfügbar"
},
{
"id": "protocol",
"hash": "ed803852db6310f8e7b377687ecf273bca525467510f337c16a406efc5a3cec3",
"count": 15,
"label": "Scan-Protokoll",
"detail": "URL, Endziel, User-Agent, Zeitstempel, HTTP/DNS/TLS und Renderer.",
"status": "verfügbar"
},
{
"id": "checkpoints",
"hash": "9dbf43ce1fec61320a482eddcd652c0f02767587e5954f54ca23f62dbab31baf",
"count": 6,
"label": "Prüfschritte",
"detail": "Kanonischer JSON-Hash der dokumentierten Prüfstationen.",
"status": "verfügbar"
},
{
"id": "consent_states",
"hash": "4c6fd8288209437d4d29b7db6ad596252434052f1571b72aba7b0bcdb0aed8a7",
"count": 4,
"label": "Consent-Zustände",
"detail": "Default-, Ablehnen-, Akzeptieren- und GPC-Nachweise soweit verfügbar.",
"status": "verfügbar"
},
{
"id": "third_party_evidence",
"hash": "4f53cda18c2baa0c0354bb5f9a3ecbe5ed12ab4d8e11ba873c2f11161202b945",
"count": 0,
"label": "Drittanbieter-Auszug",
"detail": "Sanitisierte Anbieter-, Kategorie-, Transfer- und Request-Zählwerte.",
"status": "leer"
},
{
"id": "cookie_evidence",
"hash": "e32385b4fda4e157c1e96ab3ebb301b712527037887ecfc52cbefcda350059e0",
"count": 1,
"label": "Cookie-Auszug",
"detail": "Sanitisierte Cookie-Metadaten ohne Cookie-Werte.",
"status": "verfügbar"
},
{
"id": "request_samples",
"hash": "4f53cda18c2baa0c0354bb5f9a3ecbe5ed12ab4d8e11ba873c2f11161202b945",
"count": 0,
"label": "Request-Samples",
"detail": "Sanitisierte Drittanbieter-Samples ohne vollständige Request-URLs.",
"status": "leer"
},
{
"id": "checked_pages",
"hash": "479731c03ecb5823716d0ed8f706a92c5f73fbc76b1ede360ac978e24318ab03",
"count": 8,
"label": "Geprüfte Unterseiten",
"detail": "Priorisierte Pfade aus Sitemap, Pflichtseiten und interner Linkstruktur.",
"status": "verfügbar"
},
{
"id": "screenshot_file",
"hash": "1135e856ee659ad2a59fbf2c25f4d5fe64cffc425ed8a10c0bec3011a95cdcf6",
"count": 7737,
"label": "160x150 Seitenvorschau-Datei",
"detail": "/cache/screenshots/gfz.de-160x150-b263ec32cec12e3d94.png",
"status": "verfügbar"
}
],
"algorithm": "sha256",
"available": true,
"root_hash": "615315414ec28d4dfd160bf7af02f8a24ec83727ac186d37c6902900e0879910",
"checked_at": "2026-06-19T06:19:30+00:00",
"limitations": [
"Das Manifest schützt die im Report veröffentlichten/sanitisierten Nachweise, nicht verdeckte Cookie-Werte oder vollständige Request-URLs.",
"Ohne externe qualifizierte Zeitstempelung beweist der Hash Integrität des exportierten Artefakts, aber keine amtliche Zustellung."
],
"section_count": 9,
"canonicalization": "JSON UTF-8, sort_keys=true, kompakte Separatoren; Screenshot als rohe Datei-Bytes.",
"available_hash_count": 9
},
"audit_evidence_pack": {
"status": "verfügbar",
"summary": "Nachweisprotokoll mit 51 Browser-Request(s), 1 Cookie-Nachweis(en), 0 Drittanbieter-Auszug/auszügen und 4 Consent-Zustand/Zuständen.",
"protocol": {
"host": "gfz.de",
"dns_ok": true,
"tls_ok": true,
"bot_url": "https://saferpage.de/bot",
"renderer": "playwright-chromium",
"final_url": "https://www.gfz.de/",
"input_url": "https://gfz.de/",
"checked_at": "2026-06-19T06:19:30+00:00",
"user_agent": "SaferPageCrawler/0.3 (+https://saferpage.de/bot; schedules passive DACH website checks; report examples: https://saferpage.de/tests; kostenloser Report: <a href=\"https://saferpage.de/gfz.de\">https://saferpage.de/gfz.de</a>)",
"http_status": 200,
"scan_context": "crawler",
"screenshot_url": "/cache/screenshots/gfz.de-160x150-b263ec32cec12e3d94.png",
"googlebot_status": 200,
"browser_final_url": "https://www.gfz.de/",
"dns_address_count": 1
},
"checkpoints": [
{
"label": "DNS",
"detail": "1 Adresse(n) aufgelöst.",
"status": "ok"
},
{
"label": "TLS/HTTPS",
"detail": "TLSv1.3",
"status": "ok"
},
{
"label": "HTTP-Abruf",
"detail": "Status 200, Endziel https://www.gfz.de/.",
"status": "ok"
},
{
"label": "Browserlauf",
"detail": "51 Request(s), 0 Drittanbieter-Domain(s).",
"status": "ok"
},
{
"label": "Consent-Zustände",
"detail": "Default, Ablehnen, Akzeptieren und GPC werden soweit möglich gegenübergestellt.",
"status": "unauffällig"
},
{
"label": "Exports",
"detail": "PDF/Druck, JSON und CSV enthalten die wesentlichen Prüfnachweise.",
"status": "verfügbar"
}
],
"limitations": [
"Öffentliche Nachweise enthalten keine Cookie-Werte und keine vollständigen Request-URLs.",
"Der Scan ist ein passiver Browser- und HTTP-Kurzcheck; rechtliche Bewertung bleibt Betreiberaufgabe.",
"Dynamische Inhalte können sich je nach Region, Zeit, Gerät und Consent-Auswahl ändern."
],
"checked_pages": [
{
"path": "/datenschutz",
"source": "homepage_link",
"status": 0,
"category": "datenschutz"
},
{
"path": "/impressum",
"source": "homepage_link",
"status": 0,
"category": "impressum"
},
{
"path": "/kontakt",
"source": "homepage_link",
"status": 0,
"category": "kontakt"
},
{
"path": "/presse/gfz-schuelerlabor",
"source": "homepage_link",
"status": 0,
"category": "newsletter"
},
{
"path": "/ueber-uns/preise-und-auszeichnungen/rolf-emmermann-medaille",
"source": "homepage_link",
"status": 0,
"category": "preise"
},
{
"path": "/departments",
"source": "homepage_link",
"status": 0,
"category": "unterseite"
},
{
"path": "/departments/geochemie",
"source": "homepage_link",
"status": 0,
"category": "unterseite"
},
{
"path": "/departments/geodaesie",
"source": "homepage_link",
"status": 0,
"category": "unterseite"
}
],
"cookie_evidence": [
{
"name": "PHPSESSID",
"domain": "gfz.de",
"secure": false,
"category": "Notwendig",
"provider": "gfz.de",
"tracking": false,
"retention": "Session",
"same_site": "Lax",
"pre_consent": true
}
],
"browser_evidence": {
"gpc_enabled": true,
"request_count": 51,
"storage_total": 0,
"accept_clicked": true,
"reject_clicked": false,
"browser_cookie_count": 1,
"contacted_domain_count": 1,
"third_party_domain_count": 0,
"storage_tracking_hint_count": 0,
"privacy_relevant_domain_count": 0
},
"storage_evidence": {
"tracking_key_hints": [],
"local_storage_total": 0,
"session_storage_total": 0
},
"third_party_evidence": [],
"external_script_count": 0,
"consent_state_evidence": [
{
"label": "Erstaufruf",
"cookie_count": 0,
"domain_count": 0,
"request_count": 0,
"storage_tracking_hint_count": 0,
"privacy_relevant_domain_count": 0
},
{
"label": "Nach Ablehnen neu",
"cookie_count": 0,
"domain_count": 0,
"request_count": 0,
"storage_tracking_hint_count": 0,
"privacy_relevant_domain_count": 0
},
{
"label": "Nach Akzeptieren neu",
"cookie_count": 0,
"domain_count": 0,
"request_count": 0,
"storage_tracking_hint_count": 0,
"privacy_relevant_domain_count": 0
},
{
"label": "GPC-Aufruf",
"cookie_count": 0,
"domain_count": 0,
"request_count": 0,
"storage_tracking_hint_count": 0,
"privacy_relevant_domain_count": 0
}
],
"request_sample_evidence": []
},
"consent_visual_salience_evidence": {
"schema": "https://saferpage.de/schemas/consent-visual-salience-evidence.v1",
"status": "accept_without_visible_reject_signal",
"available": true,
"evidence_level": "dom_viewport_signal_only",
"summary": "Der erste Headless-Chromium-Viewport liefert sichtbare Consent-Control-Signale mit Text, Position, Groesse und typografischen Hinweisen.",
"sample_status": "classified_control_samples",
"classified_sample_count": 2,
"accept_control_count": 2,
"reject_control_count": 0,
"settings_control_count": 0,
"visible_control_count": 27,
"accept_max_area": 7511,
"reject_max_area": 0,
"reject_prominence_ratio": "nicht messbar",
"samples": [
{
"kind": "accept",
"text": "NICHT ZUSTIMMEN",
"tag": "button",
"width": 186,
"height": 40,
"area": 7511,
"top": 870,
"left": 229,
"font_weight": "400"
},
{
"kind": "accept",
"text": "ZUSTIMMEN",
"tag": "button",
"width": 138,
"height": 40,
"area": 5568,
"top": 870,
"left": 657,
"font_weight": "400"
}
],
"sample_boundary": "Samples enthalten nur klassifizierte Accept-/Reject-/Settings-Controls. Weitere sichtbare Consent-Controls bleiben als Zaehler erhalten, werden aber ohne Klassifizierung nicht als Ablehnen-, Akzeptieren- oder Einstellungsprobe behauptet.",
"claim_boundary": "Consent-Visual-Salienz ist ein DOM-/Viewport-Signal aus dem ersten Browserlauf. Sie ist keine Rechtsbewertung, kein Dark-Pattern-Endurteil und kein Nachweis fuer spaetere Consent-Zustaende, Scrollbereiche, Loginbereiche oder manuelle Betreiberkontexte."
}
}