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": "ldi.nrw.de",
"normalized_url": "https://ldi.nrw.de/",
"score": 62,
"verdict": {
"color": "orange",
"label": "auffällig",
"score": 62
},
"scan_id": "72c5af78-f0ba-48bf-9da3-6568e64aeee1",
"created_at": "2026-06-18 08:49:58.070004+02",
"evidence": {
"dns": {
"ok": true,
"addresses": [
"93.184.132.49"
],
"duration_ms": 30
},
"tls": {
"ok": true,
"cipher": "TLS_AES_256_GCM_SHA384",
"issuer": [
[
[
"countryName",
"DE"
]
],
[
[
"organizationName",
"Deutsche Telekom Security GmbH"
]
],
[
[
"organizationIdentifier",
"NTRDE-DER3201.HRB15241"
]
],
[
[
"commonName",
"Telekom Security OV RSA CA 26A"
]
]
],
"subject": [
[
[
"countryName",
"DE"
]
],
[
[
"stateOrProvinceName",
"NRW"
]
],
[
[
"localityName",
"Duesseldorf"
]
],
[
[
"organizationName",
"IT.NRW"
]
],
[
[
"commonName",
"ldi.nrw.de"
]
]
],
"version": "TLSv1.3",
"not_after": "Dec 26 23:59:59 2026 GMT",
"hostname_matches": true,
"days_until_expiry": 191,
"subject_alt_names": [
"ldi.nrw.de",
"www.ldi.nrw.de"
],
"issuer_common_name": "Telekom Security OV RSA CA 26A"
},
"http": {
"ok": true,
"status": 200,
"headers": {
"date": "Tue, 16 Jun 2026 13:04:53 GMT",
"vary": "Accept-Encoding",
"server": "Apache",
"expires": "Sun, 19 Nov 1978 05:00:00 GMT",
"connection": "close",
"content-type": "text/html; charset=UTF-8",
"cache-control": "must-revalidate, no-cache, private",
"content-length": "197473",
"referrer-policy": "strict-origin-when-cross-origin",
"x-frame-options": "SAMEORIGIN",
"content-language": "de",
"x-xss-protection": "0; mode=block",
"x-content-type-options": "nosniff",
"content-security-policy": "default-src 'self' *.nrw.de; script-src 'self' 'unsafe-inline' 'unsafe-eval' *.nrw.de *.google.com *.youtube.com *.youtu.be *.twimg.com *.twitter.com twitter.com *.jwpcdn.com *.gstatic.com *.googleapis.com *.googlesyndication.com *.openstreetmap.org *.mozilla.org *.vimeo.com *.vimeocdn.com *.flickr.com *.staticflickr.com *.cloudflare.com cdn.jsdelivr.net svc.webspellchecker.net; style-src 'self' 'unsafe-inline' *.nrw.de *.twitter.com twitter.com *.facebook.com *.googleapis.com *.twimg.com *.cloudflare.com cdn.jsdelivr.net svc.webspellchecker.net; font-src data: *; img-src data: *; frame-ancestors 'self' *.nrw.de *.facebook.com *.facebook.de *.twitter.com twitter.com *.google.com *.youtube.com *.youtu.be ytchannelembed.com; worker-src 'self' *.nrw.de *.facebook.com *.facebook.de *.twitter.com twitter.com *.google.com *.youtube.com *.youtu.be ytchannelembed.com *.openstreetmap.org broschueren.nordrheinwestfalendirekt.de; frame-src 'self' *.nrw.de *.facebook.com *.facebook.de *.twitter.com twitter.com *.google.com *.youtube.com *.youtu.be ytchannelembed.com *.openstreetmap.org broschueren.nordrheinwestfalendirekt.de; object-src 'self'; connect-src 'self' *.nrw.de svc.webspellchecker.net; media-src *; upgrade-insecure-requests;",
"strict-transport-security": "max-age=31536000; preload",
"x-permitted-cross-domain-policies": "master-only"
},
"body_size": 197473,
"final_url": "https://www.ldi.nrw.de/",
"duration_ms": 345
},
"scanner": {
"bot_url": "https://saferpage.de/bot",
"context": "manual",
"user_agent": "SaferPageBot/0.2 (+https://saferpage.de/bot; passive website safety check; no attack tests)",
"default_user_agent": "SaferPageBot/0.2 (+https://saferpage.de/bot; passive website safety check; no attack tests)"
},
"domain_records": {
"mx": true,
"caa": false,
"spf": true,
"dmarc": true,
"dnssec": false,
"records": {
"mx": [
"40 relay7m.it.nrw.de.",
"60 relay7v.it.nrw.de."
],
"ns": [],
"caa": [],
"txt": [
"v=spf1 include:_spf.nrw.de include:_spf2.nrw.de ?all"
],
"cname": [],
"dmarc": [
"v=DMARC1; p=none; ruf=mailto:forensic_dmarc@mail.it.nrw.de"
],
"dnskey_present": false
},
"spf_includes": [
"_spf.nrw.de",
"_spf2.nrw.de"
],
"verifications": []
},
"googlebot_http": {
"ok": true,
"status": 200,
"headers": {
"date": "Tue, 16 Jun 2026 13:04:53 GMT",
"vary": "Accept-Encoding",
"server": "Apache",
"expires": "Sun, 19 Nov 1978 05:00:00 GMT",
"connection": "close",
"content-type": "text/html; charset=UTF-8",
"cache-control": "must-revalidate, no-cache, private",
"content-length": "197473",
"referrer-policy": "strict-origin-when-cross-origin",
"x-frame-options": "SAMEORIGIN",
"content-language": "de",
"x-xss-protection": "0; mode=block",
"x-content-type-options": "nosniff",
"content-security-policy": "default-src 'self' *.nrw.de; script-src 'self' 'unsafe-inline' 'unsafe-eval' *.nrw.de *.google.com *.youtube.com *.youtu.be *.twimg.com *.twitter.com twitter.com *.jwpcdn.com *.gstatic.com *.googleapis.com *.googlesyndication.com *.openstreetmap.org *.mozilla.org *.vimeo.com *.vimeocdn.com *.flickr.com *.staticflickr.com *.cloudflare.com cdn.jsdelivr.net svc.webspellchecker.net; style-src 'self' 'unsafe-inline' *.nrw.de *.twitter.com twitter.com *.facebook.com *.googleapis.com *.twimg.com *.cloudflare.com cdn.jsdelivr.net svc.webspellchecker.net; font-src data: *; img-src data: *; frame-ancestors 'self' *.nrw.de *.facebook.com *.facebook.de *.twitter.com twitter.com *.google.com *.youtube.com *.youtu.be ytchannelembed.com; worker-src 'self' *.nrw.de *.facebook.com *.facebook.de *.twitter.com twitter.com *.google.com *.youtube.com *.youtu.be ytchannelembed.com *.openstreetmap.org broschueren.nordrheinwestfalendirekt.de; frame-src 'self' *.nrw.de *.facebook.com *.facebook.de *.twitter.com twitter.com *.google.com *.youtube.com *.youtu.be ytchannelembed.com *.openstreetmap.org broschueren.nordrheinwestfalendirekt.de; object-src 'self'; connect-src 'self' *.nrw.de svc.webspellchecker.net; media-src *; upgrade-insecure-requests;",
"strict-transport-security": "max-age=31536000; preload",
"x-permitted-cross-domain-policies": "master-only"
},
"body_size": 197473,
"final_url": "https://www.ldi.nrw.de/",
"duration_ms": 401
},
"ai_search_policy_evidence": {
"files": [
{
"id": "robots_txt",
"url": "https://www.ldi.nrw.de/robots.txt",
"label": "robots.txt",
"reason": "",
"status": "found",
"body_size": 2005,
"truncated": false,
"body_sha256": "17f7b0b22f4a02e7b9d4b252bf47b78870c738d7f35dcfdb043b02470e347603",
"duration_ms": 79,
"http_status": 200,
"ai_bot_policy": {
"bot_directives": [],
"explicit_ai_bots": [],
"explicit_ai_bot_count": 0,
"wildcard_directive_count": 51,
"wildcard_directives_sample": [
{
"value": "/core/*.css$",
"directive": "allow"
},
{
"value": "/core/*.css?",
"directive": "allow"
},
{
"value": "/core/*.js$",
"directive": "allow"
},
{
"value": "/core/*.js?",
"directive": "allow"
},
{
"value": "/core/*.gif",
"directive": "allow"
},
{
"value": "/core/*.jpg",
"directive": "allow"
},
{
"value": "/core/*.jpeg",
"directive": "allow"
},
{
"value": "/core/*.png",
"directive": "allow"
}
]
},
"relevant_lines": [
"# This file is to prevent the crawling and indexing of certain parts",
"User-agent: *",
"Allow: /core/*.css$",
"Allow: /core/*.css?",
"Allow: /core/*.js$",
"Allow: /core/*.js?",
"Allow: /core/*.gif",
"Allow: /core/*.jpg",
"Allow: /core/*.jpeg",
"Allow: /core/*.png",
"Allow: /core/*.svg",
"Allow: /profiles/*.css$",
"Allow: /profiles/*.css?",
"Allow: /profiles/*.js$",
"Allow: /profiles/*.js?",
"Allow: /profiles/*.gif"
]
},
{
"id": "llms_txt",
"url": "https://www.ldi.nrw.de/llms.txt",
"label": "llms.txt",
"reason": "http_error",
"status": "missing",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 84,
"http_status": 404,
"relevant_lines": []
},
{
"id": "ai_txt",
"url": "https://www.ldi.nrw.de/.well-known/ai.txt",
"label": "AI Policy",
"reason": "http_error",
"status": "missing",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 82,
"http_status": 404,
"relevant_lines": []
},
{
"id": "ai_policy_txt",
"url": "https://www.ldi.nrw.de/.well-known/ai-policy.txt",
"label": "AI Policy",
"reason": "http_error",
"status": "missing",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 77,
"http_status": 404,
"relevant_lines": []
},
{
"id": "ward_txt",
"url": "https://www.ldi.nrw.de/.well-known/ward.txt",
"label": "WARD Policy",
"reason": "http_error",
"status": "missing",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 114,
"http_status": 404,
"relevant_lines": []
}
],
"origin": "https://www.ldi.nrw.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.ldi.nrw.de/ads.txt",
"label": "ads.txt",
"reason": "http_error",
"status": "missing",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 143,
"http_status": 404,
"ads_txt_policy": [],
"relevant_lines": [],
"sellers_json_policy": []
},
{
"id": "app_ads_txt",
"url": "https://www.ldi.nrw.de/app-ads.txt",
"label": "app-ads.txt",
"reason": "http_error",
"status": "missing",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 78,
"http_status": 404,
"ads_txt_policy": [],
"relevant_lines": [],
"sellers_json_policy": []
},
{
"id": "sellers_json",
"url": "https://www.ldi.nrw.de/sellers.json",
"label": "sellers.json",
"reason": "http_error",
"status": "missing",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 157,
"http_status": 404,
"ads_txt_policy": [],
"relevant_lines": [],
"sellers_json_policy": []
}
],
"origin": "https://www.ldi.nrw.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.ldi.nrw.de/.well-known/security.txt",
"label": "security.txt",
"reason": "",
"status": "found",
"body_size": 347,
"truncated": false,
"body_sha256": "4389a18242bc1c77cab747d4c7f8d2860320b177f4fe0d899810c1c21775f8cf",
"duration_ms": 84,
"http_status": 200,
"relevant_lines": [
"Contact: mailto:cert@it.nrw.de",
"Expires: 2027-01-01T10:00:00.000Z",
"Encryption: https://www.cert.nrw.de/files/CERT%20NRW_0x212C0843_public.asc",
"Preferred-Languages: de,en",
"Canonical: https://www.cert.nrw.de/.well-known/security.txt",
"Policy: https://www.cert.nrw.de/files/cert_nrw_responsible_disclosure_policy_en.pdf",
"Hiring: https://www.it.nrw/karriere"
],
"security_txt_policy": {
"field_count": 7,
"contact_count": 1,
"expires_values": [
"2027-01-01T10:00:00.000Z"
],
"fields_present": [
"canonical",
"contact",
"encryption",
"expires",
"hiring",
"policy",
"preferred-languages"
],
"policy_present": true,
"contact_samples": [
"mailto:cert@it.nrw.de"
],
"expires_present": true,
"canonical_present": true,
"encryption_present": true,
"preferred_languages": [
"de,en"
]
}
},
{
"id": "security_txt_legacy",
"url": "https://www.ldi.nrw.de/security.txt",
"label": "security.txt legacy",
"reason": "http_error",
"status": "missing",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 85,
"http_status": 404,
"relevant_lines": [],
"security_txt_policy": []
}
],
"origin": "https://www.ldi.nrw.de",
"schema": "https://saferpage.de/schemas/security-trust-policy-evidence.v1",
"status": "checked",
"metrics": {
"file_count": 2,
"field_count": 7,
"contact_count": 1,
"found_file_count": 1,
"preferred_well_known_found": 1
},
"summary": "1 von 2 security.txt-Ziel(en) gefunden; 1 Kontaktfeld(er), 7 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": 7,
"contact_count": 1,
"fields_present": [
"canonical",
"contact",
"encryption",
"expires",
"hiring",
"policy",
"preferred-languages"
],
"policy_present": true,
"expires_present": true,
"encryption_present": true,
"security_txt_found": true,
"preferred_well_known_found": true
}
},
"findings": [
{
"id": "consent_no_reject_option",
"title": "Cookie-Hinweis ohne klare Ablehnen-Option",
"public": true,
"audience": "nutzer",
"category": "privacy",
"severity": "warning",
"evidence_items": [
"Sichtbare Banner-Controls: Akzeptieren 0, Ablehnen 0, Einstellungen 0"
],
"user_importance": 121,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "google_consent_mode_missing",
"title": "Google Consent Mode Default nicht erkannt",
"public": true,
"audience": "nutzer",
"category": "privacy",
"severity": "warning",
"evidence_items": [
"Google-Tags erkannt, aber kein sichtbarer Consent-Mode-/Consent-Kontext"
],
"user_importance": 120,
"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.ldi.nrw.de/",
"evidence_items": [
"https://www.ldi.nrw.de/"
],
"user_importance": 118,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "privacy_policy_provider_disclosure_gap",
"title": "Erkannte Anbieter fehlen in der Datenschutzerklärung",
"public": true,
"audience": "nutzer",
"category": "privacy",
"severity": "warning",
"evidence_items": [
"Erkannte Anbieter sind nicht alle in der Datenschutzerklärung erwähnt"
],
"user_importance": 116,
"importance_label": "Wichtig für Nutzer",
"missing_providers": [
"Google Analytics"
]
},
{
"id": "privacy_policy_required_items_missing",
"title": "Datenschutzerklärung deckt zentrale Bausteine nicht vollständig ab",
"public": true,
"missing": [
"Zwecke der Verarbeitung",
"Speicherfrist / Löschung",
"Empfänger / Auftragsverarbeiter",
"Cookies / Tracking",
"Widerruf / Opt-out",
"Drittlandtransfer"
],
"audience": "nutzer",
"category": "privacy",
"severity": "warning",
"user_importance": 112,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "privacy_policy_tracking_disclosure_gap",
"title": "Cookies/Tracking in der Datenschutzerklärung nicht klar erkannt",
"public": true,
"audience": "nutzer",
"category": "privacy",
"severity": "warning",
"user_importance": 111,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "browser_keystroke_listener_signals",
"count": 11,
"title": "Viele Tastatur-/Eingabe-Listener im Browser erkannt",
"public": true,
"audience": "nutzer",
"category": "privacy",
"severity": "info",
"evidence_items": [
"Tastatur-Eingabe-Listener (Session-Replay-nah) im Browser-Lauf erkannt"
],
"user_importance": 110,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "csp_unsafe_inline",
"title": "CSP erlaubt unsafe-inline für Skripte",
"public": true,
"audience": "nutzer",
"category": "security_headers",
"severity": "warning",
"user_importance": 96,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "csp_unsafe_eval",
"title": "CSP erlaubt eval-nahe Skriptausführung",
"public": true,
"audience": "nutzer",
"category": "security_headers",
"severity": "warning",
"user_importance": 94,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "csp_permissive_script_sources",
"title": "CSP erlaubt sehr breite Skriptquellen",
"public": true,
"sources": [
"*.nrw.de",
"*.google.com",
"*.youtube.com",
"*.youtu.be",
"*.twimg.com",
"*.twitter.com",
"*.jwpcdn.com",
"*.gstatic.com"
],
"audience": "nutzer",
"category": "security_headers",
"severity": "info",
"user_importance": 88,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "important_pages_not_discovered",
"title": "Wichtige Betreiberseiten nicht vollständig in der Linkstruktur gefunden",
"public": true,
"audience": "nutzer",
"category": "crawl",
"severity": "warning",
"evidence_items": [
"Wichtige Seiten in der Linkstruktur gefunden: datenschutz"
],
"user_importance": 88,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "missing_meta_description",
"title": "Meta-Description fehlt",
"public": true,
"audience": "nutzer",
"category": "content",
"severity": "info",
"evidence_items": [
"Im HTML kein <meta name=\"description\"> gefunden"
],
"user_importance": 84,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "image_alt_missing",
"count": 11,
"title": "Bilder ohne Alternativtext",
"public": true,
"audience": "nutzer",
"category": "accessibility",
"severity": "info",
"evidence_items": [
"/sites/default/files/styles/slider_main_16_9_960/public/2025-02/panthermedia_b42196053_3508x2341.jpg?h=2553af24&itok=3NS8HiMb",
"/sites/default/files/styles/slider_main_16_9_960/public/2025-07/panthermedia-232199340-m_datenpanne.jpg?h=8eb76705&itok=6I0vhEFG",
"/sites/default/files/styles/slider_main_16_9_960/public/2026-04/istock-523769722.jpg?h=9effd7ce&itok=cM04uDEB",
"/sites/default/files/styles/slider_main_16_9_960/public/2026-04/wmy_0005.jpg?h=99ad6be6&itok=xG9wnAS4",
"/sites/default/files/styles/slider_main_16_9_960/public/2026-03/istock-1315342275_1.jpg?h=3345eb8f&itok=jSYSnftJ",
"/sites/default/files/styles/slider_main_16_9_960/public/2025-12/cyber_kriminalitaet_252995358-m.jpg?h=8eb76705&itok=1AjHyyKR",
"/sites/default/files/styles/teaser_landscape_2_1_320/public/2026-04/wmy_0005.jpg?h=53780ebf&itok=luKkuTnU",
"/sites/default/files/styles/teaser_landscape_2_1_320/public/2025-12/panthermedia_telekommunikation_208386606-m.jpg?h=b7294b58&itok=w1IlnxYh"
],
"user_importance": 82,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "large_html_response",
"title": "HTML-Antwort ist groß",
"public": true,
"audience": "nutzer",
"category": "performance",
"severity": "info",
"evidence_items": [
"HTML-Größe: 197473 Bytes"
],
"user_importance": 82,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "compression_missing",
"title": "Komprimierung nicht erkannt",
"public": true,
"audience": "betreiber",
"category": "performance",
"severity": "info",
"evidence_items": [
"HTTP-Antwort ohne gzip/br-Komprimierung (kein Content-Encoding-Header)"
],
"user_importance": 76,
"importance_label": "Technischer Hinweis"
},
{
"id": "csp_missing_base_uri",
"title": "CSP ohne base-uri",
"public": true,
"audience": "betreiber",
"category": "security_headers",
"severity": "info",
"evidence_items": [
"Content-Security-Policy ohne base-uri-Direktive"
],
"user_importance": 74,
"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": "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": "orange",
"score": 52,
"title": "Sicherheit, TLS & Header",
"source": "DNS, TLS, HTTP-Status, Zertifikat und Security-Header",
"status": "auffällig",
"evidence": "1 Infrastruktur-Hinweis(e), Security-Header: 5/9 vorhanden, 4 fehlen, externe Skript-Hosts: 0."
},
{
"id": "google_third_parties",
"color": "orange",
"score": 58,
"title": "Google-Dienste & Drittanbieter",
"source": "Chromium-Requests, Anbieterklassifikation und Google Consent Mode Heuristik",
"status": "auffällig",
"evidence": "Google-Tags: ja, 0 Google-nahe Domain(s), Consent-Default: nein, Analytics: nein, Werbung: nein, Fonts: nein."
},
{
"id": "privacy_consent",
"color": "orange",
"score": 60,
"title": "Datenschutz, Cookies & Consent",
"source": "Browser, HTTP-Header, HTML und Consent-/Cookie-Heuristik",
"status": "auffällig",
"evidence": "0 Tracking-Script(s), 0 Cookie(s) vor Einwilligung, 0 Tracking-Cookie(s), Ablehnen-Option: nein, Consent-Audit: 60."
},
{
"id": "site_coverage",
"color": "orange",
"score": 67,
"title": "Seitenabdeckung & Crawl",
"source": "Startseiten-Links, Compliance-Links und begrenzter interner Zusatzabruf",
"status": "auffällig",
"evidence": "30 interne Linkziele erkannt, 4 priorisierte Unterseite(n) abgerufen."
},
{
"id": "accessibility_usability",
"color": "orange",
"score": 68,
"title": "Barrierefreiheit & Usability",
"source": "Passives HTML-Sample: Bilder, Formulare, Buttons, Sprache, Headings und Viewport",
"status": "auffällig",
"evidence": "11 Bild(er) ohne alt, 0 Formularfeld(er) ohne Beschriftung, 0 Button(s) ohne Namen."
},
{
"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": "forms_payments",
"color": "yellow",
"score": 84,
"title": "Formulare, Login & Zahlung",
"source": "HTML-Formulare, Eingabefelder, Zahlungsanbieter und Kontextlinks",
"status": "prüfen",
"evidence": "Aus diesem Rohfeld wird im Report keine zusätzliche Scan-Feststellung abgeleitet; Betreiberkontext und Umsetzungshinweise stehen auf separaten Seiten."
},
{
"id": "browser_evidence",
"color": "yellow",
"score": 88,
"title": "Browser-Nachweis",
"source": "Headless Chromium mit Screenshot- und Request-Telemetrie",
"status": "prüfen",
"evidence": "46 Request(s), 0 Drittanbieter-Domain(s), davon 0 datenschutzrelevant, 0 Browser-Cookie(s), Transfer-Prüfbedarf: 0, Referrer-/URL-Leaks: 0, Fingerprinting-/Replay-Hinweise: 1."
},
{
"id": "performance_mobile",
"color": "yellow",
"score": 88,
"title": "Performance & mobile Nutzbarkeit",
"source": "HTTP-Antwort, HTML-Größe, Komprimierung und mobile Basis",
"status": "prüfen",
"evidence": "Performance-Score 88, Antwortzeit 345 ms."
},
{
"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": "cookie_inventory",
"color": "green",
"score": 100,
"title": "Cookie-Inventar",
"source": "HTTP-Set-Cookie und Chromium-Cookies beim ersten Seitenaufruf",
"status": "unauffällig",
"evidence": "0 Cookie(s), 0 Tracking-/Werbe-Cookie(s), 0 Drittanbieter-Cookie(s), 0 langlebig, 0 sehr lang."
},
{
"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": "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": "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": "tracking_pixels_beacons",
"color": "green",
"score": 100,
"title": "Tracking-Pixel & Beacons",
"source": "HTML-Pixel, Link-Ping-Attribute, Chromium-Requests und Browser-API-Instrumentierung",
"status": "unauffällig",
"evidence": "0 Pixel-/Bildtracking-Hinweis(e), 0 Beacon-/Telemetry-Hinweis(e), 0 Link-Ping(s)."
}
],
"ai_search_policy_evidence": {
"files": [
{
"id": "robots_txt",
"url": "https://www.ldi.nrw.de/robots.txt",
"label": "robots.txt",
"reason": "",
"status": "found",
"body_size": 2005,
"truncated": false,
"body_sha256": "17f7b0b22f4a02e7b9d4b252bf47b78870c738d7f35dcfdb043b02470e347603",
"duration_ms": 79,
"http_status": 200,
"ai_bot_policy": {
"bot_directives": [],
"explicit_ai_bots": [],
"explicit_ai_bot_count": 0,
"wildcard_directive_count": 51,
"wildcard_directives_sample": [
{
"value": "/core/*.css$",
"directive": "allow"
},
{
"value": "/core/*.css?",
"directive": "allow"
},
{
"value": "/core/*.js$",
"directive": "allow"
},
{
"value": "/core/*.js?",
"directive": "allow"
},
{
"value": "/core/*.gif",
"directive": "allow"
},
{
"value": "/core/*.jpg",
"directive": "allow"
},
{
"value": "/core/*.jpeg",
"directive": "allow"
},
{
"value": "/core/*.png",
"directive": "allow"
}
]
},
"relevant_lines": [
"# This file is to prevent the crawling and indexing of certain parts",
"User-agent: *",
"Allow: /core/*.css$",
"Allow: /core/*.css?",
"Allow: /core/*.js$",
"Allow: /core/*.js?",
"Allow: /core/*.gif",
"Allow: /core/*.jpg",
"Allow: /core/*.jpeg",
"Allow: /core/*.png",
"Allow: /core/*.svg",
"Allow: /profiles/*.css$",
"Allow: /profiles/*.css?",
"Allow: /profiles/*.js$",
"Allow: /profiles/*.js?",
"Allow: /profiles/*.gif"
]
},
{
"id": "llms_txt",
"url": "https://www.ldi.nrw.de/llms.txt",
"label": "llms.txt",
"reason": "http_error",
"status": "missing",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 84,
"http_status": 404,
"relevant_lines": []
},
{
"id": "ai_txt",
"url": "https://www.ldi.nrw.de/.well-known/ai.txt",
"label": "AI Policy",
"reason": "http_error",
"status": "missing",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 82,
"http_status": 404,
"relevant_lines": []
},
{
"id": "ai_policy_txt",
"url": "https://www.ldi.nrw.de/.well-known/ai-policy.txt",
"label": "AI Policy",
"reason": "http_error",
"status": "missing",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 77,
"http_status": 404,
"relevant_lines": []
},
{
"id": "ward_txt",
"url": "https://www.ldi.nrw.de/.well-known/ward.txt",
"label": "WARD Policy",
"reason": "http_error",
"status": "missing",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 114,
"http_status": 404,
"relevant_lines": []
}
],
"origin": "https://www.ldi.nrw.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.ldi.nrw.de/ads.txt",
"label": "ads.txt",
"reason": "http_error",
"status": "missing",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 143,
"http_status": 404,
"ads_txt_policy": [],
"relevant_lines": [],
"sellers_json_policy": []
},
{
"id": "app_ads_txt",
"url": "https://www.ldi.nrw.de/app-ads.txt",
"label": "app-ads.txt",
"reason": "http_error",
"status": "missing",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 78,
"http_status": 404,
"ads_txt_policy": [],
"relevant_lines": [],
"sellers_json_policy": []
},
{
"id": "sellers_json",
"url": "https://www.ldi.nrw.de/sellers.json",
"label": "sellers.json",
"reason": "http_error",
"status": "missing",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 157,
"http_status": 404,
"ads_txt_policy": [],
"relevant_lines": [],
"sellers_json_policy": []
}
],
"origin": "https://www.ldi.nrw.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.ldi.nrw.de/.well-known/security.txt",
"label": "security.txt",
"reason": "",
"status": "found",
"body_size": 347,
"truncated": false,
"body_sha256": "4389a18242bc1c77cab747d4c7f8d2860320b177f4fe0d899810c1c21775f8cf",
"duration_ms": 84,
"http_status": 200,
"relevant_lines": [
"Contact: mailto:cert@it.nrw.de",
"Expires: 2027-01-01T10:00:00.000Z",
"Encryption: https://www.cert.nrw.de/files/CERT%20NRW_0x212C0843_public.asc",
"Preferred-Languages: de,en",
"Canonical: https://www.cert.nrw.de/.well-known/security.txt",
"Policy: https://www.cert.nrw.de/files/cert_nrw_responsible_disclosure_policy_en.pdf",
"Hiring: https://www.it.nrw/karriere"
],
"security_txt_policy": {
"field_count": 7,
"contact_count": 1,
"expires_values": [
"2027-01-01T10:00:00.000Z"
],
"fields_present": [
"canonical",
"contact",
"encryption",
"expires",
"hiring",
"policy",
"preferred-languages"
],
"policy_present": true,
"contact_samples": [
"mailto:cert@it.nrw.de"
],
"expires_present": true,
"canonical_present": true,
"encryption_present": true,
"preferred_languages": [
"de,en"
]
}
},
{
"id": "security_txt_legacy",
"url": "https://www.ldi.nrw.de/security.txt",
"label": "security.txt legacy",
"reason": "http_error",
"status": "missing",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 85,
"http_status": 404,
"relevant_lines": [],
"security_txt_policy": []
}
],
"origin": "https://www.ldi.nrw.de",
"schema": "https://saferpage.de/schemas/security-trust-policy-evidence.v1",
"status": "checked",
"metrics": {
"file_count": 2,
"field_count": 7,
"contact_count": 1,
"found_file_count": 1,
"preferred_well_known_found": 1
},
"summary": "1 von 2 security.txt-Ziel(en) gefunden; 1 Kontaktfeld(er), 7 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": 7,
"contact_count": 1,
"fields_present": [
"canonical",
"contact",
"encryption",
"expires",
"hiring",
"policy",
"preferred-languages"
],
"policy_present": true,
"expires_present": true,
"encryption_present": true,
"security_txt_found": true,
"preferred_well_known_found": true
},
"site_coverage_analysis": {
"color": "orange",
"pages": [
{
"url": "https://www.ldi.nrw.de/31_Taetigkeitsbericht_LDI_NRW",
"path": "/31_Taetigkeitsbericht_LDI_NRW",
"text": "© Landtag NRW/Meyer Datenschutzbeauftragte legt Bericht vor – und warnt vor Dat",
"source": "homepage_link",
"category": "datenschutz",
"priority": 100
},
{
"url": "https://www.ldi.nrw.de/Chatkontrolle_Trilog",
"path": "/Chatkontrolle_Trilog",
"text": "© DSK Datenschutzkonferenz fordert EU-Gesetzgeber zur endgültigen Absage an die",
"source": "homepage_link",
"category": "datenschutz",
"priority": 100
},
{
"url": "https://www.ldi.nrw.de/Digital_Fitness_Check",
"path": "/Digital_Fitness_Check",
"text": "© DSK Digital Fitness Check: Datenschutzkonferenz schlägt Anpassungen der DS-GV",
"source": "homepage_link",
"category": "datenschutz",
"priority": 100
},
{
"url": "https://www.ldi.nrw.de/OH-Mietinteressenten",
"path": "/OH-Mietinteressenten",
"text": "© iStock/alvarez Welche Angaben dürfen Vermieter*innen von potentiellen Mieter*",
"source": "homepage_link",
"category": "datenschutz",
"priority": 100
},
{
"url": "https://www.ldi.nrw.de/Umfrage_Bitkom",
"path": "/Umfrage_Bitkom",
"text": "Bildagentur PantherMedia / peshkova 25.02.2026 „Umfrage zeigt: Unternehmen brauc",
"source": "homepage_link",
"category": "datenschutz",
"priority": 100
},
{
"url": "https://www.ldi.nrw.de/Videoueberwachung_Karte",
"path": "/Videoueberwachung_Karte",
"text": "© PantherMedia/Denniro Was gilt für die private Videoüberwachung? Datenschutzbe",
"source": "homepage_link",
"category": "datenschutz",
"priority": 100
},
{
"url": "https://www.ldi.nrw.de/Zertifizierung_TUEV",
"path": "/Zertifizierung_TUEV",
"text": "© pantherMedia / Melpomene LDI NRW treibt Datenschutz-Zertifizierung weiter vor",
"source": "homepage_link",
"category": "datenschutz",
"priority": 100
},
{
"url": "https://www.ldi.nrw.de/datenschutz",
"path": "/datenschutz",
"text": "Datenschutz",
"source": "homepage_link",
"category": "datenschutz",
"priority": 100
},
{
"url": "https://www.ldi.nrw.de/datenschutz/bildung-und-forschung",
"path": "/datenschutz/bildung-und-forschung",
"text": "Bildung und Forschung",
"source": "homepage_link",
"category": "datenschutz",
"priority": 100
},
{
"url": "https://www.ldi.nrw.de/datenschutz/datenschutzbeauftragte",
"path": "/datenschutz/datenschutzbeauftragte",
"text": "Datenschutzbeauftragte",
"source": "homepage_link",
"category": "datenschutz",
"priority": 100
},
{
"url": "https://www.ldi.nrw.de/datenschutz/internationaler-datenverkehr",
"path": "/datenschutz/internationaler-datenverkehr",
"text": "Internationaler Datenverkehr",
"source": "homepage_link",
"category": "datenschutz",
"priority": 100
},
{
"url": "https://www.ldi.nrw.de/datenschutz/internationaler-datenverkehr/allgemeinen-grundsaetze",
"path": "/datenschutz/internationaler-datenverkehr/allgemeinen-grundsaetze",
"text": "Allgemeine Grundsätze",
"source": "homepage_link",
"category": "datenschutz",
"priority": 100
}
],
"score": 67,
"status": "auffällig",
"summary": "30 interne Linkziele erkannt (1 aus Sitemap), 4 priorisierte Unterseite(n) zusätzlich abgerufen.",
"findings": [
{
"id": "important_pages_not_discovered",
"title": "Wichtige Betreiberseiten nicht vollständig in der Linkstruktur gefunden",
"public": true,
"category": "crawl",
"severity": "warning"
},
{
"id": "privacy_policy_required_items_missing",
"title": "Datenschutzerklärung deckt zentrale Bausteine nicht vollständig ab",
"public": true,
"missing": [
"Zwecke der Verarbeitung",
"Speicherfrist / Löschung",
"Empfänger / Auftragsverarbeiter",
"Cookies / Tracking",
"Widerruf / Opt-out",
"Drittlandtransfer"
],
"category": "privacy",
"severity": "warning"
},
{
"id": "privacy_policy_tracking_disclosure_gap",
"title": "Cookies/Tracking in der Datenschutzerklärung nicht klar erkannt",
"public": true,
"category": "privacy",
"severity": "warning"
},
{
"id": "privacy_policy_provider_disclosure_gap",
"title": "Erkannte Anbieter fehlen in der Datenschutzerklärung",
"public": true,
"category": "privacy",
"severity": "warning",
"missing_providers": [
"Google Analytics"
]
}
],
"robots_ok": true,
"categories": {
"datenschutz": 30
},
"sample_limit": 4,
"sampled_count": 4,
"sampled_pages": [
{
"ok": true,
"url": "https://www.ldi.nrw.de/31_Taetigkeitsbericht_LDI_NRW",
"path": "/31_Taetigkeitsbericht_LDI_NRW",
"audit": {
"form_count": 3,
"finding_ids": [
"operator_identity_unclear",
"consent_no_reject_option"
],
"cookie_count": 0,
"imprint_found": true,
"consent_hint_found": true,
"reject_option_found": false,
"privacy_policy_found": true,
"tracking_script_count": 0,
"pre_consent_cookie_count": 0,
"pre_consent_tracking_cookie_count": 0
},
"forms": 3,
"title": "Landesdatenschutzbeauftragte legt Tätigkeitsbericht vor – und warnt vor Datennutzung um jeden Preis | LDI - Landesbeauft",
"status": 200,
"category": "datenschutz",
"duration_ms": 123,
"privacy_hint": true,
"privacy_policy_audit": {
"url": "https://www.ldi.nrw.de/31_Taetigkeitsbericht_LDI_NRW",
"color": "orange",
"found": [
"Verantwortlicher / Anbieter",
"Kontakt / Datenschutzkontakt",
"Rechtsgrundlagen",
"Betroffenenrechte",
"Beschwerde bei Aufsichtsbehörde",
"Stand / Aktualitätsdatum",
"Datenschutzkontakt / DPO-Hinweis",
"Verständliche Satzlänge"
],
"score": 57,
"checks": [
{
"id": "controller_identity",
"found": true,
"label": "Verantwortlicher / Anbieter"
},
{
"id": "contact",
"found": true,
"label": "Kontakt / Datenschutzkontakt"
},
{
"id": "purposes",
"found": false,
"label": "Zwecke der Verarbeitung"
},
{
"id": "legal_basis",
"found": true,
"label": "Rechtsgrundlagen"
},
{
"id": "rights",
"found": true,
"label": "Betroffenenrechte"
},
{
"id": "retention",
"found": false,
"label": "Speicherfrist / Löschung"
},
{
"id": "recipients",
"found": false,
"label": "Empfänger / Auftragsverarbeiter"
},
{
"id": "cookies_tracking",
"found": false,
"label": "Cookies / Tracking"
},
{
"id": "withdrawal",
"found": false,
"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": true,
"label": "Stand / Aktualitätsdatum",
"detail": "2026-04-17"
},
{
"id": "dpo_contact",
"found": true,
"label": "Datenschutzkontakt / DPO-Hinweis"
},
{
"id": "readability",
"found": true,
"label": "Verständliche Satzlänge",
"detail": "20.8 Wörter/Satz"
}
],
"status": "auffällig",
"missing": [
"Zwecke der Verarbeitung",
"Speicherfrist / Löschung",
"Empfänger / Auftragsverarbeiter",
"Cookies / Tracking",
"Widerruf / Opt-out",
"Drittlandtransfer"
],
"summary": "8 von 14 zentralen Datenschutz-Bausteinen erkannt.",
"findings": [],
"available": true,
"freshness": {
"stale": false,
"age_days": 62,
"last_updated": "2026-04-17",
"update_date_found": true
},
"word_count": 1250,
"readability": {
"hard_to_read": false,
"sentence_count": 60,
"avg_sentence_words": 20.8
},
"missing_count": 6,
"dpo_contact_found": true
}
},
{
"ok": true,
"url": "https://www.ldi.nrw.de/Chatkontrolle_Trilog",
"path": "/Chatkontrolle_Trilog",
"audit": {
"form_count": 3,
"finding_ids": [
"operator_identity_unclear"
],
"cookie_count": 0,
"imprint_found": true,
"consent_hint_found": false,
"reject_option_found": false,
"privacy_policy_found": true,
"tracking_script_count": 0,
"pre_consent_cookie_count": 0,
"pre_consent_tracking_cookie_count": 0
},
"forms": 3,
"title": "Datenschutzkonferenz fordert EU-Gesetzgeber zur endgültigen Absage an die Chatkontrolle auf | LDI - Landesbeauftragte fü",
"status": 200,
"category": "datenschutz",
"duration_ms": 105,
"privacy_hint": true,
"privacy_policy_audit": {
"url": "https://www.ldi.nrw.de/Chatkontrolle_Trilog",
"color": "red",
"found": [
"Kontakt / Datenschutzkontakt",
"Rechtsgrundlagen",
"Beschwerde bei Aufsichtsbehörde",
"Stand / Aktualitätsdatum",
"Datenschutzkontakt / DPO-Hinweis"
],
"score": 30,
"checks": [
{
"id": "controller_identity",
"found": false,
"label": "Verantwortlicher / Anbieter"
},
{
"id": "contact",
"found": true,
"label": "Kontakt / Datenschutzkontakt"
},
{
"id": "purposes",
"found": false,
"label": "Zwecke der Verarbeitung"
},
{
"id": "legal_basis",
"found": true,
"label": "Rechtsgrundlagen"
},
{
"id": "rights",
"found": false,
"label": "Betroffenenrechte"
},
{
"id": "retention",
"found": false,
"label": "Speicherfrist / Löschung"
},
{
"id": "recipients",
"found": false,
"label": "Empfänger / Auftragsverarbeiter"
},
{
"id": "cookies_tracking",
"found": false,
"label": "Cookies / Tracking"
},
{
"id": "withdrawal",
"found": false,
"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": true,
"label": "Stand / Aktualitätsdatum",
"detail": "2026-05-06"
},
{
"id": "dpo_contact",
"found": true,
"label": "Datenschutzkontakt / DPO-Hinweis"
},
{
"id": "readability",
"found": false,
"label": "Verständliche Satzlänge",
"detail": "42.5 Wörter/Satz"
}
],
"status": "kritisch",
"missing": [
"Verantwortlicher / Anbieter",
"Zwecke der Verarbeitung",
"Betroffenenrechte",
"Speicherfrist / Löschung",
"Empfänger / Auftragsverarbeiter",
"Cookies / Tracking",
"Widerruf / Opt-out",
"Drittlandtransfer",
"Verständliche Satzlänge"
],
"summary": "5 von 14 zentralen Datenschutz-Bausteinen erkannt.",
"findings": [
{
"id": "privacy_policy_hard_to_read",
"title": "Datenschutzerklärung ist schwer lesbar",
"public": true,
"category": "privacy",
"severity": "info",
"avg_sentence_words": 42.5
}
],
"available": true,
"freshness": {
"stale": false,
"age_days": 43,
"last_updated": "2026-05-06",
"update_date_found": true
},
"word_count": 637,
"readability": {
"hard_to_read": true,
"sentence_count": 15,
"avg_sentence_words": 42.5
},
"missing_count": 9,
"dpo_contact_found": true
}
},
{
"ok": true,
"url": "https://www.ldi.nrw.de/Digital_Fitness_Check",
"path": "/Digital_Fitness_Check",
"audit": {
"form_count": 3,
"finding_ids": [
"operator_identity_unclear"
],
"cookie_count": 0,
"imprint_found": true,
"consent_hint_found": false,
"reject_option_found": false,
"privacy_policy_found": true,
"tracking_script_count": 0,
"pre_consent_cookie_count": 0,
"pre_consent_tracking_cookie_count": 0
},
"forms": 3,
"title": "Digital Fitness Check: Datenschutzkonferenz schlägt Anpassungen der DS-GVO vor | LDI - Landesbeauftragte für Datenschutz",
"status": 200,
"category": "datenschutz",
"duration_ms": 103,
"privacy_hint": true,
"privacy_policy_audit": {
"url": "https://www.ldi.nrw.de/Digital_Fitness_Check",
"color": "orange",
"found": [
"Verantwortlicher / Anbieter",
"Kontakt / Datenschutzkontakt",
"Rechtsgrundlagen",
"Betroffenenrechte",
"Beschwerde bei Aufsichtsbehörde",
"Stand / Aktualitätsdatum",
"Datenschutzkontakt / DPO-Hinweis",
"Verständliche Satzlänge"
],
"score": 57,
"checks": [
{
"id": "controller_identity",
"found": true,
"label": "Verantwortlicher / Anbieter"
},
{
"id": "contact",
"found": true,
"label": "Kontakt / Datenschutzkontakt"
},
{
"id": "purposes",
"found": false,
"label": "Zwecke der Verarbeitung"
},
{
"id": "legal_basis",
"found": true,
"label": "Rechtsgrundlagen"
},
{
"id": "rights",
"found": true,
"label": "Betroffenenrechte"
},
{
"id": "retention",
"found": false,
"label": "Speicherfrist / Löschung"
},
{
"id": "recipients",
"found": false,
"label": "Empfänger / Auftragsverarbeiter"
},
{
"id": "cookies_tracking",
"found": false,
"label": "Cookies / Tracking"
},
{
"id": "withdrawal",
"found": false,
"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": true,
"label": "Stand / Aktualitätsdatum",
"detail": "2026-03-17"
},
{
"id": "dpo_contact",
"found": true,
"label": "Datenschutzkontakt / DPO-Hinweis"
},
{
"id": "readability",
"found": true,
"label": "Verständliche Satzlänge",
"detail": "26.5 Wörter/Satz"
}
],
"status": "auffällig",
"missing": [
"Zwecke der Verarbeitung",
"Speicherfrist / Löschung",
"Empfänger / Auftragsverarbeiter",
"Cookies / Tracking",
"Widerruf / Opt-out",
"Drittlandtransfer"
],
"summary": "8 von 14 zentralen Datenschutz-Bausteinen erkannt.",
"findings": [],
"available": true,
"freshness": {
"stale": false,
"age_days": 93,
"last_updated": "2026-03-17",
"update_date_found": true
},
"word_count": 982,
"readability": {
"hard_to_read": false,
"sentence_count": 37,
"avg_sentence_words": 26.5
},
"missing_count": 6,
"dpo_contact_found": true
}
},
{
"ok": true,
"url": "https://www.ldi.nrw.de/OH-Mietinteressenten",
"path": "/OH-Mietinteressenten",
"audit": {
"form_count": 3,
"finding_ids": [
"operator_identity_unclear"
],
"cookie_count": 0,
"imprint_found": true,
"consent_hint_found": false,
"reject_option_found": false,
"privacy_policy_found": true,
"tracking_script_count": 0,
"pre_consent_cookie_count": 0,
"pre_consent_tracking_cookie_count": 0
},
"forms": 3,
"title": "Welche Angaben dürfen Vermieter*innen von potentiellen Mieter*innen verlangen? Datenschutzbeauftragte legen einheitliche",
"status": 200,
"category": "datenschutz",
"duration_ms": 95,
"privacy_hint": true,
"privacy_policy_audit": {
"url": "https://www.ldi.nrw.de/OH-Mietinteressenten",
"color": "orange",
"found": [
"Kontakt / Datenschutzkontakt",
"Rechtsgrundlagen",
"Betroffenenrechte",
"Beschwerde bei Aufsichtsbehörde",
"Stand / Aktualitätsdatum",
"Datenschutzkontakt / DPO-Hinweis",
"Verständliche Satzlänge"
],
"score": 50,
"checks": [
{
"id": "controller_identity",
"found": false,
"label": "Verantwortlicher / Anbieter"
},
{
"id": "contact",
"found": true,
"label": "Kontakt / Datenschutzkontakt"
},
{
"id": "purposes",
"found": false,
"label": "Zwecke der Verarbeitung"
},
{
"id": "legal_basis",
"found": true,
"label": "Rechtsgrundlagen"
},
{
"id": "rights",
"found": true,
"label": "Betroffenenrechte"
},
{
"id": "retention",
"found": false,
"label": "Speicherfrist / Löschung"
},
{
"id": "recipients",
"found": false,
"label": "Empfänger / Auftragsverarbeiter"
},
{
"id": "cookies_tracking",
"found": false,
"label": "Cookies / Tracking"
},
{
"id": "withdrawal",
"found": false,
"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": true,
"label": "Stand / Aktualitätsdatum",
"detail": "2026-03-19"
},
{
"id": "dpo_contact",
"found": true,
"label": "Datenschutzkontakt / DPO-Hinweis"
},
{
"id": "readability",
"found": true,
"label": "Verständliche Satzlänge",
"detail": "24.9 Wörter/Satz"
}
],
"status": "auffällig",
"missing": [
"Verantwortlicher / Anbieter",
"Zwecke der Verarbeitung",
"Speicherfrist / Löschung",
"Empfänger / Auftragsverarbeiter",
"Cookies / Tracking",
"Widerruf / Opt-out",
"Drittlandtransfer"
],
"summary": "7 von 14 zentralen Datenschutz-Bausteinen erkannt.",
"findings": [],
"available": true,
"freshness": {
"stale": false,
"age_days": 91,
"last_updated": "2026-03-19",
"update_date_found": true
},
"word_count": 873,
"readability": {
"hard_to_read": false,
"sentence_count": 35,
"avg_sentence_words": 24.9
},
"missing_count": 7,
"dpo_contact_found": true
}
}
],
"robots_checked": true,
"sitemap_sources": [
"https://www.ldi.nrw.de/sitemap.xml"
],
"sitemap_available": true,
"sitemap_url_count": 1,
"homepage_link_count": 173,
"internal_link_count": 30,
"privacy_policy_audit": {
"url": "https://www.ldi.nrw.de/31_Taetigkeitsbericht_LDI_NRW",
"color": "orange",
"found": [
"Verantwortlicher / Anbieter",
"Kontakt / Datenschutzkontakt",
"Rechtsgrundlagen",
"Betroffenenrechte",
"Beschwerde bei Aufsichtsbehörde",
"Stand / Aktualitätsdatum",
"Datenschutzkontakt / DPO-Hinweis",
"Verständliche Satzlänge"
],
"score": 57,
"checks": [
{
"id": "controller_identity",
"found": true,
"label": "Verantwortlicher / Anbieter"
},
{
"id": "contact",
"found": true,
"label": "Kontakt / Datenschutzkontakt"
},
{
"id": "purposes",
"found": false,
"label": "Zwecke der Verarbeitung"
},
{
"id": "legal_basis",
"found": true,
"label": "Rechtsgrundlagen"
},
{
"id": "rights",
"found": true,
"label": "Betroffenenrechte"
},
{
"id": "retention",
"found": false,
"label": "Speicherfrist / Löschung"
},
{
"id": "recipients",
"found": false,
"label": "Empfänger / Auftragsverarbeiter"
},
{
"id": "cookies_tracking",
"found": false,
"label": "Cookies / Tracking"
},
{
"id": "withdrawal",
"found": false,
"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": true,
"label": "Stand / Aktualitätsdatum",
"detail": "2026-04-17"
},
{
"id": "dpo_contact",
"found": true,
"label": "Datenschutzkontakt / DPO-Hinweis"
},
{
"id": "readability",
"found": true,
"label": "Verständliche Satzlänge",
"detail": "20.8 Wörter/Satz"
}
],
"status": "auffällig",
"missing": [
"Zwecke der Verarbeitung",
"Speicherfrist / Löschung",
"Empfänger / Auftragsverarbeiter",
"Cookies / Tracking",
"Widerruf / Opt-out",
"Drittlandtransfer"
],
"summary": "8 von 14 zentralen Datenschutz-Bausteinen erkannt.",
"findings": [],
"available": true,
"freshness": {
"stale": false,
"age_days": 62,
"last_updated": "2026-04-17",
"update_date_found": true
},
"word_count": 1250,
"readability": {
"hard_to_read": false,
"sentence_count": 60,
"avg_sentence_words": 20.8
},
"missing_count": 6,
"dpo_contact_found": true
},
"sitemap_source_count": 1,
"provider_disclosure_audit": {
"color": "red",
"found": [],
"score": 0,
"checks": [
{
"id": "analytics_google_analytics",
"found": false,
"category": "analytics",
"evidence": [
"g-NW12UE"
],
"keywords": [
"google analytics",
"analytics.google",
"_ga",
"ga4",
"gtag"
],
"provider": "Google Analytics",
"category_label": "Tracking-ID"
}
],
"status": "kritisch",
"missing": [
"Google Analytics"
],
"summary": "0 von 1 technisch erkannten Anbieter(n) wurden in der Datenschutzerklärung erwähnt.",
"available": true,
"missing_count": 1,
"detected_count": 1,
"mentioned_count": 0
},
"important_categories_found": [
"datenschutz"
],
"sampled_tracking_page_count": 0,
"sampled_form_privacy_gap_count": 0,
"sitemap_candidate_source_count": 1
},
"page_analysis": {
"h1": [],
"h2": [
"Social Media Einstellungen",
"<strong>Videoüberwachung von Spielhallen: Landesdatenschutzbeauftragte muss korrigierend eingreifen </strong>",
"Aus diesem Rohfeld wird im Report keine zusätzliche Scan-Feststellung abgeleitet; Betreiberkontext und Umsetzungshinweise stehen auf separaten Seiten.",
"<strong>Was gilt für die private Videoüberwachung? Datenschutzbeauftragte startet erfolgreich Aufklärungsaktion</strong>",
"<strong>Datenschutzkonferenz fordert EU-Gesetzgeber zur endgültigen Absage an die Chatkontrolle auf</strong>",
"<strong>Datenpannenmanagement an Kliniken geprüft: Hohe Standards, aber auch Verbesserung nötig</strong>",
"Datenschutzbeauftragte legt Bericht vor – und warnt vor Datennutzung um jeden Preis ",
"<strong>Welche Angaben dürfen Vermieter*innen von potentiellen Mieter*innen verlangen? Datenschutzbeauftragte legen einheitliche Regeln fest</strong>",
"<strong>Digital Fitness Check: Datenschutzkonferenz schlägt Anpassungen der DS-GVO vor</strong>",
"Informationsfreiheitsbeauftragte fordern Stärkung demokratischer Teilhaberechte"
],
"title": "Aktuelles | LDI - Landesbeauftragte für Datenschutz und Informationsfreiheit Nordrhein-Westfalen",
"keywords": [
[
"panthermedia",
30
],
[
"datenschutz",
17
],
[
"informationsfreiheit",
16
],
[
"landesbeauftragte",
15
],
[
"innen",
15
],
[
"datenschutzbeauftragte",
10
],
[
"videoüberwachung",
8
],
[
"daten",
8
],
[
"informationen",
7
],
[
"aktuelles",
6
]
],
"language": "de",
"description": "",
"favicon_url": "https://www.ldi.nrw.de/themes/nrw/nrw_base_theme/images/icon/apple-touch-icon-57x57.png",
"link_counts": {
"external": 7,
"internal": 166
},
"preview_image": "/cache/screenshots/ldi.nrw.de-160x150-474e499868d6a9974f.png",
"screenshot_url": "/cache/screenshots/ldi.nrw.de-160x150-474e499868d6a9974f.png",
"external_scripts": [],
"browser_final_url": "https://www.ldi.nrw.de/",
"meta_preview_image": "",
"screenshot_renderer": "playwright-chromium",
"external_link_targets": [
{
"host": "de.pinterest.com",
"count": 1,
"examples": [
{
"href": "https://de.pinterest.com/",
"text": "Pinterest"
}
],
"nofollow": 0,
"strength": "strong",
"follow_count": 1
},
{
"host": "facebook.com",
"count": 1,
"examples": [
{
"href": "https://www.facebook.com",
"text": "Facebook"
}
],
"nofollow": 0,
"strength": "strong",
"follow_count": 1
},
{
"host": "flickr.com",
"count": 1,
"examples": [
{
"href": "https://www.flickr.com/",
"text": "Flickr"
}
],
"nofollow": 0,
"strength": "weak",
"follow_count": 1
},
{
"host": "instagram.com",
"count": 1,
"examples": [
{
"href": "https://instagram.com/",
"text": "Instagram"
}
],
"nofollow": 0,
"strength": "strong",
"follow_count": 1
},
{
"host": "twitter.com",
"count": 1,
"examples": [
{
"href": "https://twitter.com/",
"text": "X/Twitter"
}
],
"nofollow": 0,
"strength": "strong",
"follow_count": 1
},
{
"host": "vimeo.com",
"count": 1,
"examples": [
{
"href": "https://vimeo.com/",
"text": "Vimeo"
}
],
"nofollow": 0,
"strength": "weak",
"follow_count": 1
},
{
"host": "youtube.com",
"count": 1,
"examples": [
{
"href": "https://www.youtube.com/",
"text": "Youtube"
}
],
"nofollow": 0,
"strength": "weak",
"follow_count": 1
}
]
},
"browser_analysis": {
"cookies": {
"items": [],
"total": 0,
"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_keystroke_listener_signals",
"count": 11,
"title": "Viele Tastatur-/Eingabe-Listener im Browser erkannt",
"public": true,
"category": "privacy",
"severity": "info"
}
],
"renderer": "playwright-chromium",
"final_url": "https://www.ldi.nrw.de/",
"consent_ui": {
"accept_controls": [],
"accept_max_area": 0,
"reject_controls": [],
"reject_max_area": 0,
"settings_controls": [],
"first_layer_summary": "Akzeptieren 0 / Ablehnen 0 / Einstellungen 0",
"cookie_context_found": true,
"reject_less_prominent": false,
"visible_control_count": 28,
"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": 0,
"request_count": 46,
"sec_gpc_header": true,
"navigator_value": true,
"contacted_domains": [
{
"host": "ldi.nrw.de",
"count": 46,
"category": "other",
"provider": "ldi.nrw.de",
"third_party": false,
"category_label": "Sonstige",
"resource_types": {
"font": 3,
"image": 33,
"script": 5,
"document": 1,
"stylesheet": 4
}
}
],
"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": false,
"storage": {
"total": 0,
"tracking_key_hints": [],
"local_storage_total": 0,
"session_storage_total": 0
},
"clicked_text": "",
"accept_clicked": false,
"accept_available": false,
"contacted_domains": [],
"contacted_domain_count": 0,
"new_domains_after_accept": [],
"privacy_relevant_domains": [],
"third_party_domain_count": 0,
"cookie_count_after_accept": 0,
"cookie_count_before_accept": 0,
"request_count_after_accept": 0,
"storage_count_after_accept": 0,
"request_count_before_accept": 0,
"new_cookie_count_after_accept": 0,
"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": 46,
"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": "ldi.nrw.de",
"count": 46,
"category": "other",
"provider": "ldi.nrw.de",
"third_party": false,
"category_label": "Sonstige",
"resource_types": {
"font": 3,
"image": 33,
"script": 5,
"document": 1,
"stylesheet": 4
}
}
],
"privacy_api_metrics": {
"api_calls": {
"keyboard_input_listener_count": 11
},
"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": 11
},
"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": 100,
"href": "/datenschutz",
"left": 235,
"text": "Datenschutz",
"width": 117,
"height": 72,
"category": "privacy_notice"
},
{
"tag": "a",
"top": 100,
"href": "/kontakt",
"left": 589,
"text": "Kontakt",
"width": 123,
"height": 72,
"category": "contact"
},
{
"tag": "a",
"top": 231,
"href": "/pruefung_spielhallen",
"left": 0,
"text": "© PantherMedia/Denniro Videoüberwachung von Spielhallen: Landesdatenschutzbeauftragte muss",
"width": 1024,
"height": 374,
"category": "privacy_notice"
},
{
"tag": "a",
"top": 691,
"href": "/ueber-uns",
"left": 0,
"text": "Über uns Bettina Gayk ist die Landesbeauftragte für Datenschutz und Informationsfreiheit i",
"width": 512,
"height": 336,
"category": "privacy_notice"
}
],
"available": true,
"sample_count": 4,
"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": 3
},
"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": 0,
"domain_count": 1,
"request_count": 46,
"storage_total": 0,
"new_cookie_count": 0,
"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": 0,
"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": "nicht ausgeführt",
"evidence": "",
"risk_level": "niedrig",
"cookie_count": 0,
"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": "gpc",
"label": "GPC-Aufruf",
"status": "aktiv",
"evidence": "Navigator-GPC und Sec-GPC wurden im gesonderten Browserlauf gesetzt.",
"risk_level": "niedrig",
"cookie_count": 0,
"domain_count": 1,
"request_count": 46,
"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": "yellow",
"score": 88,
"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": false,
"count": 11,
"label": "Tastatur-/Eingabe-Listener",
"detail": "11 Tastatur-/Input-Listener, 32 Interaktions-Listener, 0 MutationObserver."
}
],
"status": "prüfen",
"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": 11
},
"summary": "1 Fingerprinting-/Session-Replay-Hinweis(e) aus dem Browserlauf.",
"findings": [
{
"id": "browser_keystroke_listener_signals",
"count": 11,
"title": "Viele Tastatur-/Eingabe-Listener im Browser erkannt",
"public": true,
"category": "privacy",
"severity": "info"
}
],
"finding_count": 1,
"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": [],
"score": 100,
"status": "unauffällig",
"summary": "0 Pixel-/Bildtracking-Hinweis(e), 0 Beacon-/Telemetry-Hinweis(e), 0 Link-Ping(s).",
"findings": [],
"pixel_count": 0,
"link_ping_count": 0,
"telemetry_count": 0,
"beacon_api_count": 0,
"third_party_count": 0,
"fetch_keepalive_count": 0,
"privacy_relevant_count": 0,
"beacon_code_reference_count": 0,
"fetch_keepalive_reference_count": 0
}
},
"privacy_analysis": {
"cookies": {
"items": [],
"total": 0,
"tracking": [],
"pre_consent": [],
"missing_secure": [],
"missing_samesite": [],
"pre_consent_tracking": [],
"pre_consent_nonessential": []
},
"findings": [],
"tracking_ids": [
{
"type": "google_analytics_4",
"value": "g-NW12UE",
"provider": "Google Analytics 4"
}
],
"tracking_scripts": [],
"consent_hint_found": false,
"privacy_policy_hint_found": true
},
"consent_audit": {
"color": "orange",
"score": 60,
"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": false,
"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": true,
"label": "Ablehnen im sichtbaren Banner",
"detail": "Sichtbare Banner-Controls: Akzeptieren 0, Ablehnen 0, Einstellungen 0."
},
{
"id": "browser_settings_visible",
"ok": true,
"label": "Einstellungen im sichtbaren Banner",
"detail": "Sichtbare Banner-Controls: Akzeptieren 0, 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": "google_default_restrictive",
"ok": false,
"label": "Google Consent Default restriktiv",
"detail": "Google-Tags brauchen vor dem ersten Laden restriktive Consent-Defaults."
},
{
"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: nicht ausgefuehrt, neue Requests 0, neue Cookies 0, 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": "auffällig",
"summary": "Consent ist teilweise erkennbar; einzelne Punkte bleiben Betreiberkontext.",
"evidence": [
"0 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 0, 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: nicht ausgefuehrt, neue Requests 0, neue Cookies 0, 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": [
{
"kind": "google_consent",
"level": "hoch",
"source": "Google",
"target": "Google Consent Defaults",
"recipes": [
{
"tool": "Google Consent Mode v2"
},
{
"tool": "Google Tag Manager"
},
{
"tool": "Cookiebot"
},
{
"tool": "Usercentrics"
},
{
"tool": "OneTrust"
}
],
"category": "tag_manager",
"evidence": "Google-Tags erkannt, aber kein Consent-Default vor dem ersten Tag.",
"category_label": "Tag-Manager"
}
],
"summary": "1 Blockier-/Consent-Maßnahme(n) abgeleitet: 1 hoch, 0 mittel.",
"available": true,
"high_count": 1,
"total_count": 1,
"type_counts": {
"google_consent": 1
},
"medium_count": 0
},
"tcf_api_found": false,
"cookiebot_found": false,
"accept_test_enabled": false,
"browser_cookie_count": 0,
"accept_button_clicked": false,
"browser_storage_count": 0,
"reject_button_clicked": false,
"reject_less_prominent": false,
"tcf_tc_string_present": false,
"tracking_script_count": 0,
"accept_button_available": false,
"reject_button_available": false,
"reject_prominence_ratio": 0,
"pre_consent_cookie_count": 0,
"pre_consent_cookie_names": [],
"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": 0,
"browser_cookie_context_found": true,
"browser_reject_control_count": 0,
"gpc_third_party_cookie_count": 0,
"post_accept_new_cookie_count": 0,
"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": [],
"score": 100,
"total": 0,
"status": "unauffällig",
"summary": "0 Cookie(s) inventarisiert: 0 Tracking-/Werbe-Cookie(s), 0 Drittanbieter-Cookie(s), 0 langlebige Cookie(s), 0 sehr lange Laufzeit(en).",
"findings": [],
"categories": [],
"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": 0,
"pre_consent_count": 0,
"retention_classes": [],
"third_party_count": 0,
"missing_secure_count": 0,
"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": "orange",
"score": 52,
"checks": [
{
"ok": true,
"note": "",
"label": "HSTS",
"value": "max-age=31536000; preload",
"header": "strict-transport-security",
"present": true,
"purpose": "Erzwingt HTTPS nach dem ersten sicheren Aufruf.",
"severity": "warning"
},
{
"ok": true,
"note": "",
"label": "Content-Security-Policy",
"value": "default-src 'self' *.nrw.de; script-src 'self' 'unsafe-inline' 'unsafe-eval' *.nrw.de *.google.com *.youtube.com *.youtu.be *.twimg.com *.twitter.com twitter.com *.jwpcdn.com *.gstatic.com *.googleapis.com *.googlesy",
"header": "content-security-policy",
"present": true,
"purpose": "Begrenzt Skript-, Frame- und Ressourcenquellen im Browser.",
"severity": "warning"
},
{
"ok": true,
"note": "",
"label": "X-Frame-Options",
"value": "SAMEORIGIN",
"header": "x-frame-options",
"present": true,
"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": true,
"note": "",
"label": "Referrer-Policy",
"value": "strict-origin-when-cross-origin",
"header": "referrer-policy",
"present": true,
"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": "auffällig",
"missing": [
"Permissions-Policy",
"Cross-Origin-Opener-Policy",
"Cross-Origin-Resource-Policy",
"Cross-Origin-Embedder-Policy"
],
"summary": "5 von 9 wichtigen Security-Headern vorhanden, 5 korrekt bewertet. CSP wirksam mit 12 Direktive(n), 2 Warnung(en), 2 Hinweis(e).",
"findings": [
{
"id": "csp_unsafe_inline",
"title": "CSP erlaubt unsafe-inline für Skripte",
"public": true,
"category": "security_headers",
"severity": "warning"
},
{
"id": "csp_unsafe_eval",
"title": "CSP erlaubt eval-nahe Skriptausführung",
"public": true,
"category": "security_headers",
"severity": "warning"
},
{
"id": "csp_permissive_script_sources",
"title": "CSP erlaubt sehr breite Skriptquellen",
"public": true,
"sources": [
"*.nrw.de",
"*.google.com",
"*.youtube.com",
"*.youtu.be",
"*.twimg.com",
"*.twitter.com",
"*.jwpcdn.com",
"*.gstatic.com"
],
"category": "security_headers",
"severity": "info"
},
{
"id": "csp_missing_base_uri",
"title": "CSP ohne base-uri",
"public": true,
"category": "security_headers",
"severity": "info"
}
],
"ok_count": 5,
"weak_count": 0,
"csp_analysis": {
"color": "orange",
"score": 52,
"status": "auffällig",
"summary": "CSP wirksam mit 12 Direktive(n), 2 Warnung(en), 2 Hinweis(e).",
"enforced": true,
"findings": [
{
"id": "csp_unsafe_inline",
"title": "CSP erlaubt unsafe-inline für Skripte",
"public": true,
"category": "security_headers",
"severity": "warning"
},
{
"id": "csp_unsafe_eval",
"title": "CSP erlaubt eval-nahe Skriptausführung",
"public": true,
"category": "security_headers",
"severity": "warning"
},
{
"id": "csp_permissive_script_sources",
"title": "CSP erlaubt sehr breite Skriptquellen",
"public": true,
"sources": [
"*.nrw.de",
"*.google.com",
"*.youtube.com",
"*.youtu.be",
"*.twimg.com",
"*.twitter.com",
"*.jwpcdn.com",
"*.gstatic.com"
],
"category": "security_headers",
"severity": "info"
},
{
"id": "csp_missing_base_uri",
"title": "CSP ohne base-uri",
"public": true,
"category": "security_headers",
"severity": "info"
}
],
"available": true,
"directives": [
{
"name": "connect-src",
"value": "'self' *.nrw.de svc.webspellchecker.net",
"values": [
"'self'",
"*.nrw.de",
"svc.webspellchecker.net"
]
},
{
"name": "default-src",
"value": "'self' *.nrw.de",
"values": [
"'self'",
"*.nrw.de"
]
},
{
"name": "font-src",
"value": "data: *",
"values": [
"data:",
"*"
]
},
{
"name": "frame-ancestors",
"value": "'self' *.nrw.de *.facebook.com *.facebook.de *.twitter.com twitter.com *.google.com *.youtube.com *.youtu.be ytchannelembed.com",
"values": [
"'self'",
"*.nrw.de",
"*.facebook.com",
"*.facebook.de",
"*.twitter.com",
"twitter.com",
"*.google.com",
"*.youtube.com",
"*.youtu.be",
"ytchannelembed.com"
]
},
{
"name": "frame-src",
"value": "'self' *.nrw.de *.facebook.com *.facebook.de *.twitter.com twitter.com *.google.com *.youtube.com *.youtu.be ytchannelembed.com *.openstreetmap.org broschueren.nordrheinwestfalendirekt.de",
"values": [
"'self'",
"*.nrw.de",
"*.facebook.com",
"*.facebook.de",
"*.twitter.com",
"twitter.com",
"*.google.com",
"*.youtube.com",
"*.youtu.be",
"ytchannelembed.com",
"*.openstreetmap.org",
"broschueren.nordrheinwestfalendirekt.de"
]
},
{
"name": "img-src",
"value": "data: *",
"values": [
"data:",
"*"
]
},
{
"name": "media-src",
"value": "*",
"values": [
"*"
]
},
{
"name": "object-src",
"value": "'self'",
"values": [
"'self'"
]
},
{
"name": "script-src",
"value": "'self' 'unsafe-inline' 'unsafe-eval' *.nrw.de *.google.com *.youtube.com *.youtu.be *.twimg.com *.twitter.com twitter.com *.jwpcdn.com *.gstatic.com *.googleapis.com *.googlesyndication.com *.openstreetmap.org *.mozilla.",
"values": [
"'self'",
"'unsafe-inline'",
"'unsafe-eval'",
"*.nrw.de",
"*.google.com",
"*.youtube.com",
"*.youtu.be",
"*.twimg.com",
"*.twitter.com",
"twitter.com",
"*.jwpcdn.com",
"*.gstatic.com",
"*.googleapis.com",
"*.googlesyndication.com",
"*.openstreetmap.org",
"*.mozilla.org"
]
},
{
"name": "style-src",
"value": "'self' 'unsafe-inline' *.nrw.de *.twitter.com twitter.com *.facebook.com *.googleapis.com *.twimg.com *.cloudflare.com cdn.jsdelivr.net svc.webspellchecker.net",
"values": [
"'self'",
"'unsafe-inline'",
"*.nrw.de",
"*.twitter.com",
"twitter.com",
"*.facebook.com",
"*.googleapis.com",
"*.twimg.com",
"*.cloudflare.com",
"cdn.jsdelivr.net",
"svc.webspellchecker.net"
]
},
{
"name": "upgrade-insecure-requests",
"value": "",
"values": []
},
{
"name": "worker-src",
"value": "'self' *.nrw.de *.facebook.com *.facebook.de *.twitter.com twitter.com *.google.com *.youtube.com *.youtu.be ytchannelembed.com *.openstreetmap.org broschueren.nordrheinwestfalendirekt.de",
"values": [
"'self'",
"*.nrw.de",
"*.facebook.com",
"*.facebook.de",
"*.twitter.com",
"twitter.com",
"*.google.com",
"*.youtube.com",
"*.youtu.be",
"ytchannelembed.com",
"*.openstreetmap.org",
"broschueren.nordrheinwestfalendirekt.de"
]
}
],
"info_count": 2,
"report_only": false,
"finding_count": 4,
"warning_count": 2
},
"missing_count": 4,
"present_count": 5,
"missing_info_count": 4,
"missing_warning_count": 0
},
"infrastructure_analysis": {
"signals": {
"caa": false,
"dnssec": false,
"final_https": true,
"tls_version": "TLSv1.3",
"hsts_enabled": true,
"address_count": 1,
"ipv6_available": false,
"email_protection": {
"mx": true,
"spf": true,
"dmarc": true
},
"certificate_valid": true,
"certificate_issuer": "Telekom Security OV RSA CA 26A",
"certificate_alt_names": [
"ldi.nrw.de",
"www.ldi.nrw.de"
],
"multiple_ip_addresses": false,
"certificate_expires_at": "Dec 26 23:59:59 2026 GMT",
"certificate_days_remaining": 191,
"certificate_hostname_matches": true
},
"findings": [
{
"id": "caa_missing",
"title": "CAA-Record fehlt",
"public": true,
"category": "dns",
"severity": "info"
}
],
"risk_level": "low",
"positive_signals": [
"Moderne TLS-Version aktiv: TLSv1.3.",
"HSTS ist aktiv.",
"DMARC ist für die Domain vorhanden."
]
},
"performance_analysis": {
"score": 88,
"signals": {
"compressed": false,
"duration_ms": 345,
"image_count": 34,
"script_count": 5,
"cache_control": "must-revalidate, no-cache, private",
"content_length": 197473,
"viewport_found": true,
"stylesheet_count": 4
},
"findings": [
{
"id": "large_html_response",
"title": "HTML-Antwort ist groß",
"public": true,
"category": "performance",
"severity": "info"
},
{
"id": "compression_missing",
"title": "Komprimierung nicht erkannt",
"public": true,
"category": "performance",
"severity": "info"
}
],
"risk_level": "medium"
},
"accessibility_analysis": {
"color": "orange",
"score": 68,
"status": "auffällig",
"signals": {
"h1_count": 0,
"image_count": 34,
"button_count": 14,
"heading_count": 37,
"viewport_found": true,
"html_lang_found": true,
"form_field_count": 11,
"image_missing_alt_count": 11,
"buttons_without_name_count": 0,
"form_fields_without_label_count": 0
},
"summary": "34 Bild(er), 11 Formularfeld(er), 14 Button(s) im passiven HTML-Sample auf Basis-Barrierefreiheit geprüft.",
"findings": [
{
"id": "image_alt_missing",
"count": 11,
"title": "Bilder ohne Alternativtext",
"public": true,
"category": "accessibility",
"severity": "info",
"evidence_items": [
"/sites/default/files/styles/slider_main_16_9_960/public/2025-02/panthermedia_b42196053_3508x2341.jpg?h=2553af24&itok=3NS8HiMb",
"/sites/default/files/styles/slider_main_16_9_960/public/2025-07/panthermedia-232199340-m_datenpanne.jpg?h=8eb76705&itok=6I0vhEFG",
"/sites/default/files/styles/slider_main_16_9_960/public/2026-04/istock-523769722.jpg?h=9effd7ce&itok=cM04uDEB",
"/sites/default/files/styles/slider_main_16_9_960/public/2026-04/wmy_0005.jpg?h=99ad6be6&itok=xG9wnAS4",
"/sites/default/files/styles/slider_main_16_9_960/public/2026-03/istock-1315342275_1.jpg?h=3345eb8f&itok=jSYSnftJ",
"/sites/default/files/styles/slider_main_16_9_960/public/2025-12/cyber_kriminalitaet_252995358-m.jpg?h=8eb76705&itok=1AjHyyKR",
"/sites/default/files/styles/teaser_landscape_2_1_320/public/2026-04/wmy_0005.jpg?h=53780ebf&itok=luKkuTnU",
"/sites/default/files/styles/teaser_landscape_2_1_320/public/2025-12/panthermedia_telekommunikation_208386606-m.jpg?h=b7294b58&itok=w1IlnxYh"
]
}
],
"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": "11 von 34 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 11 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 14 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": false,
"wcag": "WCAG 1.3.1 Info and Relationships / 2.4.6 Headings and Labels",
"title": "Überschriftenstruktur",
"impact": "mittel",
"status": "prüfen",
"evidence": "0 H1 und 37 Ü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": "2 WCAG-/EAA-Prüfpunkt(e) auffällig, davon 0 mit hoher Auswirkung.",
"standard": "WCAG 2.2 orientierte Basisprüfung",
"available": true,
"issue_count": 2,
"high_impact_count": 0
}
},
"domain_history": {
"summary": "Domainhistorie konnte per RDAP nicht zuverlässig abgerufen werden.",
"findings": [],
"available": false,
"risk_level": "unknown"
},
"data_entry_analysis": {
"forms": [
{
"url": "https://www.ldi.nrw.de/31_Taetigkeitsbericht_LDI_NRW",
"path": "/31_Taetigkeitsbericht_LDI_NRW",
"method": "UNBEKANNT",
"source": "crawl",
"purpose": "Formular",
"data_types": [],
"field_count": 0
},
{
"url": "https://www.ldi.nrw.de/Chatkontrolle_Trilog",
"path": "/Chatkontrolle_Trilog",
"method": "UNBEKANNT",
"source": "crawl",
"purpose": "Formular",
"data_types": [],
"field_count": 0
},
{
"url": "https://www.ldi.nrw.de/Digital_Fitness_Check",
"path": "/Digital_Fitness_Check",
"method": "UNBEKANNT",
"source": "crawl",
"purpose": "Formular",
"data_types": [],
"field_count": 0
},
{
"url": "https://www.ldi.nrw.de/OH-Mietinteressenten",
"path": "/OH-Mietinteressenten",
"method": "UNBEKANNT",
"source": "crawl",
"purpose": "Formular",
"data_types": [],
"field_count": 0
},
{
"purpose": "Formular",
"field_count": 0,
"source": "crawl",
"path": "/31_Taetigkeitsbericht_LDI_NRW",
"url": "https://www.ldi.nrw.de/31_Taetigkeitsbericht_LDI_NRW"
},
{
"purpose": "Formular",
"field_count": 0,
"source": "crawl",
"path": "/Chatkontrolle_Trilog",
"url": "https://www.ldi.nrw.de/Chatkontrolle_Trilog"
},
{
"purpose": "Formular",
"field_count": 0,
"source": "crawl",
"path": "/Digital_Fitness_Check",
"url": "https://www.ldi.nrw.de/Digital_Fitness_Check"
},
{
"purpose": "Formular",
"field_count": 0,
"source": "crawl",
"path": "/OH-Mietinteressenten",
"url": "https://www.ldi.nrw.de/OH-Mietinteressenten"
}
],
"score": 84,
"summary": "Crawl fand 12 Formular(e) auf 4 geprüften Seite(n), u. a. /31_Taetigkeitsbericht_LDI_NRW, /Chatkontrolle_Trilog, /Digital_Fitness_Check, /OH-Mietinteressenten.",
"findings": [],
"form_count": 12,
"risk_level": "medium",
"field_count": 2,
"asks_for_data": true,
"crawl_form_pages": [
{
"url": "https://www.ldi.nrw.de/31_Taetigkeitsbericht_LDI_NRW",
"path": "/31_Taetigkeitsbericht_LDI_NRW",
"category": "datenschutz",
"form_count": 3
},
{
"url": "https://www.ldi.nrw.de/Chatkontrolle_Trilog",
"path": "/Chatkontrolle_Trilog",
"category": "datenschutz",
"form_count": 3
},
{
"url": "https://www.ldi.nrw.de/Digital_Fitness_Check",
"path": "/Digital_Fitness_Check",
"category": "datenschutz",
"form_count": 3
},
{
"url": "https://www.ldi.nrw.de/OH-Mietinteressenten",
"path": "/OH-Mietinteressenten",
"category": "datenschutz",
"form_count": 3
}
],
"payment_providers": [],
"detected_data_types": [
{
"id": "contact",
"count": 1,
"label": "Kontaktformular"
}
],
"crawl_form_page_count": 4,
"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": "72c5af78-f0ba-48bf-9da3-6568e64aeee1",
"created_at": "2026-06-18 08:49:58.070004+02",
"score": 62,
"verdict": "auffällig",
"finding_count": 20,
"integrity_root_hash": "a8fb0d4841ced35c96500ec36b796d3857dff5203eed51a81ccaaf12ea547d71",
"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": "ldi.nrw.de",
"rank": 1,
"score": 62,
"status": "über_durchschnitt",
"summary": "ldi.nrw.de liegt mit 62 Punkten über dem gespeicherten Durchschnitt von 53.7.",
"available": true,
"peer_count": 2271,
"percentile": 0,
"query_mode": "php_ttl_cache_refresh",
"distribution": {
"0_39": 270,
"40_59": 1076,
"60_79": 921,
"80_100": 4
},
"median_score": 58,
"average_score": 53.7,
"comparison_basis": "Neuester gespeicherter SaferPage-Scan je Domain; überwiegend deutschsprachige gespeicherte Checks.",
"same_score_count": 0,
"better_than_count": 0,
"qualified_peer_count": 2192,
"zero_score_count": 79,
"top_quartile_score": 64,
"top_decile_score": 67,
"qualified_average_score": 55.6,
"qualified_median_score": 58,
"qualified_top_quartile_score": 64,
"qualified_top_decile_score": 68,
"thresholds": [
{
"id": "critical",
"label": "Kritisch",
"range": "0-39",
"met": false
},
{
"id": "basic",
"label": "Basis stabilisieren",
"range": "40-59",
"met": false
},
{
"id": "managed",
"label": "Gesteuert",
"range": "60-79",
"met": true
},
{
"id": "strong",
"label": "Stark",
"range": "80-100",
"met": false
}
],
"risk_tier": "gesteuert",
"target_score": 80,
"aspirational_target_score": 80,
"gap_to_target": 18,
"gap_to_top_quartile": 2,
"gap_to_strong": 18,
"cache_ttl_seconds": 300
},
"audit_receipt": {
"url": "https://ldi.nrw.de/",
"host": "ldi.nrw.de",
"status": "verfügbar",
"bot_url": "https://saferpage.de/bot",
"summary": "Prüfbeleg für ldi.nrw.de: kontrollierter HTTP-/Browser-Kurzcheck mit 46 Request(s), 4 Consent-Zustand/Zuständen und 6 Artefakt(en).",
"renderer": "playwright-chromium",
"artifacts": [
{
"label": "Öffentlicher Kurzreport",
"detail": "https://saferpage.de/ldi.nrw.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/ldi.nrw.de-160x150-474e499868d6a9974f.png",
"status": "verfügbar"
},
{
"label": "Empfänger-/Anbieterinventar",
"detail": "0 Anbieterzeile(n), 0 AVV-/Rollenprüfung(en).",
"status": "unauffällig"
},
{
"label": "Barrierefreiheitserklärung-Entwurf",
"detail": "2 bekannte Barrierefreiheits-Punkt(e).",
"status": "Teilweise konform im automatischen Basischeck"
}
],
"available": true,
"final_url": "https://www.ldi.nrw.de/",
"checked_at": "2026-06-18T06:49:57+00:00",
"share_text": "SaferPage Prüfbeleg ldi.nrw.de: 46 Browser-Request(s), 0 Drittanbieter, 0 Cookie-/Storage-Einträge, geprüft am 2026-06-18T06:49:57.",
"user_agent": "SaferPageBot/0.2 (+https://saferpage.de/bot; passive website safety check; no attack tests)",
"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": "manual",
"coverage_items": [
{
"label": "HTTP/DNS/TLS",
"value": "HTTP 200 · DNS ok · TLS ok"
},
{
"label": "Browserlauf",
"value": "46 Request(s), 0 Drittanbieter-Domain(s), 0 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": "0 Cookie-Zeile(n) im öffentlichen Nachweis."
}
],
"confidence_score": 90,
"browser_final_url": "https://www.ldi.nrw.de/"
},
"evidence_integrity_manifest": {
"host": "ldi.nrw.de",
"status": "verfügbar",
"summary": "Integritätsmanifest für ldi.nrw.de: 9/9 Nachweisbereich(e) mit SHA-256-Hash dokumentiert.",
"sections": [
{
"id": "audit_receipt",
"hash": "c8078482ed0b056a8cc3f91057324dab7ed4e281e1d50f19179a134695f259ae",
"count": 18,
"label": "Prüfbeleg",
"detail": "Kanonischer JSON-Hash des kompakten Prüfbelegs.",
"status": "verfügbar"
},
{
"id": "protocol",
"hash": "770915522c3049cbab5cea5f65762cbde2ddd240e5126eb5aff71a13b40abe2a",
"count": 15,
"label": "Scan-Protokoll",
"detail": "URL, Endziel, User-Agent, Zeitstempel, HTTP/DNS/TLS und Renderer.",
"status": "verfügbar"
},
{
"id": "checkpoints",
"hash": "28378cfe0b776ba13bcfbc00fe50bdba8833e9f3377d4f14a51f0eed40984f2d",
"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": "4f53cda18c2baa0c0354bb5f9a3ecbe5ed12ab4d8e11ba873c2f11161202b945",
"count": 0,
"label": "Cookie-Auszug",
"detail": "Sanitisierte Cookie-Metadaten ohne Cookie-Werte.",
"status": "leer"
},
{
"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": "d96ddd3ba0c37e30275e8ebf68ea7594b1f0bb80bff616a28adee9e8286878e0",
"count": 8,
"label": "Geprüfte Unterseiten",
"detail": "Priorisierte Pfade aus Sitemap, Pflichtseiten und interner Linkstruktur.",
"status": "verfügbar"
},
{
"id": "screenshot_file",
"hash": "ff370e93806c0bf297d6234e6be4ae46acef8a4a6b9975d78e0a36d12d9b85e0",
"count": 9562,
"label": "160x150 Seitenvorschau-Datei",
"detail": "/cache/screenshots/ldi.nrw.de-160x150-474e499868d6a9974f.png",
"status": "verfügbar"
}
],
"algorithm": "sha256",
"available": true,
"root_hash": "a8fb0d4841ced35c96500ec36b796d3857dff5203eed51a81ccaaf12ea547d71",
"checked_at": "2026-06-18T06:49:57+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 46 Browser-Request(s), 0 Cookie-Nachweis(en), 0 Drittanbieter-Auszug/auszügen und 4 Consent-Zustand/Zuständen.",
"protocol": {
"host": "ldi.nrw.de",
"dns_ok": true,
"tls_ok": true,
"bot_url": "https://saferpage.de/bot",
"renderer": "playwright-chromium",
"final_url": "https://www.ldi.nrw.de/",
"input_url": "https://ldi.nrw.de/",
"checked_at": "2026-06-18T06:49:57+00:00",
"user_agent": "SaferPageBot/0.2 (+https://saferpage.de/bot; passive website safety check; no attack tests)",
"http_status": 200,
"scan_context": "manual",
"screenshot_url": "/cache/screenshots/ldi.nrw.de-160x150-474e499868d6a9974f.png",
"googlebot_status": 200,
"browser_final_url": "https://www.ldi.nrw.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.ldi.nrw.de/.",
"status": "ok"
},
{
"label": "Browserlauf",
"detail": "46 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": "/31_Taetigkeitsbericht_LDI_NRW",
"source": "homepage_link",
"status": 0,
"category": "datenschutz"
},
{
"path": "/Chatkontrolle_Trilog",
"source": "homepage_link",
"status": 0,
"category": "datenschutz"
},
{
"path": "/Digital_Fitness_Check",
"source": "homepage_link",
"status": 0,
"category": "datenschutz"
},
{
"path": "/OH-Mietinteressenten",
"source": "homepage_link",
"status": 0,
"category": "datenschutz"
},
{
"path": "/Umfrage_Bitkom",
"source": "homepage_link",
"status": 0,
"category": "datenschutz"
},
{
"path": "/Videoueberwachung_Karte",
"source": "homepage_link",
"status": 0,
"category": "datenschutz"
},
{
"path": "/Zertifizierung_TUEV",
"source": "homepage_link",
"status": 0,
"category": "datenschutz"
},
{
"path": "/datenschutz",
"source": "homepage_link",
"status": 0,
"category": "datenschutz"
}
],
"cookie_evidence": [],
"browser_evidence": {
"gpc_enabled": true,
"request_count": 46,
"storage_total": 0,
"accept_clicked": false,
"reject_clicked": false,
"browser_cookie_count": 0,
"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": "measured_dom_viewport_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": "visible_controls_without_classified_samples",
"classified_sample_count": 0,
"accept_control_count": 0,
"reject_control_count": 0,
"settings_control_count": 0,
"visible_control_count": 28,
"accept_max_area": 0,
"reject_max_area": 0,
"reject_prominence_ratio": "nicht messbar",
"samples": [],
"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."
}
}