8 wichtige Security-Header fehlen oder sind nicht belegt.
CVE-2020-11023: Potential XSS vulnerability in jQuery: –
Tracking und Consent zuerst prüfen: Consent ist teilweise erkennbar; einzelne Punkte bleiben Betreiberkontext.
- Quelle
- Scan-Evidence
Live-Domain-Report
Scan-ID: 5ecd581b-74f5-4c27-adb2-47936a9008d2 · 2026-06-19 21:39:17.329649+02
Geprüfte Domain-Wurzel: https://miniweb-hilfe.nuernberg.de/
Kurz-URL: saferpage.de/miniweb-hilfe.nuernberg.de
Datenschutz-Score
22/100 Kritische HinweiseIn 20 Sekunden lesen
Nutzen Sie diese Kurzfassung zuerst als Evidence-Checkliste: belegte Signale, Claim-Grenzen und Links stehen im Vordergrund; Betreiberkontext ohne Scan-Beleg wird nur verlinkt.
Score-Erklärung
Diese Erklärung macht die Gesamtaussage lesbar: Score-Treiber, entlastende Signale, Gate-/Grenzsignale und manuelle Prüfpunkte bleiben getrennt. Der Score ist kein Verbot, kein Gütesiegel und keine Rechtsfreigabe. Score-Methodik öffnen
8 wichtige Security-Header fehlen oder sind nicht belegt.
CVE-2020-11023: Potential XSS vulnerability in jQuery: –
Tracking und Consent zuerst prüfen: Consent ist teilweise erkennbar; einzelne Punkte bleiben Betreiberkontext.
0 Cookie(s) vor Einwilligung im gespeicherten Erstaufruf.
0 datenschutzrelevante Drittanbieter-Domain(s) aus Browserkontakten.
0 Tracking-Script(s) im gespeicherten Lauf.
Kein Google-Tag, keine Google-Domain und keine Google-Tracking-ID belegt.
Impressum-Link wurde im passiven Sample belegt.
Datenschutz-Hinweis wurde im passiven Sample belegt.
Score unter 50: hoher Betreiber-Pruefbedarf, aber kein Verbot und kein Seriositaetsurteil.
4 manuelle Review-Ausloeser aus der Scope-Grenze.
4 nicht automatisch gepruefte Bereiche, etwa Login, Checkout, Vertrags- oder Rechtskontext.
Korrektur melden: Wenn Score-Treiber durch Consent-Wall, Paywall, veraltete Inhalte oder falsch erkannte Betreiberinformationen verzerrt sind, melden Sie Domain, Report-URL, Scan-ID und kurze Begruendung ueber Kontakt.
Prüfumfang & Grenzen
Prüfumfang und Grenzen des passiven SaferPage-Kurzchecks: getestet, nicht getestet, manuell zu prüfen und erneut zu scannen.
Passiver HTTP-/Browser-Sample: 47 Browser-Request(s), 0 datenschutzrelevante Drittanbieter-Domain(s).
Cookies und Consent-Startzustand: 0 Cookie(s) vor Einwilligung im gespeicherten Lauf.
Öffentlich erreichbare Test-URLs: 1 direkt geprüfte Test-URL(s) im Crawl-/Coverage-Abschnitt.
Formular-Evidenz aus öffentlichem Crawl: Keine Formularabgabe im passiven Sample belegt.
Claim-Grenze: Der Prüfumfang beschreibt den gespeicherten passiven Kurzcheck. Er ersetzt keine Rechtsberatung, keine Betreiberfreigabe und keinen Deep-Scan hinter Login, Paywall oder Interaktion.
Zuletzt geprüfte Seiten
Der Kurzreport zeigt hier die priorisierten Unterseiten aus dem letzten Crawl mit direktem Link zur geprüften Ziel-URL. Die Screenshot-Vorschau oben ist eine kleine 160x150-Evidence zum geprüften Seitenzustand; die Liste darunter macht sichtbar, ob Datenschutz-, Impressum-, Formular- oder andere wichtige Seiten im Test enthalten waren.
1 abgerufene Unterseite(n) · 1 zusätzlich entdeckte interne Linkziele.
Vollständiges Seiteninventar öffnen · Agentur-DeepScan öffnen
Audit-Ausgabe
Dieser Bericht ist für die Browser-Funktion „Drucken“ beziehungsweise „Als PDF speichern“ optimiert. Rohdaten und auditfähige Nachweise bleiben zusätzlich über JSON, CSV, Excel-Tabellen und ein ZIP-Nachweispaket mit getrennten Cookie-, Drittanbieter-, Consent-, Request- und Aufgaben-Tabellen exportierbar.
Link-only
Dieser Report zeigt Scan-Fakten zur geprüften Website. Umsetzungsschritte, Hintergrundseiten, Checklisten, Code und allgemeine Empfehlungen stehen auf getrennten Seiten; im Report erscheint nur der Link.
–
Guide-, Checklisten- und Umsetzungstexte stehen auf separaten Seiten; hier bleiben Evidence und Link.Consent ist teilweise erkennbar; einzelne Punkte bleiben Betreiberkontext.
Guide-, Checklisten- und Umsetzungstexte stehen auf separaten Seiten; hier bleiben Evidence und Link.Tracking-Requests dürfen die aktuelle Seiten-URL nicht unnötig als Parameter übertragen.
Guide-, Checklisten- und Umsetzungstexte stehen auf separaten Seiten; hier bleiben Evidence und Link.Betreiber-Fazit
Die Kurzfassung zeigt technische Signale aus dem passiven Lauf. Betreiberkontext ohne Scan-Beleg wird nur als Hintergrund-Link angeboten.
Prüfprofil
Prüfprofil Deutschland -> DACH: Allgemeine Website, Zielgruppe Gemischte Zielgruppe. 4 Schwerpunkt(e) für Betreiber priorisiert.
Das Profil priorisiert technische Prüfpunkte für Betreiber; es ersetzt keine rechtliche Einzelfallprüfung.
Website-Typ: Allgemeine Website · Betreiber: Deutschland · Zielregion: DACH
Prüfmodule
1 Infrastruktur-Hinweis(e), Security-Header: 1/9 vorhanden, 8 fehlen, externe Skript-Hosts: 1.
Details und Umsetzungshinweise stehen auf separaten Seiten; sichtbar bleiben Modulscore, Evidence und Link.Mehr erfahren1 interne Linkziele erkannt, 1 priorisierte Unterseite(n) abgerufen.
Details und Umsetzungshinweise stehen auf separaten Seiten; sichtbar bleiben Modulscore, Evidence und Link.Mehr erfahrenScan-Evidence in diesem Modul vorhanden; Betreiberkontext steht auf einer separaten Seite.
Details und Umsetzungshinweise stehen auf separaten Seiten; sichtbar bleiben Modulscore, Evidence und Link.Mehr erfahren10 externe Skript(e) von 1 Host(s), 10 ohne SRI, 0 Tracking-/Tag-nahe Skript(e).
Details und Umsetzungshinweise stehen auf separaten Seiten; sichtbar bleiben Modulscore, Evidence und Link.Mehr erfahren47 Request(s), 3 Drittanbieter-Domain(s), davon 0 datenschutzrelevant, 0 Browser-Cookie(s), Transfer-Prüfbedarf: 0, Referrer-/URL-Leaks: 1, Fingerprinting-/Replay-Hinweise: 1.
Details und Umsetzungshinweise stehen auf separaten Seiten; sichtbar bleiben Modulscore, Evidence und Link.Mehr erfahren1 SEO-Spam-Hinweis(e), 0 Cloaking-Hinweis(e).
Details und Umsetzungshinweise stehen auf separaten Seiten; sichtbar bleiben Modulscore, Evidence und Link.Mehr erfahren1 Drittanbieter-Domain(s) mit Referrer-/URL-Leak-Prüfbedarf, 0 sensible Query-Kontexte.
Details und Umsetzungshinweise stehen auf separaten Seiten; sichtbar bleiben Modulscore, Evidence und Link.Mehr erfahrenDie Seite kann Newsletter, Zahlung, Kontaktformular abfragen.
Details und Umsetzungshinweise stehen auf separaten Seiten; sichtbar bleiben Modulscore, Evidence und Link.Mehr erfahrenLink-only Detailmodule
Dieser Report bleibt bei Scan-Fakten zur geprüften Website. Nachweise, Badge-Code, Benchmark, Monitoring, Arbeitspfade und Hintergrundseiten öffnen auf eigenen Seiten; im Report stehen nur feste Links, keine Hintergrundinhalte.
Monitoring
Noch kein Vergleich
Noch kein früherer gespeicherter Scan für diese Domain vorhanden.
Betreiber-Risiko
Hoher Betreiber-Handlungsbedarf
Abgeleitet aus dem Datenschutz-Webseiten-Report: Datenschutz, TDDDG/ePrivacy, BSI-Sicherheit, Google-Qualität und Nutzbarkeit werden nach passiven Befunden priorisiert.
Domainhistorie
Domainhistorie konnte per RDAP nicht zuverlässig abgerufen werden.
Datenschutz zuerst
Cookies beim ersten Aufruf: 0 · Tracking-Skripte: 0 · Datenschutzerklärung: ja · Impressum: ja · Ablehnen-Option: nein
Dateneingabe & Zahlung
Im passiven Sample wurde keine Formular-Evidence gespeichert. Datenschutzkontext: ja · Details auf der verlinkten Seite
PII & Datenlecks
0 PII-/Datenleck-Hinweis(e) aus URL-, Formular- und Browserkontext. Score: 100 · Hinweise: 0
Kurzantwort
Der Check bleibt passiv und formuliert die wichtigsten Punkte als Betreiberhinweise. Technische Details bleiben nachvollziehbar im JSON erhalten.
Browser-Sicht
Requests: 47 · kontaktierte Domains: 4 · Drittanbieter: 3 · Browser-Cookies: 0 · Storage: 4 (0 Tracking-Hinweis(e)) · Banner: Akzeptieren 1 / Ablehnen 0 / Einstellungen 4 · Ablehnen/Akzeptieren: 0 · Reject-Test: nicht gefunden, neue Cookies 0, neue Tracking-Kontakte 0 · Accept-Test: geklickt, neue Cookies 7, neue Tracking-Kontakte 0 · TCF-String: nein, Purposes 0, Vendors 0 · GPC: aktiv, Datenschutz-Domains 0, Drittanbieter-Cookies 0 · Viewport-Signale: Datenschutz 1 / Impressum 2 / Kontakt 0 / Cookie 3 · CMP: ja · Browser: playwright-chromium
Consent-Zustände
Consent-State-Evidence: 4 Zustände verglichen, 0 hoch auffällig, 0 mittel auffällig. Score: 100
Consent-Journey
Consent-Journey: 0 neue Datenschutz-Domain(s) nach Ablehnen, 0 nach Akzeptieren, 0 im GPC-Aufruf. Score: 100 · Ablehnen neu: 0 · Akzeptieren neu: 0 · GPC: 0
Drittanbieter-Kontakte
3 Drittanbieter-Domain(s) beim ersten Browseraufruf, davon 0 datenschutzrelevant. Score: 95 · Requests: 5 · datenschutzrelevant: 0
Betreiber-Verzeichnis
3 Empfänger-/Anbieter-Eintrag/Einträge aus Browserkontakten und Cookie-Inventar, 0 datenschutzrelevant, 2 mit AVV-/Rollenprüfung. Score: 90 · hoher Prüfbedarf: 0 · AVV/Rolle prüfen: 2
Aus diesem Rohfeld wird im Report keine zusätzliche Scan-Feststellung abgeleitet; Betreiberkontext und Umsetzungshinweise stehen auf separaten Seiten.
Transfer-Risiko
3 Drittanbieter für Transfer-/Jurisdiktionsprüfung, 0 mit hohem Prüfbedarf, 2 unklar. Score: 84 · hoher Prüfbedarf: 0 · unklar: 2
Externe Inhalte
0 externe Embed-/Widget-Dienst(e), 0 davon im ersten Browseraufruf geladen. Score: 100 · vorab geladen: 0 · Captcha: 0
Referrer & URL-Leaks
1 Drittanbieter-Domain(s) mit Referrer-/URL-Leak-Prüfbedarf, 0 sensible Query-Kontexte. Score: 88 · Domains: 1 · sensible Kontexte: 0
Tracking-Pixel & Beacons
0 Pixel-/Bildtracking-Hinweis(e), 0 Beacon-/Telemetry-Hinweis(e), 0 Link-Ping(s). Score: 100 · Pixel: 0 · Beacons/Telemetry: 0 · Link-Pings: 0
Fingerprinting & Session-Replay
1 Fingerprinting-/Session-Replay-Hinweis(e) aus dem Browserlauf. Score: 88 · Hinweise: 1
Seitenabdeckung
1 interne Linkziele erkannt (0 aus Sitemap), 1 priorisierte Unterseite(n) zusätzlich abgerufen. Score: 50 · wichtige Seiten: · Sitemap-URLs: 0 · gelesene Sitemaps: 1 · Unterseiten mit Tracking: 0 · Formularlücken: 0
Google Consent Mode
Kein Google-Tag, keine Google-Domain und keine Google-Tracking-ID im passiven Check belegt.
SaferPage stellt deshalb keinen Google-Consent-Mode-Fehler dar; spätere Google-Tags brauchen einen neuen technischen Re-Scan.
Consent Mode
Kein Google-Tag, keine Google-Domain und keine Google-Tracking-ID erkannt; Google Consent Mode ist aus dieser Scan-Evidenz nicht erforderlich.
Der Report zeigt nur Scan-Status, Zähler und den Link zur Detailseite. Consent-Anleitung, Code und Umsetzungsschritte werden hier nicht gerendert.
Consent-Audit
Consent ist teilweise erkennbar; einzelne Punkte bleiben Betreiberkontext. Score: 64 · Cookies vor Einwilligung: 0 · Tracking-Cookies: 0 · Browser-Ablehnen: 0 · Ablehnen/Akzeptieren: 0 · Reject geklickt: nein · neue Cookies nach Ablehnen: 0 · Accept geklickt: ja · neue Cookies nach Akzeptieren: 7 · neue Tracking-Kontakte nach Akzeptieren: 0 · TCF-String: nein · TCF Purposes: 0 · TCF Vendors: 0 · GPC Datenschutz-Domains: 0 · GPC Drittanbieter-Cookies: 0 · Storage-Hinweise: 0 · CMP: ja · datenschutzrelevante Drittanbieter: 0
Banner-UX
Consent-Banner-UX: 1 auffällige Prüfpunkt(e), davon 1 hoch. Muster: Ablehnen nicht gleichwertig sichtbar. Score: 82 · Akzeptieren: 1 · Ablehnen: 0 · Einstellungen: 4 · Dark-Pattern-Hinweise: 1
Automatisch aus sichtbaren Banner-Controls und Browser-Interaktionen abgeleitet; visuelle Details und Rechtmäßigkeit fachlich prüfen.
Welche Consent-Controls waren im ersten Viewport sichtbar? Status: accept_without_visible_reject_signal · Akzeptieren: 1 · Ablehnen: 0 · Einstellungen: 4 · sichtbare Controls: 27 · Ablehnen/Akzeptieren: nicht messbar
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.
TCF-Decoder
TCF-Decoder: 0 Zweck(e) mit Consent/LI-Signal, 0 Vendor-Consent(s), 0 Vendor-LI-Signal(e). Score: 100 · TC-String: nein · Purposes Consent: 0 · Purposes LI: 0 · Vendor Consent: 0 · Vendor LI: 0
Quellenmatrix
Quellen und Betreiber-Background stehen auf separaten Seiten.
Dieser Report zeigt dazu nur Zähler und Link; Quellenkommentare sind kein Befund zur geprüften Website.
Quellen: 9 · offizielle Links: 5
DSGVO & TDDDG
Der passive Scan stellt keine Rechtsgrundlage fest.
Er zählt nur beobachtete Cookie-, Storage-, Drittanbieter-, Formular- und Consent-Signale. Die fachliche Rechtsgrundlagenprüfung bleibt Sache des Betreibers und ist als Guide verlinkt.
Einwilligungsbezug: 8 · vor Consent auffällig: 0 · unklar/prüfen: 11 · Drittanbieter: 3 · Storage: 4
Detailprüfung, Rechtsbewertung und Umsetzungshinweise werden nicht im Report angezeigt.
Disclosure-Abgleich
Disclosure-Abgleich: 4 beobachtete Anbieter, 4 Anbieter ohne klare Erwähnung, 0 fehlende Policy-Bausteine.
Automatischer Textabgleich gegen technische Beobachtungen; Schreibweisen und dynamische Inhalte können manuelle Prüfung erfordern.
Score: 0 · Anbieter erkannt: 4 · Anbieter fehlen: 4 · Policy-Lücken: 0
Datenschutzhinweis
Disclosure-Signale aus dem Scan.
Der Report zeigt hier nur Zähler, beobachtete Signale und Links; redaktionelle Inhalte und Betreiber-Background stehen auf separaten Seiten.
Cookie-Inventar
0 Cookie(s) inventarisiert: 0 Tracking-/Werbe-Cookie(s), 0 Drittanbieter-Cookie(s), 0 langlebige Cookie(s), 0 sehr lange Laufzeit(en). Score: 100 · ohne Secure: 0 · ohne SameSite: 0 · persistent: 0 · langlebiges Tracking: 0 · sehr lang: 0 · Laufzeitrisiko: 0
Cookie-Disclosure
Cookie-Erklärung mit 4 Eintrag/Einträgen aus Cookies und Web Storage: 0 einwilligungspflichtig, 4 unklassifiziert. Score: 78 · einwilligungspflichtig: 0 · vor Consent: 0 · unklassifiziert: 4
Automatisch aus SaferPage-Cookie- und Web-Storage-Signalen abgeleitet; Kategorien und Zwecke vor Veröffentlichung fachlich prüfen.
Barrierefreiheit & Usability
6 Bild(er), 0 Formularfeld(er), 49 Button(s) im passiven HTML-Sample auf Basis-Barrierefreiheit geprüft. Score: 92
1 WCAG-/EAA-Prüfpunkt(e) auffällig, davon 1 mit hoher Auswirkung. Automatisch aus HTML-Signalen abgeleitet; ersetzt keine vollständige manuelle WCAG-/BITV-Prüfung.
BFSG/WCAG
Barrierefreiheits-Signale aus dem Scan. Status: Nicht vollständig konform im automatischen Basischeck
Erklärungstexte und allgemeine Umsetzungshinweise stehen auf separaten Seiten.
DSGVO, Cookies & Tracking
Consent-Hinweis: nein · Datenschutz-Hinweis: ja · Cookies: 0
Seiteninhalt & Keywords
Hinweise zur Nutzung des Internetangebots
– Nürnberg – deine Stadt
Informationen und Hilfestellungen zur Benutzung der Internetseiten der stadt Nürnberg
Technologie-Erkennung
Server: myracloud · Powered-by: nicht erkannt · Generator: IMPERIA 11.5.5
CVE & Versionsrisiko
Advisory-Treffer gefunden. Erkannte Versionen: 2 · Advisory-Treffer: 4 · Versionsregeln: 0
Impressum & Betreibertransparenz
Impressum: ja · Datenschutz: ja · Ablehnen-Option: nein
Performance / PageSpeed-Basis
Score: 94 · Antwortzeit: 97 ms · HTML: 0 Bytes · Viewport: ja
Infrastruktur & TLS-Vertrauen
IPs: 1 · IPv6: nein · Zertifikat: 53 Tage · HSTS: ja · MX/SPF/DMARC: nein/nein/nein
Security-Header
1 von 9 wichtigen Security-Headern vorhanden, 1 korrekt bewertet. Keine Content-Security-Policy gefunden. Score: 46 · vorhanden: 1 · fehlen: 8 · prüfen: 0
Skript-Lieferkette
10 externe Skript(e) von 1 Host(s), 10 ohne SRI, 0 Tracking-/Tag-nahe Skript(e). Score: 68 · Hosts: 1 · ohne SRI: 10 · Tracking/Tags: 0
Zusammenhänge & Servernetzwerk
Ad-/Tracking-IDs: 0 · gleiche-IP-Nachbarn: 5 · bekannte eingehende Links: 3 · Servernetze: 1
SEO, Verhalten & Cloaking
SEO-Risiko: high · Browser-Verhalten: low · Cloaking: low
Weitere technische Signale
Öffentlich abrufbare Same-Origin-Signale aus robots.txt, Sitemaps, Meta-/X-Robots, KI-/Crawler-Policys, ads.txt/sellers.json, security.txt und Hreflang. Jede Zeile ist ein technischer Beleg, kein abschließendes Urteil.
{
"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": "miniweb-hilfe.nuernberg.de",
"normalized_url": "https://miniweb-hilfe.nuernberg.de/",
"score": 22,
"verdict": {
"color": "red",
"label": "riskant",
"score": 22
},
"scan_id": "5ecd581b-74f5-4c27-adb2-47936a9008d2",
"created_at": "2026-06-19 21:39:17.329649+02",
"evidence": {
"dns": {
"ok": true,
"addresses": [
"62.91.41.84"
],
"duration_ms": 7
},
"tls": {
"ok": true,
"cipher": "TLS_AES_256_GCM_SHA384",
"issuer": [
[
[
"countryName",
"US"
]
],
[
[
"organizationName",
"Let's Encrypt"
]
],
[
[
"commonName",
"R13"
]
]
],
"subject": [
[
[
"commonName",
"miniweb-hilfe.nuernberg.de"
]
]
],
"version": "TLSv1.3",
"not_after": "Aug 12 10:34:13 2026 GMT",
"hostname_matches": true,
"days_until_expiry": 53,
"subject_alt_names": [
"miniweb-hilfe.nuernberg.de"
],
"issuer_common_name": "R13"
},
"http": {
"ok": true,
"status": 200,
"headers": {
"date": "Fri, 19 Jun 2026 19:38:53 GMT",
"etag": "\"myra-9138864f\"",
"server": "myracloud",
"expires": "Fri, 19 Jun 2026 19:39:53 GMT",
"connection": "close",
"content-type": "text/html",
"cache-control": "max-age=60",
"x-clusternode": "5",
"transfer-encoding": "chunked",
"strict-transport-security": "max-age=31536000",
"access-control-allow-origin": "*",
"access-control-allow-methods": "*"
},
"body_size": 113153,
"final_url": "https://www.nuernberg.de/internet/stadtportal/hilfe.html",
"duration_ms": 97
},
"scanner": {
"bot_url": "https://saferpage.de/bot",
"context": "crawler",
"user_agent": "SaferPageCrawler/0.3 (+https://saferpage.de/bot; schedules passive DACH website checks; report examples: https://saferpage.de/tests; kostenloser Report: <a href=\"https://saferpage.de/miniweb-hilfe.nuernberg.de\">https://saferpage.de/miniweb-hilfe.nuernberg.de</a>)",
"default_user_agent": "SaferPageBot/0.2 (+https://saferpage.de/bot; passive website safety check; no attack tests)"
},
"domain_records": {
"mx": false,
"caa": false,
"spf": false,
"dmarc": false,
"dnssec": false,
"records": {
"mx": [],
"ns": [],
"caa": [],
"txt": [],
"cname": [],
"dmarc": [],
"dnskey_present": false
},
"spf_includes": [],
"verifications": []
},
"googlebot_http": {
"ok": true,
"status": 200,
"headers": {
"date": "Fri, 19 Jun 2026 19:38:53 GMT",
"etag": "\"myra-b10c954e\"",
"x-cdn": "1",
"server": "myracloud",
"expires": "Fri, 19 Jun 2026 19:35:22 GMT",
"connection": "close",
"content-type": "text/html",
"cache-control": "max-age=60",
"x-clusternode": "5",
"x-cdn-updating": "1",
"transfer-encoding": "chunked",
"strict-transport-security": "max-age=31536000",
"access-control-allow-origin": "*",
"access-control-allow-methods": "*"
},
"body_size": 113153,
"final_url": "https://www.nuernberg.de/internet/stadtportal/hilfe.html",
"duration_ms": 73
},
"ai_search_policy_evidence": {
"files": [
{
"id": "robots_txt",
"url": "https://www.nuernberg.de/robots.txt",
"label": "robots.txt",
"reason": "",
"status": "found",
"body_size": 2261,
"truncated": false,
"body_sha256": "46db45a8aed76b7a95c9c675ef0a0df2a3166b4f82268d847f4cdcab31c8d932",
"duration_ms": 154,
"http_status": 200,
"ai_bot_policy": {
"bot_directives": [],
"explicit_ai_bots": [],
"explicit_ai_bot_count": 0,
"wildcard_directive_count": 40,
"wildcard_directives_sample": [
{
"value": "/imperia/md/_sandkasten/bilder/intranet/",
"directive": "disallow"
},
{
"value": "/imperia/md/_sandkasten/dokumente/intranet/",
"directive": "disallow"
},
{
"value": "/imperia/md/bauordnungsbehoerde/bilder/intranet/",
"directive": "disallow"
},
{
"value": "/imperia/md/frauenbeauftragte/bilder/intranet/",
"directive": "disallow"
},
{
"value": "/imperia/md/frauenbeauftragte/dokumente/intranet/",
"directive": "disallow"
},
{
"value": "/imperia/md/geoinformation/bilder/intranet/",
"directive": "disallow"
},
{
"value": "/imperia/md/kem/bilder/intranet/",
"directive": "disallow"
},
{
"value": "/imperia/md/kommunikation_stadtmarketing/bilder/intranet/",
"directive": "disallow"
}
]
},
"relevant_lines": [
"User-agent: *",
"Disallow: /imperia/md/_sandkasten/bilder/intranet/",
"Disallow: /imperia/md/_sandkasten/dokumente/intranet/",
"Disallow: /imperia/md/bauordnungsbehoerde/bilder/intranet/",
"Disallow: /imperia/md/frauenbeauftragte/bilder/intranet/",
"Disallow: /imperia/md/frauenbeauftragte/dokumente/intranet/",
"Disallow: /imperia/md/geoinformation/bilder/intranet/",
"Disallow: /imperia/md/kem/bilder/intranet/",
"Disallow: /imperia/md/kommunikation_stadtmarketing/bilder/intranet/",
"Disallow: /imperia/md/personalamt/bilder/intranet/",
"Disallow: /imperia/md/personalamt/dokumente/intranet/",
"Disallow: /imperia/md/sandkasten/dokumente/intranet/",
"Disallow: /imperia/md/stadtarchiv/bilder/intranet/",
"Disallow: /imperia/md/stadtplanung/intranet/",
"Disallow: /imperia/md/sun/bilder/intranet/",
"Disallow: /imperia/md/zentral/bilder/intranet/"
]
},
{
"id": "llms_txt",
"url": "https://www.nuernberg.de/llms.txt",
"label": "llms.txt",
"reason": "http_error",
"status": "missing",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 259,
"http_status": 404,
"relevant_lines": []
},
{
"id": "ai_txt",
"url": "https://www.nuernberg.de/.well-known/ai.txt",
"label": "AI Policy",
"reason": "http_error",
"status": "missing",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 242,
"http_status": 404,
"relevant_lines": []
},
{
"id": "ai_policy_txt",
"url": "https://www.nuernberg.de/.well-known/ai-policy.txt",
"label": "AI Policy",
"reason": "http_error",
"status": "missing",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 177,
"http_status": 404,
"relevant_lines": []
},
{
"id": "ward_txt",
"url": "https://www.nuernberg.de/.well-known/ward.txt",
"label": "WARD Policy",
"reason": "http_error",
"status": "missing",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 145,
"http_status": 404,
"relevant_lines": []
}
],
"origin": "https://www.nuernberg.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.nuernberg.de/ads.txt",
"label": "ads.txt",
"reason": "http_error",
"status": "missing",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 170,
"http_status": 404,
"ads_txt_policy": [],
"relevant_lines": [],
"sellers_json_policy": []
},
{
"id": "app_ads_txt",
"url": "https://www.nuernberg.de/app-ads.txt",
"label": "app-ads.txt",
"reason": "http_error",
"status": "missing",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 258,
"http_status": 404,
"ads_txt_policy": [],
"relevant_lines": [],
"sellers_json_policy": []
},
{
"id": "sellers_json",
"url": "https://www.nuernberg.de/sellers.json",
"label": "sellers.json",
"reason": "http_error",
"status": "missing",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 213,
"http_status": 404,
"ads_txt_policy": [],
"relevant_lines": [],
"sellers_json_policy": []
}
],
"origin": "https://www.nuernberg.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.nuernberg.de/.well-known/security.txt",
"label": "security.txt",
"reason": "http_error",
"status": "missing",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 137,
"http_status": 404,
"relevant_lines": [],
"security_txt_policy": []
},
{
"id": "security_txt_legacy",
"url": "https://www.nuernberg.de/security.txt",
"label": "security.txt legacy",
"reason": "http_error",
"status": "missing",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 264,
"http_status": 404,
"relevant_lines": [],
"security_txt_policy": []
}
],
"origin": "https://www.nuernberg.de",
"schema": "https://saferpage.de/schemas/security-trust-policy-evidence.v1",
"status": "checked",
"metrics": {
"file_count": 2,
"field_count": 0,
"contact_count": 0,
"found_file_count": 0,
"preferred_well_known_found": 0
},
"summary": "0 von 2 security.txt-Ziel(en) gefunden; 0 Kontaktfeld(er), 0 strukturierte Feld(er).",
"available": true,
"guardrails": [
"Nur feste Same-Origin-security.txt-Ziele",
"Keine Off-Host-Redirects",
"64-KB-Body-Limit",
"Öffentlich nur Hash, Status und kurze relevante Zeilen"
],
"field_count": 0,
"contact_count": 0,
"fields_present": [],
"policy_present": false,
"expires_present": false,
"encryption_present": false,
"security_txt_found": false,
"preferred_well_known_found": false
}
},
"findings": [
{
"id": "known_vulnerability_advisory",
"title": "CVE-2015-9251: Cross-Site Scripting (XSS) in jquery",
"public": true,
"version": "1.11.2",
"audience": "nutzer",
"category": "vulnerability",
"severity": "warning",
"confirmed": true,
"technology": "jQuery",
"advisory_id": "CVE-2015-9251",
"user_importance": 135,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "known_vulnerability_advisory",
"title": "CVE-2019-11358: XSS in jQuery as used in Drupal, Backdrop CMS, and other products",
"public": true,
"version": "1.11.2",
"audience": "nutzer",
"category": "vulnerability",
"severity": "warning",
"confirmed": true,
"technology": "jQuery",
"advisory_id": "CVE-2019-11358",
"user_importance": 135,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "known_vulnerability_advisory",
"title": "CVE-2020-11022: Potential XSS vulnerability in jQuery",
"public": true,
"version": "1.11.2",
"audience": "nutzer",
"category": "vulnerability",
"severity": "warning",
"confirmed": true,
"technology": "jQuery",
"advisory_id": "CVE-2020-11022",
"user_importance": 135,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "known_vulnerability_advisory",
"title": "CVE-2020-11023: Potential XSS vulnerability in jQuery",
"public": true,
"version": "1.11.2",
"audience": "nutzer",
"category": "vulnerability",
"severity": "critical",
"confirmed": true,
"technology": "jQuery",
"advisory_id": "CVE-2020-11023",
"user_importance": 135,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "browser_consent_reject_missing",
"title": "Kein sichtbarer Ablehnen-Button im Banner",
"public": true,
"audience": "nutzer",
"category": "privacy",
"severity": "warning",
"user_importance": 122,
"importance_label": "Wichtig für Nutzer"
},
{
"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 1, Ablehnen 0, Einstellungen 4"
],
"user_importance": 121,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "third_party_page_url_parameter",
"count": 1,
"title": "Seiten-URL wird in Drittanbieter-Requests übertragen",
"public": true,
"audience": "nutzer",
"category": "privacy",
"severity": "warning",
"evidence_items": [
"consent.cookiebot.com"
],
"user_importance": 118,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "external_link_spam",
"title": "Sehr viele externe Links erkannt",
"public": true,
"audience": "nutzer",
"category": "seo",
"severity": "warning",
"evidence_items": [
"22 externe Links auf der Startseite"
],
"user_importance": 116,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "privacy_policy_too_thin",
"title": "Datenschutzhinweis wirkt sehr dünn",
"public": true,
"audience": "nutzer",
"category": "privacy",
"severity": "warning",
"evidence_items": [
"Erkannter Datenschutztext ist sehr kurz/dünn für eine vollständige Erklärung"
],
"user_importance": 113,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "browser_keystroke_listener_signals",
"count": 15,
"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": "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: keine"
],
"user_importance": 88,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "button_name_missing",
"count": 1,
"title": "Buttons ohne erkennbaren Namen",
"public": true,
"audience": "nutzer",
"category": "accessibility",
"severity": "warning",
"evidence_items": [
"type=button class=\"button--resize\""
],
"user_importance": 86,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "external_script_without_sri",
"count": 10,
"title": "Externe Skripte ohne Subresource Integrity",
"public": true,
"audience": "nutzer",
"category": "security_headers",
"severity": "info",
"evidence_items": [
"https://www.nuernberg.de/hydra/javascript/theme.js?v=2.66.1",
"https://www.nuernberg.de/hydra/javascript/jquery-1.11.2.min.js?v=2.66.1",
"https://www.nuernberg.de/hydra/javascript/jquery-ui.min.js?v=2.66.1",
"https://www.nuernberg.de/hydra/javascript/routing.js?v=2.66.1",
"https://www.nuernberg.de/hydra/javascript/ilightbox.js?v=2.66.1",
"https://www.nuernberg.de/hydra/javascript/global.js?v=2.66.1",
"https://www.nuernberg.de/hydra/javascript/savemode_preview.js?v=2.66.1",
"https://www.nuernberg.de/hydra/javascript/web_components/accessibility/nbg-accessibility.js?v=2.66.1"
],
"user_importance": 84,
"importance_label": "Wichtig für Nutzer"
},
{
"id": "too_many_render_blocking_assets",
"title": "Viele potenziell blockierende Assets",
"public": true,
"audience": "betreiber",
"category": "performance",
"severity": "info",
"evidence_items": [
"Viele render-blockierende CSS/JS-Ressourcen im <head> der Startseite"
],
"user_importance": 74,
"importance_label": "Technischer Hinweis"
},
{
"id": "missing_csp",
"title": "Content-Security-Policy fehlt",
"public": true,
"audience": "betreiber",
"category": "security_headers",
"severity": "warning",
"evidence_items": [
"HTTP-Header „Content-Security-Policy\" fehlt in der Antwort der Startseite"
],
"user_importance": 72,
"importance_label": "Technischer Hinweis"
},
{
"id": "missing_x_frame_options",
"title": "X-Frame-Options fehlt",
"public": true,
"audience": "betreiber",
"category": "security_headers",
"severity": "warning",
"evidence_items": [
"HTTP-Header „X-Frame-Options\" fehlt in der Antwort der Startseite"
],
"user_importance": 70,
"importance_label": "Technischer Hinweis"
},
{
"id": "missing_x_content_type_options",
"title": "X-Content-Type-Options fehlt",
"public": true,
"audience": "betreiber",
"category": "security_headers",
"severity": "warning",
"evidence_items": [
"HTTP-Header „X-Content-Type-Options\" fehlt in der Antwort der Startseite"
],
"user_importance": 70,
"importance_label": "Technischer Hinweis"
},
{
"id": "missing_cross_origin_embedder_policy",
"title": "Cross-Origin-Embedder-Policy fehlt",
"public": true,
"audience": "betreiber",
"category": "security_headers",
"severity": "info",
"evidence_items": [
"HTTP-Header „Cross-Origin-Embedder-Policy\" fehlt in der Antwort der Startseite"
],
"user_importance": 68,
"importance_label": "Technischer Hinweis"
},
{
"id": "missing_cross_origin_opener_policy",
"title": "Cross-Origin-Opener-Policy fehlt",
"public": true,
"audience": "betreiber",
"category": "security_headers",
"severity": "info",
"evidence_items": [
"HTTP-Header „Cross-Origin-Opener-Policy\" fehlt in der Antwort der Startseite"
],
"user_importance": 66,
"importance_label": "Technischer Hinweis"
},
{
"id": "missing_cross_origin_resource_policy",
"title": "Cross-Origin-Resource-Policy fehlt",
"public": true,
"audience": "betreiber",
"category": "security_headers",
"severity": "info",
"evidence_items": [
"HTTP-Header „Cross-Origin-Resource-Policy\" fehlt in der Antwort der Startseite"
],
"user_importance": 64,
"importance_label": "Technischer Hinweis"
},
{
"id": "crawl_coverage_limited",
"title": "Wenig interne Seiten auf der Startseite gefunden",
"public": true,
"audience": "betreiber",
"category": "crawl",
"severity": "info",
"evidence_items": [
"Nur 1 interne Links auf der Startseite gefunden"
],
"user_importance": 62,
"importance_label": "Technischer Hinweis"
},
{
"id": "consent_banner_dark_pattern_risk",
"count": 1,
"title": "Consent-Banner mit Dark-Pattern-/UX-Risiko",
"public": true,
"audience": "betreiber",
"category": "privacy",
"severity": "warning",
"evidence_items": [
"Banner-UX: Akzeptieren 1 vs. Ablehnen 0 – Ablehnen weniger prominent/gleichwertig"
],
"user_importance": 60,
"importance_label": "Technischer Hinweis"
},
{
"id": "missing_referrer_policy",
"title": "Referrer-Policy fehlt",
"public": true,
"audience": "betreiber",
"category": "security_headers",
"severity": "info",
"evidence_items": [
"HTTP-Header „Referrer-Policy\" fehlt in der Antwort der Startseite"
],
"user_importance": 40,
"importance_label": "Technischer Hinweis"
},
{
"id": "missing_permissions_policy",
"title": "Permissions-Policy fehlt",
"public": true,
"audience": "betreiber",
"category": "security_headers",
"severity": "info",
"evidence_items": [
"HTTP-Header „Permissions-Policy\" fehlt in der Antwort der Startseite"
],
"user_importance": 40,
"importance_label": "Technischer Hinweis"
},
{
"id": "unknown_vendor_jurisdiction",
"title": "Anbieter-Jurisdiktion nicht klar ableitbar",
"public": true,
"audience": "betreiber",
"category": "privacy",
"severity": "info",
"evidence_items": [
"Drittanbieter mit unklarer Anbieter-Jurisdiktion / möglichem Drittlandtransfer"
],
"user_importance": 30,
"importance_label": "Technischer Hinweis"
}
],
"audit_modules": [
{
"id": "security_tls",
"color": "red",
"score": 46,
"title": "Sicherheit, TLS & Header",
"source": "DNS, TLS, HTTP-Status, Zertifikat und Security-Header",
"status": "kritisch",
"evidence": "1 Infrastruktur-Hinweis(e), Security-Header: 1/9 vorhanden, 8 fehlen, externe Skript-Hosts: 1."
},
{
"id": "site_coverage",
"color": "orange",
"score": 50,
"title": "Seitenabdeckung & Crawl",
"source": "Startseiten-Links, Compliance-Links und begrenzter interner Zusatzabruf",
"status": "auffällig",
"evidence": "1 interne Linkziele erkannt, 1 priorisierte Unterseite(n) abgerufen."
},
{
"id": "privacy_consent",
"color": "orange",
"score": 64,
"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: 64."
},
{
"id": "script_supply_chain",
"color": "orange",
"score": 68,
"title": "Externe Skripte & SRI",
"source": "HTML-Script-Tags, Anbieterklassifikation und SRI-Attribute",
"status": "auffällig",
"evidence": "10 externe Skript(e) von 1 Host(s), 10 ohne SRI, 0 Tracking-/Tag-nahe Skript(e)."
},
{
"id": "browser_evidence",
"color": "yellow",
"score": 79,
"title": "Browser-Nachweis",
"source": "Headless Chromium mit Screenshot- und Request-Telemetrie",
"status": "prüfen",
"evidence": "47 Request(s), 3 Drittanbieter-Domain(s), davon 0 datenschutzrelevant, 0 Browser-Cookie(s), Transfer-Prüfbedarf: 0, Referrer-/URL-Leaks: 1, Fingerprinting-/Replay-Hinweise: 1."
},
{
"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": "referrer_url_leaks",
"color": "yellow",
"score": 88,
"title": "Referrer & URL-Leaks",
"source": "Chromium-Request-Telemetrie ohne gespeicherte Parameterwerte",
"status": "prüfen",
"evidence": "1 Drittanbieter-Domain(s) mit Referrer-/URL-Leak-Prüfbedarf, 0 sensible Query-Kontexte."
},
{
"id": "forms_payments",
"color": "green",
"score": 90,
"title": "Formulare, Login & Zahlung",
"source": "HTML-Formulare, Eingabefelder, Zahlungsanbieter und Kontextlinks",
"status": "unauffällig",
"evidence": "Die Seite kann Newsletter, Zahlung, Kontaktformular abfragen."
},
{
"id": "accessibility_usability",
"color": "green",
"score": 92,
"title": "Barrierefreiheit & Usability",
"source": "Passives HTML-Sample: Bilder, Formulare, Buttons, Sprache, Headings und Viewport",
"status": "unauffällig",
"evidence": "0 Bild(er) ohne alt, 0 Formularfeld(er) ohne Beschriftung, 1 Button(s) ohne Namen."
},
{
"id": "performance_mobile",
"color": "green",
"score": 94,
"title": "Performance & mobile Nutzbarkeit",
"source": "HTTP-Antwort, HTML-Größe, Komprimierung und mobile Basis",
"status": "unauffällig",
"evidence": "Performance-Score 94, Antwortzeit 97 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": "google_third_parties",
"color": "green",
"score": 100,
"title": "Google-Dienste & Drittanbieter",
"source": "Chromium-Requests, Anbieterklassifikation und Google Consent Mode Heuristik",
"status": "unauffällig",
"evidence": "Keine Google-Domain, keine Google-Tracking-ID und keine datenschutzrelevanten Drittanbieter im passiven Check erkannt."
},
{
"id": "operator_transparency",
"color": "green",
"score": 100,
"title": "Impressum, Kontakt & Datenschutzerklärung",
"source": "Deutschsprachige Betreiber- und Datenschutzhinweis-Erkennung",
"status": "unauffällig",
"evidence": "Impressum: ja, Datenschutz: ja, Kontakt: ja."
},
{
"id": "pii_exposure",
"color": "green",
"score": 100,
"title": "PII, URL-Parameter & Datenleck-Schutz",
"source": "URL-Parameter, interne Links, HTML-Formulare, Browser-Drittanbieter und Dateneingabe-Kontext",
"status": "unauffällig",
"evidence": "0 PII-/Datenleck-Hinweis(e) aus URL-, Formular- und Browserkontext."
},
{
"id": "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.nuernberg.de/robots.txt",
"label": "robots.txt",
"reason": "",
"status": "found",
"body_size": 2261,
"truncated": false,
"body_sha256": "46db45a8aed76b7a95c9c675ef0a0df2a3166b4f82268d847f4cdcab31c8d932",
"duration_ms": 154,
"http_status": 200,
"ai_bot_policy": {
"bot_directives": [],
"explicit_ai_bots": [],
"explicit_ai_bot_count": 0,
"wildcard_directive_count": 40,
"wildcard_directives_sample": [
{
"value": "/imperia/md/_sandkasten/bilder/intranet/",
"directive": "disallow"
},
{
"value": "/imperia/md/_sandkasten/dokumente/intranet/",
"directive": "disallow"
},
{
"value": "/imperia/md/bauordnungsbehoerde/bilder/intranet/",
"directive": "disallow"
},
{
"value": "/imperia/md/frauenbeauftragte/bilder/intranet/",
"directive": "disallow"
},
{
"value": "/imperia/md/frauenbeauftragte/dokumente/intranet/",
"directive": "disallow"
},
{
"value": "/imperia/md/geoinformation/bilder/intranet/",
"directive": "disallow"
},
{
"value": "/imperia/md/kem/bilder/intranet/",
"directive": "disallow"
},
{
"value": "/imperia/md/kommunikation_stadtmarketing/bilder/intranet/",
"directive": "disallow"
}
]
},
"relevant_lines": [
"User-agent: *",
"Disallow: /imperia/md/_sandkasten/bilder/intranet/",
"Disallow: /imperia/md/_sandkasten/dokumente/intranet/",
"Disallow: /imperia/md/bauordnungsbehoerde/bilder/intranet/",
"Disallow: /imperia/md/frauenbeauftragte/bilder/intranet/",
"Disallow: /imperia/md/frauenbeauftragte/dokumente/intranet/",
"Disallow: /imperia/md/geoinformation/bilder/intranet/",
"Disallow: /imperia/md/kem/bilder/intranet/",
"Disallow: /imperia/md/kommunikation_stadtmarketing/bilder/intranet/",
"Disallow: /imperia/md/personalamt/bilder/intranet/",
"Disallow: /imperia/md/personalamt/dokumente/intranet/",
"Disallow: /imperia/md/sandkasten/dokumente/intranet/",
"Disallow: /imperia/md/stadtarchiv/bilder/intranet/",
"Disallow: /imperia/md/stadtplanung/intranet/",
"Disallow: /imperia/md/sun/bilder/intranet/",
"Disallow: /imperia/md/zentral/bilder/intranet/"
]
},
{
"id": "llms_txt",
"url": "https://www.nuernberg.de/llms.txt",
"label": "llms.txt",
"reason": "http_error",
"status": "missing",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 259,
"http_status": 404,
"relevant_lines": []
},
{
"id": "ai_txt",
"url": "https://www.nuernberg.de/.well-known/ai.txt",
"label": "AI Policy",
"reason": "http_error",
"status": "missing",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 242,
"http_status": 404,
"relevant_lines": []
},
{
"id": "ai_policy_txt",
"url": "https://www.nuernberg.de/.well-known/ai-policy.txt",
"label": "AI Policy",
"reason": "http_error",
"status": "missing",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 177,
"http_status": 404,
"relevant_lines": []
},
{
"id": "ward_txt",
"url": "https://www.nuernberg.de/.well-known/ward.txt",
"label": "WARD Policy",
"reason": "http_error",
"status": "missing",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 145,
"http_status": 404,
"relevant_lines": []
}
],
"origin": "https://www.nuernberg.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.nuernberg.de/ads.txt",
"label": "ads.txt",
"reason": "http_error",
"status": "missing",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 170,
"http_status": 404,
"ads_txt_policy": [],
"relevant_lines": [],
"sellers_json_policy": []
},
{
"id": "app_ads_txt",
"url": "https://www.nuernberg.de/app-ads.txt",
"label": "app-ads.txt",
"reason": "http_error",
"status": "missing",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 258,
"http_status": 404,
"ads_txt_policy": [],
"relevant_lines": [],
"sellers_json_policy": []
},
{
"id": "sellers_json",
"url": "https://www.nuernberg.de/sellers.json",
"label": "sellers.json",
"reason": "http_error",
"status": "missing",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 213,
"http_status": 404,
"ads_txt_policy": [],
"relevant_lines": [],
"sellers_json_policy": []
}
],
"origin": "https://www.nuernberg.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.nuernberg.de/.well-known/security.txt",
"label": "security.txt",
"reason": "http_error",
"status": "missing",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 137,
"http_status": 404,
"relevant_lines": [],
"security_txt_policy": []
},
{
"id": "security_txt_legacy",
"url": "https://www.nuernberg.de/security.txt",
"label": "security.txt legacy",
"reason": "http_error",
"status": "missing",
"body_size": 0,
"truncated": false,
"body_sha256": "",
"duration_ms": 264,
"http_status": 404,
"relevant_lines": [],
"security_txt_policy": []
}
],
"origin": "https://www.nuernberg.de",
"schema": "https://saferpage.de/schemas/security-trust-policy-evidence.v1",
"status": "checked",
"metrics": {
"file_count": 2,
"field_count": 0,
"contact_count": 0,
"found_file_count": 0,
"preferred_well_known_found": 0
},
"summary": "0 von 2 security.txt-Ziel(en) gefunden; 0 Kontaktfeld(er), 0 strukturierte Feld(er).",
"available": true,
"guardrails": [
"Nur feste Same-Origin-security.txt-Ziele",
"Keine Off-Host-Redirects",
"64-KB-Body-Limit",
"Öffentlich nur Hash, Status und kurze relevante Zeilen"
],
"field_count": 0,
"contact_count": 0,
"fields_present": [],
"policy_present": false,
"expires_present": false,
"encryption_present": false,
"security_txt_found": false,
"preferred_well_known_found": false
},
"site_coverage_analysis": {
"color": "orange",
"pages": [
{
"url": "https://miniweb-hilfe.nuernberg.de/",
"path": "/",
"text": "Hilfe",
"source": "homepage_link",
"category": "unterseite",
"priority": 20
}
],
"score": 50,
"status": "auffällig",
"summary": "1 interne Linkziele erkannt (0 aus Sitemap), 1 priorisierte Unterseite(n) zusätzlich abgerufen.",
"findings": [
{
"id": "crawl_coverage_limited",
"title": "Wenig interne Seiten auf der Startseite gefunden",
"public": true,
"category": "crawl",
"severity": "info"
},
{
"id": "important_pages_not_discovered",
"title": "Wichtige Betreiberseiten nicht vollständig in der Linkstruktur gefunden",
"public": true,
"category": "crawl",
"severity": "warning"
}
],
"robots_ok": true,
"categories": {
"unterseite": 1
},
"sample_limit": 4,
"sampled_count": 1,
"sampled_pages": [
{
"ok": true,
"url": "https://miniweb-hilfe.nuernberg.de/",
"path": "/",
"audit": {
"form_count": 0,
"finding_ids": [
"operator_identity_unclear",
"privacy_policy_too_thin",
"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": 0,
"title": "Hinweise zur Nutzung des Internetangebots – Nürnberg – deine Stadt",
"status": 200,
"category": "unterseite",
"duration_ms": 62,
"privacy_hint": true,
"privacy_policy_audit": []
}
],
"robots_checked": true,
"sitemap_sources": [
"https://www.nuernberg.de/sitemap.xml"
],
"sitemap_available": true,
"sitemap_url_count": 0,
"homepage_link_count": 220,
"internal_link_count": 1,
"privacy_policy_audit": [],
"sitemap_source_count": 1,
"provider_disclosure_audit": {
"found": [],
"checks": [],
"reason": "no_detected_services",
"missing": [],
"available": false
},
"important_categories_found": [],
"sampled_tracking_page_count": 0,
"sampled_form_privacy_gap_count": 0,
"sitemap_candidate_source_count": 1
},
"page_analysis": {
"h1": [
"Hinweise zur Nutzung des Internetangebots"
],
"h2": [
"Menüleiste",
"<button class=\"button--accordion wrapper--icon-text\" type=\"button\" data-accordion=\"toggle\" aria-expanded=\"true\" aria-controls=\"accordion_content_0_50_9750990\"><svg class=\"icon--toggle\" viewBox=\"0 0 512 512\" aria-hidden=\"true\"><use href=\"/hydra/images/global/icons.svg#fa-chevron-circle-down-solid\"></use></svg><span>Menü</span></button>",
"Suchtipps",
"<button class=\"button--accordion wrapper--icon-text\" type=\"button\" data-accordion=\"toggle\" aria-controls=\"accordion_content_0_45_9750990\" aria-expanded=\"true\"><svg class=\"icon--toggle\" viewBox=\"0 0 512 512\" aria-hidden=\"true\"><use href=\"/hydra/images/global/icons.svg#fa-chevron-circle-down-solid\"></use></svg><span>Ansicht per Maus anpassen</span></button>",
"<button class=\"button--accordion wrapper--icon-text\" type=\"button\" data-accordion=\"toggle\" aria-expanded=\"true\" aria-controls=\"accordion_content_0_47_9750990\"><svg class=\"icon--toggle\" viewBox=\"0 0 512 512\" aria-hidden=\"true\"><use href=\"/hydra/images/global/icons.svg#fa-chevron-circle-down-solid\"></use></svg><span>Ansicht per Tastatur anpassen</span></button>",
"<button class=\"button--accordion wrapper--icon-text\" type=\"button\" data-accordion=\"toggle\" aria-controls=\"accordion_content_0_58_9750990\" aria-expanded=\"true\"><svg class=\"icon--toggle\" viewBox=\"0 0 512 512\" aria-hidden=\"true\"><use href=\"/hydra/images/global/icons.svg#fa-chevron-circle-down-solid\"></use></svg><span>Sprache einstellen</span></button>",
"<button class=\"button--accordion wrapper--icon-text\" type=\"button\" data-accordion=\"toggle\" aria-expanded=\"true\" aria-controls=\"accordion_content_0_52_9750990\"><svg class=\"icon--toggle\" viewBox=\"0 0 512 512\" aria-hidden=\"true\"><use href=\"/hydra/images/global/icons.svg#fa-chevron-circle-down-solid\"></use></svg><span>Seiten vorlesen lassen</span></button>",
"<button class=\"button--accordion wrapper--icon-text\" type=\"button\" data-accordion=\"toggle\" aria-controls=\"accordion_content_0_54_9750990\" aria-expanded=\"true\"><svg class=\"icon--toggle\" viewBox=\"0 0 512 512\" aria-hidden=\"true\"><use href=\"/hydra/images/global/icons.svg#fa-chevron-circle-down-solid\"></use></svg><span>Online-Dienste & pdf-Formulare</span></button>",
"Online-Dienste",
"pdf-Formulare"
],
"title": "Hinweise zur Nutzung des Internetangebots\n – Nürnberg – deine Stadt",
"keywords": [
[
"nürnberg",
18
],
[
"können",
13
],
[
"stadt",
12
],
[
"öffnet",
12
],
[
"seiten",
10
],
[
"menü",
9
],
[
"https",
9
],
[
"nuernberg",
9
],
[
"link",
7
],
[
"seite",
7
]
],
"language": "de",
"description": "Informationen und Hilfestellungen zur Benutzung der Internetseiten der stadt Nürnberg",
"favicon_url": "https://www.nuernberg.de/hydra/favicons/apple-touch-icon.png",
"link_counts": {
"external": 22,
"internal": 198
},
"preview_image": "/cache/screenshots/miniweb-hilfe.nuernberg.de-160x150-f3b244d9f525c66754.png",
"screenshot_url": "/cache/screenshots/miniweb-hilfe.nuernberg.de-160x150-f3b244d9f525c66754.png",
"external_scripts": [],
"browser_final_url": "https://www.nuernberg.de/internet/stadtportal/hilfe.html",
"meta_preview_image": "",
"screenshot_renderer": "playwright-chromium",
"external_link_targets": [
{
"host": "nuernberg.de",
"count": 2,
"examples": [
{
"href": "https://www.nuernberg.de/internet/stadtportal/behoerdenwegweiser.html",
"text": "Behördenwegweiser"
},
{
"href": "https://www.nuernberg.de/internet/arbeitgeberin/index.html",
"text": "Karriere"
}
],
"nofollow": 0,
"strength": "strong",
"follow_count": 2
},
{
"host": "barrierefreiheitserklaerung.nuernberg.de",
"count": 1,
"examples": [
{
"href": "https://barrierefreiheitserklaerung.nuernberg.de",
"text": "Barrierefreiheit"
}
],
"nofollow": 0,
"strength": "strong",
"follow_count": 1
},
{
"host": "behoerdenwegweiser.nuernberg.de",
"count": 1,
"examples": [
{
"href": "https://behoerdenwegweiser.nuernberg.de/",
"text": "Behördenwegweiser"
}
],
"nofollow": 0,
"strength": "strong",
"follow_count": 1
},
{
"host": "bsky.app",
"count": 1,
"examples": [
{
"href": "https://bsky.app/profile/stadtnuernberg.bsky.social",
"text": "Bluesky"
}
],
"nofollow": 0,
"strength": "weak",
"follow_count": 1
},
{
"host": "cookie-consent.nuernberg.de",
"count": 1,
"examples": [
{
"href": "https://cookie-consent.nuernberg.de",
"text": "Cookies"
}
],
"nofollow": 0,
"strength": "weak",
"follow_count": 1
},
{
"host": "datenschutzhinweis.nuernberg.de",
"count": 1,
"examples": [
{
"href": "https://datenschutzhinweis.nuernberg.de/",
"text": "Datenschutz"
}
],
"nofollow": 0,
"strength": "strong",
"follow_count": 1
},
{
"host": "dgs.nuernberg.de",
"count": 1,
"examples": [
{
"href": "https://dgs.nuernberg.de",
"text": ""
}
],
"nofollow": 0,
"strength": "weak",
"follow_count": 1
},
{
"host": "facebook.com",
"count": 1,
"examples": [
{
"href": "https://facebook.com/nuernberg.de/",
"text": "Facebook"
}
],
"nofollow": 0,
"strength": "strong",
"follow_count": 1
},
{
"host": "instagram.com",
"count": 1,
"examples": [
{
"href": "https://instagram.com/nuernberg_de",
"text": "Instagram"
}
],
"nofollow": 0,
"strength": "strong",
"follow_count": 1
},
{
"host": "jobs.nuernberg.de",
"count": 1,
"examples": [
{
"href": "https://jobs.nuernberg.de",
"text": ""
}
],
"nofollow": 0,
"strength": "weak",
"follow_count": 1
},
{
"host": "leichte-sprache.nuernberg.de",
"count": 1,
"examples": [
{
"href": "https://leichte-sprache.nuernberg.de",
"text": "Leichte Sprache"
}
],
"nofollow": 0,
"strength": "strong",
"follow_count": 1
},
{
"host": "linkedin.com",
"count": 1,
"examples": [
{
"href": "https://www.linkedin.com/company/stadt-nuernberg",
"text": "LinkedIn"
}
],
"nofollow": 0,
"strength": "strong",
"follow_count": 1
},
{
"host": "meinkonto.nuernberg.de",
"count": 1,
"examples": [
{
"href": "https://meinkonto.nuernberg.de/start",
"text": ""
}
],
"nofollow": 0,
"strength": "weak",
"follow_count": 1
},
{
"host": "online-service2.nuernberg.de",
"count": 1,
"examples": [
{
"href": "https://online-service2.nuernberg.de/dodb/AntraegeFormulare.aspx",
"text": "Liste der Online-Dienste im Behördenwegeiser der Stadt Nürnberg"
}
],
"nofollow": 0,
"strength": "strong",
"follow_count": 1
},
{
"host": "tiktok.com",
"count": 1,
"examples": [
{
"href": "https://www.tiktok.com/@nuernberg_de",
"text": "TikTok"
}
],
"nofollow": 0,
"strength": "weak",
"follow_count": 1
},
{
"host": "tourismus.nuernberg.de",
"count": 1,
"examples": [
{
"href": "https://tourismus.nuernberg.de",
"text": "Tourismus"
}
],
"nofollow": 0,
"strength": "strong",
"follow_count": 1
},
{
"host": "twitter.com",
"count": 1,
"examples": [
{
"href": "https://twitter.com/nuernberg_de",
"text": "X"
}
],
"nofollow": 0,
"strength": "weak",
"follow_count": 1
},
{
"host": "whatsapp.com",
"count": 1,
"examples": [
{
"href": "https://whatsapp.com/channel/0029VaG82vjISTkSr23MCR1U",
"text": "WhatsApp"
}
],
"nofollow": 0,
"strength": "strong",
"follow_count": 1
},
{
"host": "xing.com",
"count": 1,
"examples": [
{
"href": "https://www.xing.com/companies/stadtn%C3%BCrnberg",
"text": "Xing"
}
],
"nofollow": 0,
"strength": "weak",
"follow_count": 1
},
{
"host": "youtube.com",
"count": 1,
"examples": [
{
"href": "https://www.youtube.com/user/nbgpresse",
"text": "YouTube"
}
],
"nofollow": 0,
"strength": "weak",
"follow_count": 1
},
{
"host": "zugangseroeffnung.nuernberg.de",
"count": 1,
"examples": [
{
"href": "https://zugangseroeffnung.nuernberg.de/",
"text": "Zugangseröffnung"
}
],
"nofollow": 0,
"strength": "strong",
"follow_count": 1
}
]
},
"browser_analysis": {
"cookies": {
"items": [],
"total": 0,
"third_party": 0
},
"storage": {
"total": 4,
"local_storage_keys": [
"reducedMotion",
"fontFamily",
"accessibility",
"darkMode"
],
"tracking_key_hints": [],
"local_storage_total": 4,
"session_storage_keys": [],
"session_storage_total": 0
},
"findings": [
{
"id": "browser_consent_reject_missing",
"title": "Kein sichtbarer Ablehnen-Button im Banner",
"public": true,
"category": "privacy",
"severity": "warning"
},
{
"id": "unknown_vendor_jurisdiction",
"title": "Anbieter-Jurisdiktion nicht klar ableitbar",
"public": true,
"category": "privacy",
"severity": "info"
},
{
"id": "third_party_page_url_parameter",
"count": 1,
"title": "Seiten-URL wird in Drittanbieter-Requests übertragen",
"public": true,
"category": "privacy",
"severity": "warning"
},
{
"id": "browser_keystroke_listener_signals",
"count": 15,
"title": "Viele Tastatur-/Eingabe-Listener im Browser erkannt",
"public": true,
"category": "privacy",
"severity": "info"
}
],
"renderer": "playwright-chromium",
"final_url": "https://www.nuernberg.de/internet/stadtportal/hilfe.html",
"consent_ui": {
"accept_controls": [
{
"tag": "a",
"top": 759,
"area": 11822,
"left": 353,
"text": "Meine Auswahl erlauben",
"color": "rgb(0, 0, 0)",
"width": 240,
"height": 49,
"background": "rgb(240, 240, 240)",
"font_weight": "400"
}
],
"accept_max_area": 11822,
"reject_controls": [],
"reject_max_area": 0,
"settings_controls": [
{
"tag": "a",
"top": 759,
"area": 11822,
"left": 353,
"text": "Meine Auswahl erlauben",
"color": "rgb(0, 0, 0)",
"width": 240,
"height": 49,
"background": "rgb(240, 240, 240)",
"font_weight": "400"
},
{
"tag": "button",
"top": 0,
"area": 3328,
"left": 236,
"text": "Ansicht anpassen",
"color": "rgb(0, 0, 0)",
"width": 52,
"height": 64,
"background": "rgba(0, 0, 0, 0)",
"font_weight": "400"
},
{
"tag": "button",
"top": 639,
"area": 780,
"left": 79,
"text": "Vorlesen Einstellungen",
"color": "rgb(0, 0, 0)",
"width": 30,
"height": 26,
"background": "rgba(0, 0, 0, 0)",
"font_weight": "400"
},
{
"tag": "a",
"top": 945,
"area": 10647,
"left": 39,
"text": "Ansicht per Maus anpassen",
"color": "rgb(0, 100, 128)",
"width": 273,
"height": 39,
"background": "rgba(0, 0, 0, 0)",
"font_weight": "400"
}
],
"first_layer_summary": "Akzeptieren 1 / Ablehnen 0 / Einstellungen 4",
"cookie_context_found": true,
"reject_less_prominent": false,
"visible_control_count": 27,
"reject_prominence_ratio": 0
},
"gpc_signal": {
"error": "",
"enabled": true,
"storage": {
"total": 4,
"tracking_key_hints": [],
"local_storage_total": 4,
"session_storage_total": 0
},
"cookie_count": 0,
"request_count": 46,
"sec_gpc_header": true,
"navigator_value": true,
"contacted_domains": [
{
"host": "nuernberg.de",
"count": 41,
"category": "other",
"provider": "nuernberg.de",
"third_party": false,
"category_label": "Sonstige",
"resource_types": {
"font": 1,
"fetch": 1,
"image": 5,
"other": 1,
"script": 24,
"document": 1,
"stylesheet": 8
}
},
{
"host": "consent.cookiebot.com",
"count": 2,
"category": "other",
"provider": "consent.cookiebot.com",
"third_party": true,
"category_label": "Sonstige",
"resource_types": {
"script": 2
}
},
{
"host": "consentcdn.cookiebot.com",
"count": 2,
"category": "other",
"provider": "consentcdn.cookiebot.com",
"third_party": true,
"category_label": "Sonstige",
"resource_types": {
"xhr": 1,
"document": 1
}
},
{
"host": "cms1.stadt.nuernberg.de",
"count": 1,
"category": "other",
"provider": "cms1.stadt.nuernberg.de",
"third_party": true,
"category_label": "Sonstige",
"resource_types": {
"script": 1
}
}
],
"contacted_domain_count": 4,
"privacy_relevant_domains": [],
"third_party_cookie_count": 0,
"third_party_domain_count": 3,
"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": true,
"data_layer": true,
"cmp_detected": true,
"usercentrics": false,
"google_tag_data": false
},
"accept_signal": {
"error": "",
"enabled": true,
"storage": {
"total": 2,
"tracking_key_hints": [],
"local_storage_total": 2,
"session_storage_total": 0
},
"clicked_text": "Meine Auswahl erlauben",
"accept_clicked": true,
"accept_available": true,
"contacted_domains": [
{
"host": "nuernberg.de",
"count": 41,
"category": "other",
"provider": "nuernberg.de",
"third_party": false,
"category_label": "Sonstige",
"resource_types": {
"font": 1,
"fetch": 1,
"image": 5,
"other": 1,
"script": 24,
"document": 1,
"stylesheet": 8
}
},
{
"host": "nbgtrack.nuernberg.de",
"count": 6,
"category": "other",
"provider": "nbgtrack.nuernberg.de",
"third_party": true,
"category_label": "Sonstige",
"resource_types": {
"ping": 5,
"script": 1
}
},
{
"host": "consent.cookiebot.com",
"count": 3,
"category": "other",
"provider": "consent.cookiebot.com",
"third_party": true,
"category_label": "Sonstige",
"resource_types": {
"script": 3
}
},
{
"host": "consentcdn.cookiebot.com",
"count": 3,
"category": "other",
"provider": "consentcdn.cookiebot.com",
"third_party": true,
"category_label": "Sonstige",
"resource_types": {
"xhr": 1,
"script": 1,
"document": 1
}
},
{
"host": "cms1.stadt.nuernberg.de",
"count": 1,
"category": "other",
"provider": "cms1.stadt.nuernberg.de",
"third_party": true,
"category_label": "Sonstige",
"resource_types": {
"script": 1
}
}
],
"contacted_domain_count": 5,
"new_domains_after_accept": [
{
"host": "nbgtrack.nuernberg.de",
"count": 6,
"category": "other",
"provider": "nbgtrack.nuernberg.de",
"third_party": true,
"category_label": "Sonstige",
"resource_types": {
"ping": 5,
"script": 1
}
},
{
"host": "consent.cookiebot.com",
"count": 1,
"category": "other",
"provider": "consent.cookiebot.com",
"third_party": true,
"category_label": "Sonstige",
"resource_types": {
"script": 3
}
},
{
"host": "consentcdn.cookiebot.com",
"count": 1,
"category": "other",
"provider": "consentcdn.cookiebot.com",
"third_party": true,
"category_label": "Sonstige",
"resource_types": {
"xhr": 1,
"script": 1,
"document": 1
}
}
],
"privacy_relevant_domains": [],
"third_party_domain_count": 4,
"cookie_count_after_accept": 7,
"cookie_count_before_accept": 0,
"request_count_after_accept": 54,
"storage_count_after_accept": 2,
"request_count_before_accept": 46,
"new_cookie_count_after_accept": 7,
"privacy_relevant_domain_count": 0,
"new_request_count_after_accept": 8,
"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": 47,
"top_providers": [
{
"provider": "consent.cookiebot.com",
"request_count": 2
},
{
"provider": "consentcdn.cookiebot.com",
"request_count": 2
},
{
"provider": "cms1.stadt.nuernberg.de",
"request_count": 1
}
],
"request_samples": [
{
"host": "cms1.stadt.nuernberg.de",
"method": "GET",
"referrer": {
"host": "nuernberg.de",
"has_path": false,
"has_query": false,
"same_site": true,
"path_depth": 0,
"query_keys": [],
"sensitive_query_key_count": 0
},
"has_query": false,
"path_depth": 2,
"query_keys": [],
"third_party": true,
"resource_type": "script",
"query_key_count": 0,
"url_value_param_count": 0,
"sensitive_query_key_count": 0,
"target_url_value_param_count": 0
},
{
"host": "consent.cookiebot.com",
"method": "GET",
"referrer": {
"host": "nuernberg.de",
"has_path": false,
"has_query": false,
"same_site": true,
"path_depth": 0,
"query_keys": [],
"sensitive_query_key_count": 0
},
"has_query": false,
"path_depth": 1,
"query_keys": [],
"third_party": true,
"resource_type": "script",
"query_key_count": 0,
"url_value_param_count": 0,
"sensitive_query_key_count": 0,
"target_url_value_param_count": 0
},
{
"host": "consentcdn.cookiebot.com",
"method": "GET",
"referrer": {
"host": "nuernberg.de",
"has_path": false,
"has_query": false,
"same_site": true,
"path_depth": 0,
"query_keys": [],
"sensitive_query_key_count": 0
},
"has_query": false,
"path_depth": 2,
"query_keys": [],
"third_party": true,
"resource_type": "document",
"query_key_count": 0,
"url_value_param_count": 0,
"sensitive_query_key_count": 0,
"target_url_value_param_count": 0
},
{
"host": "consentcdn.cookiebot.com",
"method": "GET",
"referrer": {
"host": "nuernberg.de",
"has_path": false,
"has_query": false,
"same_site": true,
"path_depth": 0,
"query_keys": [],
"sensitive_query_key_count": 0
},
"has_query": false,
"path_depth": 3,
"query_keys": [],
"third_party": true,
"resource_type": "xhr",
"query_key_count": 0,
"url_value_param_count": 0,
"sensitive_query_key_count": 0,
"target_url_value_param_count": 0
},
{
"host": "consent.cookiebot.com",
"method": "GET",
"referrer": {
"host": "nuernberg.de",
"has_path": false,
"has_query": false,
"same_site": true,
"path_depth": 0,
"query_keys": [],
"sensitive_query_key_count": 0
},
"has_query": true,
"path_depth": 2,
"query_keys": [
"renew",
"referer",
"dnt",
"init",
"culture"
],
"third_party": true,
"resource_type": "script",
"query_key_count": 5,
"url_value_param_count": 0,
"sensitive_query_key_count": 0,
"target_url_value_param_count": 1
}
],
"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": true,
"declined": false,
"consented": false,
"has_response": false,
"consent_marketing": false,
"consent_statistics": false,
"consent_preferences": false
},
"usercentrics": {
"found": false,
"has_response": false,
"services_count": 0,
"accepted_services_count": 0
}
},
"contacted_domains": [
{
"host": "nuernberg.de",
"count": 42,
"category": "other",
"provider": "nuernberg.de",
"third_party": false,
"category_label": "Sonstige",
"resource_types": {
"font": 1,
"fetch": 1,
"image": 6,
"other": 1,
"script": 24,
"document": 1,
"stylesheet": 8
}
},
{
"host": "consent.cookiebot.com",
"count": 2,
"category": "other",
"provider": "consent.cookiebot.com",
"third_party": true,
"category_label": "Sonstige",
"resource_types": {
"script": 2
}
},
{
"host": "consentcdn.cookiebot.com",
"count": 2,
"category": "other",
"provider": "consentcdn.cookiebot.com",
"third_party": true,
"category_label": "Sonstige",
"resource_types": {
"xhr": 1,
"document": 1
}
},
{
"host": "cms1.stadt.nuernberg.de",
"count": 1,
"category": "other",
"provider": "cms1.stadt.nuernberg.de",
"third_party": true,
"category_label": "Sonstige",
"resource_types": {
"script": 1
}
}
],
"privacy_api_metrics": {
"api_calls": {
"mutation_observer_count": 1,
"keyboard_input_listener_count": 15
},
"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": 1,
"keyboard_input_listener_count": 15
},
"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": 604,
"href": "https://www.nuernberg.de/internet/stadtportal/datenschutz.html",
"left": 533,
"text": "Datenschutzerklärung",
"width": 156,
"height": 17,
"category": "privacy_notice"
},
{
"tag": "a",
"top": 632,
"href": "https://www.nuernberg.de/internet/stadtportal/impressum.html",
"left": 365,
"text": "Impressum",
"width": 79,
"height": 17,
"category": "imprint"
},
{
"tag": "a",
"top": 660,
"href": "https://www.nuernberg.de/internet/stadtportal/cookieinfo.html",
"left": 122,
"text": "Mehr Informationen zu Cookies",
"width": 222,
"height": 17,
"category": "cookie_consent"
},
{
"tag": "a",
"top": 631,
"href": "#desc-preferences_PREFERENCE",
"left": 253,
"text": "Mehr Informationen zu Präferenz",
"width": 16,
"height": 17,
"category": "cookie_consent"
},
{
"tag": "a",
"top": 759,
"href": "javascript: Cookiebot.hide();",
"left": 114,
"text": "Alle Cookies zulassen",
"width": 223,
"height": 49,
"category": "cookie_consent"
},
{
"tag": "a",
"top": 136,
"href": "#footer",
"left": 2,
"text": "Zu den Nutzungshinweisen und zum Impressum",
"width": 64,
"height": 24,
"category": "imprint"
}
],
"available": true,
"sample_count": 6,
"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": {
"imprint": 2,
"cookie_consent": 3,
"privacy_notice": 1
},
"contact_visible": false,
"imprint_visible": true,
"viewport_height": 960,
"cookie_consent_visible": true,
"privacy_notice_visible": true
},
"consent_journey_matrix": {
"color": "green",
"items": [
{
"host": "nbgtrack.nuernberg.de",
"states": {
"accept_new": 6
},
"category": "other",
"provider": "nbgtrack.nuernberg.de",
"category_label": "Sonstige",
"privacy_relevant": false,
"total_request_count": 6
},
{
"host": "consent.cookiebot.com",
"states": {
"gpc": 2,
"default": 2,
"accept_new": 1
},
"category": "other",
"provider": "consent.cookiebot.com",
"category_label": "Sonstige",
"privacy_relevant": false,
"total_request_count": 5
},
{
"host": "consentcdn.cookiebot.com",
"states": {
"gpc": 2,
"default": 2,
"accept_new": 1
},
"category": "other",
"provider": "consentcdn.cookiebot.com",
"category_label": "Sonstige",
"privacy_relevant": false,
"total_request_count": 5
},
{
"host": "cms1.stadt.nuernberg.de",
"states": {
"gpc": 1,
"default": 1
},
"category": "other",
"provider": "cms1.stadt.nuernberg.de",
"category_label": "Sonstige",
"privacy_relevant": false,
"total_request_count": 2
}
],
"score": 100,
"states": [
{
"id": "default",
"label": "Erstaufruf",
"description": "Kontakte ohne Nutzeraktion",
"domain_count": 3,
"request_count": 5,
"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": 3,
"request_count": 8,
"privacy_relevant_domain_count": 0
},
{
"id": "gpc",
"label": "GPC-Aufruf",
"description": "Kontakte bei Global Privacy Control",
"domain_count": 3,
"request_count": 5,
"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": 4,
"request_count": 47,
"storage_total": 4,
"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": 4,
"new_cookie_count": 0,
"third_party_cookie_count": 0,
"storage_tracking_hint_count": 0,
"privacy_relevant_domain_count": 0
},
{
"id": "accept",
"label": "Nach Akzeptieren",
"status": "geklickt",
"evidence": "Meine Auswahl erlauben",
"risk_level": "info",
"cookie_count": 7,
"domain_count": 5,
"request_count": 54,
"storage_total": 2,
"new_cookie_count": 7,
"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": 4,
"request_count": 46,
"storage_total": 4,
"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": 4,
"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": 15,
"label": "Tastatur-/Eingabe-Listener",
"detail": "15 Tastatur-/Input-Listener, 55 Interaktions-Listener, 1 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": 1,
"keyboard_input_listener_count": 15
},
"summary": "1 Fingerprinting-/Session-Replay-Hinweis(e) aus dem Browserlauf.",
"findings": [
{
"id": "browser_keystroke_listener_signals",
"count": 15,
"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": {
"other": 3
},
"provider_category_labels": {
"other": "other"
},
"third_party_domain_count": 3,
"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": "yellow",
"items": [
{
"host": "consent.cookiebot.com",
"category": "other",
"provider": "consent.cookiebot.com",
"query_keys": [
"renew",
"referer",
"dnt",
"init",
"culture"
],
"risk_reason": "Seiten-URL oder URL-Wert in Drittanbieter-Requestparametern",
"resource_type": "script",
"category_label": "Sonstige",
"referrer_query_keys": [],
"url_value_param_count": 0,
"target_url_value_param_count": 1
}
],
"score": 88,
"status": "prüfen",
"summary": "1 Drittanbieter-Domain(s) mit Referrer-/URL-Leak-Prüfbedarf, 0 sensible Query-Kontexte.",
"findings": [
{
"id": "third_party_page_url_parameter",
"count": 1,
"title": "Seiten-URL wird in Drittanbieter-Requests übertragen",
"public": true,
"category": "privacy",
"severity": "warning"
}
],
"sample_count": 5,
"full_referrer_count": 0,
"page_url_param_count": 1,
"affected_domain_count": 1,
"sensitive_query_count": 0
},
"third_party_contact_matrix": {
"color": "green",
"items": [
{
"host": "consent.cookiebot.com",
"region": "unbekannt",
"status": "prüfen",
"category": "other",
"provider": "consent.cookiebot.com",
"risk_level": "niedrig",
"request_count": 2,
"transfer_risk": "mittel",
"category_label": "Sonstige",
"resource_types": [
{
"type": "script",
"count": 2
}
],
"transfer_label": "Jurisdiktion unklar",
"privacy_relevant": false
},
{
"host": "consentcdn.cookiebot.com",
"region": "unbekannt",
"status": "prüfen",
"category": "other",
"provider": "consentcdn.cookiebot.com",
"risk_level": "niedrig",
"request_count": 2,
"transfer_risk": "mittel",
"category_label": "Sonstige",
"resource_types": [
{
"type": "document",
"count": 1
},
{
"type": "xhr",
"count": 1
}
],
"transfer_label": "Jurisdiktion unklar",
"privacy_relevant": false
},
{
"host": "cms1.stadt.nuernberg.de",
"region": "EU/EWR",
"status": "prüfen",
"category": "other",
"provider": "cms1.stadt.nuernberg.de",
"risk_level": "niedrig",
"request_count": 1,
"transfer_risk": "niedrig",
"category_label": "Sonstige",
"resource_types": [
{
"type": "script",
"count": 1
}
],
"transfer_label": "EU/EWR",
"privacy_relevant": false
}
],
"score": 95,
"status": "unauffällig",
"summary": "3 Drittanbieter-Domain(s) beim ersten Browseraufruf, davon 0 datenschutzrelevant.",
"category_counts": {
"Sonstige": 3
},
"total_domain_count": 3,
"total_request_count": 5,
"privacy_relevant_count": 0,
"transfer_risk_analysis": {
"color": "yellow",
"items": [
{
"host": "consent.cookiebot.com",
"region": "unbekannt",
"provider": "consent.cookiebot.com",
"request_count": 2,
"transfer_risk": "mittel",
"category_label": "Sonstige",
"transfer_label": "Jurisdiktion unklar",
"privacy_relevant": false
},
{
"host": "consentcdn.cookiebot.com",
"region": "unbekannt",
"provider": "consentcdn.cookiebot.com",
"request_count": 2,
"transfer_risk": "mittel",
"category_label": "Sonstige",
"transfer_label": "Jurisdiktion unklar",
"privacy_relevant": false
},
{
"host": "cms1.stadt.nuernberg.de",
"region": "EU/EWR",
"provider": "cms1.stadt.nuernberg.de",
"request_count": 1,
"transfer_risk": "niedrig",
"category_label": "Sonstige",
"transfer_label": "EU/EWR",
"privacy_relevant": false
}
],
"score": 84,
"status": "prüfen",
"summary": "3 Drittanbieter für Transfer-/Jurisdiktionsprüfung, 0 mit hohem Prüfbedarf, 2 unklar.",
"findings": [
{
"id": "unknown_vendor_jurisdiction",
"title": "Anbieter-Jurisdiktion nicht klar ableitbar",
"public": true,
"category": "privacy",
"severity": "info"
}
],
"unknown_count": 2,
"high_risk_count": 0,
"total_vendor_count": 3,
"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": [],
"tracking_scripts": [],
"consent_hint_found": false,
"privacy_policy_hint_found": true
},
"consent_audit": {
"color": "orange",
"score": 64,
"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: 4."
},
{
"id": "browser_reject_visible",
"ok": false,
"label": "Ablehnen im sichtbaren Banner",
"detail": "Sichtbare Banner-Controls: Akzeptieren 1, Ablehnen 0, Einstellungen 4."
},
{
"id": "browser_settings_visible",
"ok": true,
"label": "Einstellungen im sichtbaren Banner",
"detail": "Sichtbare Banner-Controls: Akzeptieren 1, Ablehnen 0, Einstellungen 4."
},
{
"id": "reject_equally_prominent",
"ok": true,
"label": "Ablehnen nicht deutlich schwaecher dargestellt",
"detail": "Groessen-Verhältnis Ablehnen/Akzeptieren: nicht messbar."
},
{
"id": "reject_button_clickable",
"ok": true,
"label": "Ablehnen technisch klickbar",
"detail": "Wenn ein Ablehnen-Button sichtbar ist, klickt SaferPage ihn im Chromium-Browser einmal an."
},
{
"id": "no_new_cookies_after_reject",
"ok": true,
"label": "Keine neuen Cookies nach Ablehnen",
"detail": "0 neue Cookie(s) nach dem Ablehnen-Klick."
},
{
"id": "no_tracking_storage_after_reject",
"ok": true,
"label": "Kein Tracking-Storage nach Ablehnen",
"detail": "0 Tracking-Hinweis(e) im Web Storage nach Ablehnen."
},
{
"id": "no_privacy_domains_after_reject",
"ok": true,
"label": "Keine neuen Tracking-Kontakte nach Ablehnen",
"detail": "0 neue datenschutzrelevante Domain(s) nach Ablehnen."
},
{
"id": "gpc_signal_respected",
"ok": true,
"label": "GPC-Signal ohne Tracking-Hinweise",
"detail": "GPC-Aufruf: 0 datenschutzrelevante Domain(s), 0 Drittanbieter-Cookie(s), 0 Storage-Hinweis(e)."
},
{
"id": "no_tracking_cookies_before_consent",
"ok": true,
"label": "Keine Tracking-Cookies vor Einwilligung",
"detail": "0 Tracking-Cookie(s) im Erstaufruf."
},
{
"id": "no_nonessential_cookies_before_consent",
"ok": true,
"label": "Keine nicht notwendigen Cookies vor Einwilligung",
"detail": "0 moeglicherweise nicht notwendige Cookie(s) im Erstaufruf."
},
{
"id": "third_parties_explained",
"ok": true,
"label": "Drittanbieter begrenzt und erklaerbar",
"detail": "0 datenschutzrelevante Drittanbieter-Domain(s), 3 Drittanbieter insgesamt."
},
{
"id": "storage_without_tracking_hints",
"ok": true,
"label": "Web Storage ohne Tracking-Hinweise",
"detail": "4 Storage-Key(s), 0 Tracking-Hinweis(e)."
},
{
"id": "cmp_api_detected_when_needed",
"ok": true,
"label": "CMP-/TCF-Signal bei Tracking erkennbar",
"detail": "Gängige CMP-/TCF-Indikatoren: __tcfapi, __cmp, Cookiebot, OneTrust oder Usercentrics."
},
{
"id": "accept_click_documented",
"ok": true,
"label": "Akzeptieren-Klick nachvollziehbar",
"detail": "Accept-Test: geklickt, neue Requests 8, neue Cookies 7, neue Datenschutz-Domains 0."
},
{
"id": "cmp_state_readable",
"ok": true,
"label": "CMP-/TCF-Zustand auslesbar",
"detail": "TCF TC-String: nein, Cookiebot: ja, 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)",
"4 Storage-Key(s), 0 Tracking-Hinweis(e)",
"Consent-Banner-Controls: Akzeptieren 1, Ablehnen 0, Einstellungen 4",
"Ablehnen/Akzeptieren-Prominenz: nicht messbar",
"Reject-Test: nicht ausgefuehrt, neue Cookies 0, Tracking-Storage 0, neue Datenschutz-Domains 0",
"Accept-Test: geklickt, neue Requests 8, neue Cookies 7, neue Datenschutz-Domains 0, Drittanbieter-Cookies 0",
"CMP-State: TCF-String nein, TCF Purposes 0, TCF Vendors 0, Cookiebot ja, OneTrust-Gruppen 0, Usercentrics-Services 0",
"GPC-Test: aktiv, Datenschutz-Domains 0, Drittanbieter-Cookies 0, Storage-Hinweise 0",
"CMP-/TCF-Signal: ja",
"Google Consent Default: nein"
],
"gpc_enabled": true,
"cmp_detected": true,
"blocking_plan": {
"items": [
{
"kind": "storage",
"level": "mittel",
"source": "localStorage",
"target": "accessibility",
"recipes": [
{
"tool": "Google Tag Manager"
},
{
"tool": "Usercentrics"
},
{
"tool": "Developer-Fallback"
}
],
"category": "unknown",
"evidence": "localStorage · Unklar · dauerhaft bis Löschung durch Nutzer/Browser",
"category_label": "Unklar"
},
{
"kind": "storage",
"level": "mittel",
"source": "localStorage",
"target": "darkMode",
"recipes": [
{
"tool": "Google Tag Manager"
},
{
"tool": "Usercentrics"
},
{
"tool": "Developer-Fallback"
}
],
"category": "unknown",
"evidence": "localStorage · Unklar · dauerhaft bis Löschung durch Nutzer/Browser",
"category_label": "Unklar"
},
{
"kind": "storage",
"level": "mittel",
"source": "localStorage",
"target": "fontFamily",
"recipes": [
{
"tool": "Google Tag Manager"
},
{
"tool": "Usercentrics"
},
{
"tool": "Developer-Fallback"
}
],
"category": "unknown",
"evidence": "localStorage · Unklar · dauerhaft bis Löschung durch Nutzer/Browser",
"category_label": "Unklar"
},
{
"kind": "storage",
"level": "mittel",
"source": "localStorage",
"target": "reducedMotion",
"recipes": [
{
"tool": "Google Tag Manager"
},
{
"tool": "Usercentrics"
},
{
"tool": "Developer-Fallback"
}
],
"category": "unknown",
"evidence": "localStorage · Unklar · dauerhaft bis Löschung durch Nutzer/Browser",
"category_label": "Unklar"
}
],
"summary": "4 Blockier-/Consent-Maßnahme(n) abgeleitet: 0 hoch, 4 mittel.",
"available": true,
"high_count": 0,
"total_count": 4,
"type_counts": {
"storage": 4
},
"medium_count": 4
},
"tcf_api_found": false,
"cookiebot_found": true,
"accept_test_enabled": true,
"browser_cookie_count": 0,
"accept_button_clicked": true,
"browser_storage_count": 4,
"reject_button_clicked": false,
"reject_less_prominent": false,
"tcf_tc_string_present": false,
"tracking_script_count": 0,
"accept_button_available": true,
"reject_button_available": false,
"reject_prominence_ratio": 0,
"pre_consent_cookie_count": 0,
"pre_consent_cookie_names": [],
"tcf_vendor_consent_count": 0,
"third_party_domain_count": 3,
"tcf_purpose_consent_count": 0,
"onetrust_active_group_count": 0,
"usercentrics_services_count": 0,
"browser_accept_control_count": 1,
"browser_cookie_context_found": true,
"browser_reject_control_count": 0,
"gpc_third_party_cookie_count": 0,
"post_accept_new_cookie_count": 7,
"post_reject_new_cookie_count": 0,
"post_accept_new_request_count": 8,
"browser_settings_control_count": 4,
"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": "red",
"score": 46,
"checks": [
{
"ok": true,
"note": "",
"label": "HSTS",
"value": "max-age=31536000",
"header": "strict-transport-security",
"present": true,
"purpose": "Erzwingt HTTPS nach dem ersten sicheren Aufruf.",
"severity": "warning"
},
{
"ok": false,
"note": "Fehlt in der HTTP-Antwort.",
"label": "Content-Security-Policy",
"value": "",
"header": "content-security-policy",
"present": false,
"purpose": "Begrenzt Skript-, Frame- und Ressourcenquellen im Browser.",
"severity": "warning"
},
{
"ok": false,
"note": "Fehlt in der HTTP-Antwort.",
"label": "X-Frame-Options",
"value": "",
"header": "x-frame-options",
"present": false,
"purpose": "Reduziert Clickjacking-Risiken bei älteren Browsern.",
"severity": "warning"
},
{
"ok": false,
"note": "Fehlt in der HTTP-Antwort.",
"label": "X-Content-Type-Options",
"value": "",
"header": "x-content-type-options",
"present": false,
"purpose": "Verhindert MIME-Sniffing bei Skripten und Stylesheets.",
"severity": "warning"
},
{
"ok": false,
"note": "Fehlt in der HTTP-Antwort.",
"label": "Referrer-Policy",
"value": "",
"header": "referrer-policy",
"present": false,
"purpose": "Begrenzt, welche URL-Informationen an Zielseiten weitergegeben werden.",
"severity": "info"
},
{
"ok": false,
"note": "Fehlt in der HTTP-Antwort.",
"label": "Permissions-Policy",
"value": "",
"header": "permissions-policy",
"present": false,
"purpose": "Begrenzt sensible Browser-Funktionen pro Seite.",
"severity": "info"
},
{
"ok": false,
"note": "Fehlt in der HTTP-Antwort.",
"label": "Cross-Origin-Opener-Policy",
"value": "",
"header": "cross-origin-opener-policy",
"present": false,
"purpose": "Isoliert Top-Level-Fenster und reduziert Cross-Origin-Seiteneffekte.",
"severity": "info"
},
{
"ok": false,
"note": "Fehlt in der HTTP-Antwort.",
"label": "Cross-Origin-Resource-Policy",
"value": "",
"header": "cross-origin-resource-policy",
"present": false,
"purpose": "Begrenzt, welche fremden Seiten Ressourcen einbetten dürfen.",
"severity": "info"
},
{
"ok": false,
"note": "Fehlt in der HTTP-Antwort.",
"label": "Cross-Origin-Embedder-Policy",
"value": "",
"header": "cross-origin-embedder-policy",
"present": false,
"purpose": "Erzwingt kontrollierte Cross-Origin-Einbettungen und kann Cross-Origin Isolation ermöglichen.",
"severity": "info"
}
],
"status": "kritisch",
"missing": [
"Content-Security-Policy",
"X-Frame-Options",
"X-Content-Type-Options",
"Referrer-Policy",
"Permissions-Policy",
"Cross-Origin-Opener-Policy",
"Cross-Origin-Resource-Policy",
"Cross-Origin-Embedder-Policy"
],
"summary": "1 von 9 wichtigen Security-Headern vorhanden, 1 korrekt bewertet. Keine Content-Security-Policy gefunden.",
"findings": [],
"ok_count": 1,
"weak_count": 0,
"csp_analysis": {
"color": "red",
"score": 0,
"status": "fehlt",
"summary": "Keine Content-Security-Policy gefunden.",
"enforced": false,
"findings": [],
"available": false,
"directives": [],
"report_only": false,
"finding_count": 0,
"warning_count": 0
},
"missing_count": 8,
"present_count": 1,
"missing_info_count": 5,
"missing_warning_count": 3
},
"infrastructure_analysis": {
"signals": {
"caa": false,
"dnssec": false,
"final_https": true,
"tls_version": "TLSv1.3",
"hsts_enabled": true,
"address_count": 1,
"ipv6_available": false,
"email_protection": {
"mx": false,
"spf": false,
"dmarc": false
},
"certificate_valid": true,
"certificate_issuer": "R13",
"certificate_alt_names": [
"miniweb-hilfe.nuernberg.de"
],
"multiple_ip_addresses": false,
"certificate_expires_at": "Aug 12 10:34:13 2026 GMT",
"certificate_days_remaining": 53,
"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."
]
},
"performance_analysis": {
"score": 94,
"signals": {
"compressed": false,
"duration_ms": 97,
"image_count": 6,
"script_count": 10,
"cache_control": "max-age=60",
"content_length": 0,
"viewport_found": true,
"stylesheet_count": 7
},
"findings": [
{
"id": "too_many_render_blocking_assets",
"title": "Viele potenziell blockierende Assets",
"public": true,
"category": "performance",
"severity": "info"
}
],
"risk_level": "medium"
},
"accessibility_analysis": {
"color": "green",
"score": 92,
"status": "unauffällig",
"signals": {
"h1_count": 1,
"image_count": 6,
"button_count": 49,
"heading_count": 37,
"viewport_found": true,
"html_lang_found": true,
"form_field_count": 0,
"image_missing_alt_count": 0,
"buttons_without_name_count": 1,
"form_fields_without_label_count": 0
},
"summary": "6 Bild(er), 0 Formularfeld(er), 49 Button(s) im passiven HTML-Sample auf Basis-Barrierefreiheit geprüft.",
"findings": [
{
"id": "button_name_missing",
"count": 1,
"title": "Buttons ohne erkennbaren Namen",
"public": true,
"category": "accessibility",
"severity": "warning",
"evidence_items": [
"type=button class=\"button--resize\""
]
}
],
"wcag_matrix": {
"rows": [
{
"id": "wcag_non_text_content",
"ok": true,
"wcag": "WCAG 1.1.1 Non-text Content",
"title": "Alternativtexte für Bilder",
"impact": "niedrig",
"status": "ok",
"evidence": "0 von 6 Bild(er) ohne alt-Text im HTML-Sample."
},
{
"id": "wcag_form_labels",
"ok": true,
"wcag": "WCAG 1.3.1 Info and Relationships / 3.3.2 Labels or Instructions",
"title": "Formularfelder beschriften",
"impact": "niedrig",
"status": "ok",
"evidence": "0 von 0 Formularfeld(er) ohne erkennbare Beschriftung."
},
{
"id": "wcag_button_names",
"ok": false,
"wcag": "WCAG 4.1.2 Name, Role, Value",
"title": "Buttons mit Namen versehen",
"impact": "hoch",
"status": "prüfen",
"evidence": "1 von 49 Button(s) ohne erkennbaren Namen."
},
{
"id": "wcag_page_language",
"ok": true,
"wcag": "WCAG 3.1.1 Language of Page",
"title": "Seitensprache auszeichnen",
"impact": "niedrig",
"status": "ok",
"evidence": "HTML-lang-Attribut gefunden."
},
{
"id": "wcag_heading_structure",
"ok": true,
"wcag": "WCAG 1.3.1 Info and Relationships / 2.4.6 Headings and Labels",
"title": "Überschriftenstruktur",
"impact": "niedrig",
"status": "ok",
"evidence": "1 H1 und 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": "1 WCAG-/EAA-Prüfpunkt(e) auffällig, davon 1 mit hoher Auswirkung.",
"standard": "WCAG 2.2 orientierte Basisprüfung",
"available": true,
"issue_count": 1,
"high_impact_count": 1
}
},
"domain_history": {
"summary": "Domainhistorie konnte per RDAP nicht zuverlässig abgerufen werden.",
"findings": [],
"available": false,
"risk_level": "unknown"
},
"data_entry_analysis": {
"forms": [],
"score": 90,
"summary": "Die Seite kann Newsletter, Zahlung, Kontaktformular abfragen.",
"findings": [],
"form_count": 0,
"risk_level": "low",
"field_count": 0,
"asks_for_data": true,
"payment_providers": [],
"detected_data_types": [
{
"id": "newsletter",
"count": 1,
"label": "Newsletter"
},
{
"id": "payment",
"count": 1,
"label": "Zahlung"
},
{
"id": "contact",
"count": 1,
"label": "Kontaktformular"
}
],
"privacy_context_found": true,
"operator_context_found": true
},
"pii_exposure_analysis": {
"color": "green",
"score": 100,
"checks": [
{
"id": "current_url",
"ok": true,
"count": 0,
"label": "Aktuelle URL",
"detail": "Keine sensiblen Query-Parameter erkannt."
},
{
"id": "link_queries",
"ok": true,
"count": 0,
"label": "Link-Parameter",
"detail": "Keine sensiblen Link-Querys erkannt."
},
{
"id": "get_forms",
"ok": true,
"count": 0,
"label": "GET-Formulare",
"detail": "Keine personenbezogenen GET-Formulare erkannt."
},
{
"id": "external_forms",
"ok": true,
"count": 0,
"label": "Externe Formularziele",
"detail": "Keine externen Formularziele mit personenbezogenen Feldern erkannt."
},
{
"id": "tracking_context",
"ok": true,
"count": 0,
"label": "Tracking neben Dateneingabe",
"detail": "Keine Kombination aus Dateneingabe und datenschutzrelevanten Drittanbietern erkannt."
}
],
"status": "unauffällig",
"summary": "0 PII-/Datenleck-Hinweis(e) aus URL-, Formular- und Browserkontext.",
"findings": [],
"link_hits": [],
"finding_count": 0,
"current_url_hits": [],
"tracking_context": false,
"sensitive_get_forms": []
},
"scan_history_analysis": {
"available": false,
"summary": "Noch kein früherer gespeicherter Scan für diese Domain vorhanden.",
"total_scan_count": 1,
"previous_scan_count": 0,
"history": [
{
"scan_id": "5ecd581b-74f5-4c27-adb2-47936a9008d2",
"created_at": "2026-06-19 21:39:17.329649+02",
"score": 22,
"verdict": "riskant",
"finding_count": 25,
"integrity_root_hash": "5703019bded0464e43ed5323678dffb02c04b84fa1b1a9f98ed5bb717d7ea2b4",
"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": "miniweb-hilfe.nuernberg.de",
"rank": 1,
"score": 22,
"status": "unter_durchschnitt",
"summary": "miniweb-hilfe.nuernberg.de liegt mit 22 Punkten unter dem gespeicherten Durchschnitt von 52.9.",
"available": true,
"peer_count": 8030,
"percentile": 0,
"query_mode": "php_ttl_cache_refresh",
"distribution": {
"0_39": 1259,
"40_59": 3236,
"60_79": 3518,
"80_100": 17
},
"median_score": 58,
"average_score": 52.9,
"comparison_basis": "Neuester gespeicherter SaferPage-Scan je Domain; überwiegend deutschsprachige gespeicherte Checks.",
"same_score_count": 0,
"better_than_count": 0,
"qualified_peer_count": 7721,
"zero_score_count": 309,
"top_quartile_score": 65,
"top_decile_score": 68,
"qualified_average_score": 55,
"qualified_median_score": 59,
"qualified_top_quartile_score": 65,
"qualified_top_decile_score": 69,
"thresholds": [
{
"id": "critical",
"label": "Kritisch",
"range": "0-39",
"met": true
},
{
"id": "basic",
"label": "Basis stabilisieren",
"range": "40-59",
"met": false
},
{
"id": "managed",
"label": "Gesteuert",
"range": "60-79",
"met": false
},
{
"id": "strong",
"label": "Stark",
"range": "80-100",
"met": false
}
],
"risk_tier": "kritisch",
"target_score": 40,
"aspirational_target_score": 69,
"gap_to_target": 18,
"gap_to_top_quartile": 43,
"gap_to_strong": 58,
"cache_ttl_seconds": 300
},
"audit_receipt": {
"url": "https://miniweb-hilfe.nuernberg.de/",
"host": "miniweb-hilfe.nuernberg.de",
"status": "verfügbar",
"bot_url": "https://saferpage.de/bot",
"summary": "Prüfbeleg für miniweb-hilfe.nuernberg.de: kontrollierter HTTP-/Browser-Kurzcheck mit 47 Request(s), 4 Consent-Zustand/Zuständen und 7 Artefakt(en).",
"renderer": "playwright-chromium",
"artifacts": [
{
"label": "Öffentlicher Kurzreport",
"detail": "https://saferpage.de/miniweb-hilfe.nuernberg.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/miniweb-hilfe.nuernberg.de-160x150-f3b244d9f525c66754.png",
"status": "verfügbar"
},
{
"label": "Cookie-Erklärung",
"detail": "4 Cookie-/Storage-Eintrag/Einträge.",
"status": "prüfen"
},
{
"label": "Empfänger-/Anbieterinventar",
"detail": "3 Anbieterzeile(n), 2 AVV-/Rollenprüfung(en).",
"status": "unauffällig"
},
{
"label": "Barrierefreiheitserklärung-Entwurf",
"detail": "1 bekannte Barrierefreiheits-Punkt(e).",
"status": "Nicht vollständig konform im automatischen Basischeck"
}
],
"available": true,
"final_url": "https://www.nuernberg.de/internet/stadtportal/hilfe.html",
"checked_at": "2026-06-19T19:39:16+00:00",
"share_text": "SaferPage Prüfbeleg miniweb-hilfe.nuernberg.de: 47 Browser-Request(s), 3 Drittanbieter, 4 Cookie-/Storage-Einträge, geprüft am 2026-06-19T19:39:16.",
"user_agent": "SaferPageCrawler/0.3 (+https://saferpage.de/bot; schedules passive DACH website checks; report examples: https://saferpage.de/tests; kostenloser Report: <a href=\"https://saferpage.de/miniweb-hilfe.nuernberg.de\">https://saferpage.de/miniweb-hilfe.nuernberg.de</a>)",
"limitations": [
"Öffentliche Nachweise enthalten keine Cookie-Werte und keine vollständigen Request-URLs.",
"Der Scan ist ein passiver Browser- und HTTP-Kurzcheck; rechtliche Bewertung bleibt Betreiberaufgabe.",
"Dynamische Inhalte können sich je nach Region, Zeit, Gerät und Consent-Auswahl ändern."
],
"scan_context": "crawler",
"coverage_items": [
{
"label": "HTTP/DNS/TLS",
"value": "HTTP 200 · DNS ok · TLS ok"
},
{
"label": "Browserlauf",
"value": "47 Request(s), 3 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": "1 priorisierte Unterseite(n) im Nachweispack."
},
{
"label": "Drittanbieter-Auszug",
"value": "3 Anbieterzeile(n) im öffentlichen Nachweis."
},
{
"label": "Cookie-Auszug",
"value": "0 Cookie-Zeile(n) im öffentlichen Nachweis."
}
],
"confidence_score": 78,
"browser_final_url": "https://www.nuernberg.de/internet/stadtportal/hilfe.html"
},
"evidence_integrity_manifest": {
"host": "miniweb-hilfe.nuernberg.de",
"status": "verfügbar",
"summary": "Integritätsmanifest für miniweb-hilfe.nuernberg.de: 9/9 Nachweisbereich(e) mit SHA-256-Hash dokumentiert.",
"sections": [
{
"id": "audit_receipt",
"hash": "af777cd53dacf67ad2c9cb556081de17276fb12ecdfedde1b52a00d4327925bd",
"count": 18,
"label": "Prüfbeleg",
"detail": "Kanonischer JSON-Hash des kompakten Prüfbelegs.",
"status": "verfügbar"
},
{
"id": "protocol",
"hash": "70bc6eaf36830da60e5273d09a8166b4624809ac973fcfd72e095cb1cb6e771d",
"count": 15,
"label": "Scan-Protokoll",
"detail": "URL, Endziel, User-Agent, Zeitstempel, HTTP/DNS/TLS und Renderer.",
"status": "verfügbar"
},
{
"id": "checkpoints",
"hash": "cd0bffc56868c518c62558c4f980758f54576d07a7ea41c0f1b4c0c57194a5f6",
"count": 6,
"label": "Prüfschritte",
"detail": "Kanonischer JSON-Hash der dokumentierten Prüfstationen.",
"status": "verfügbar"
},
{
"id": "consent_states",
"hash": "323fcc35c465046303059eb806d047d428e4ac2c63743d488d052f1c4705c688",
"count": 4,
"label": "Consent-Zustände",
"detail": "Default-, Ablehnen-, Akzeptieren- und GPC-Nachweise soweit verfügbar.",
"status": "verfügbar"
},
{
"id": "third_party_evidence",
"hash": "b6b591173bcc4001a2124f37510d08447243d3576e35bf165e4062e502067275",
"count": 3,
"label": "Drittanbieter-Auszug",
"detail": "Sanitisierte Anbieter-, Kategorie-, Transfer- und Request-Zählwerte.",
"status": "verfügbar"
},
{
"id": "cookie_evidence",
"hash": "4f53cda18c2baa0c0354bb5f9a3ecbe5ed12ab4d8e11ba873c2f11161202b945",
"count": 0,
"label": "Cookie-Auszug",
"detail": "Sanitisierte Cookie-Metadaten ohne Cookie-Werte.",
"status": "leer"
},
{
"id": "request_samples",
"hash": "de203d474d539e87bdf2affff896b9fa7b6f13f7f0da849300d0915017c45881",
"count": 5,
"label": "Request-Samples",
"detail": "Sanitisierte Drittanbieter-Samples ohne vollständige Request-URLs.",
"status": "verfügbar"
},
{
"id": "checked_pages",
"hash": "885028b6d7f30abab6ca483793cb6836016406aaf34d272f1a59e2bdb5eb38fb",
"count": 1,
"label": "Geprüfte Unterseiten",
"detail": "Priorisierte Pfade aus Sitemap, Pflichtseiten und interner Linkstruktur.",
"status": "verfügbar"
},
{
"id": "screenshot_file",
"hash": "4f7b1decfcbf2f9eed0beb7d77a8cc8706d64b574f5454aecd26cc67b5d5bd58",
"count": 4469,
"label": "160x150 Seitenvorschau-Datei",
"detail": "/cache/screenshots/miniweb-hilfe.nuernberg.de-160x150-f3b244d9f525c66754.png",
"status": "verfügbar"
}
],
"algorithm": "sha256",
"available": true,
"root_hash": "5703019bded0464e43ed5323678dffb02c04b84fa1b1a9f98ed5bb717d7ea2b4",
"checked_at": "2026-06-19T19:39:16+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 47 Browser-Request(s), 0 Cookie-Nachweis(en), 3 Drittanbieter-Auszug/auszügen und 4 Consent-Zustand/Zuständen.",
"protocol": {
"host": "miniweb-hilfe.nuernberg.de",
"dns_ok": true,
"tls_ok": true,
"bot_url": "https://saferpage.de/bot",
"renderer": "playwright-chromium",
"final_url": "https://www.nuernberg.de/internet/stadtportal/hilfe.html",
"input_url": "https://miniweb-hilfe.nuernberg.de/",
"checked_at": "2026-06-19T19:39:16+00:00",
"user_agent": "SaferPageCrawler/0.3 (+https://saferpage.de/bot; schedules passive DACH website checks; report examples: https://saferpage.de/tests; kostenloser Report: <a href=\"https://saferpage.de/miniweb-hilfe.nuernberg.de\">https://saferpage.de/miniweb-hilfe.nuernberg.de</a>)",
"http_status": 200,
"scan_context": "crawler",
"screenshot_url": "/cache/screenshots/miniweb-hilfe.nuernberg.de-160x150-f3b244d9f525c66754.png",
"googlebot_status": 200,
"browser_final_url": "https://www.nuernberg.de/internet/stadtportal/hilfe.html",
"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.nuernberg.de/internet/stadtportal/hilfe.html.",
"status": "ok"
},
{
"label": "Browserlauf",
"detail": "47 Request(s), 3 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": "/",
"source": "homepage_link",
"status": 0,
"category": "unterseite"
}
],
"cookie_evidence": [],
"browser_evidence": {
"gpc_enabled": true,
"request_count": 47,
"storage_total": 4,
"accept_clicked": true,
"reject_clicked": false,
"browser_cookie_count": 0,
"contacted_domain_count": 4,
"third_party_domain_count": 3,
"storage_tracking_hint_count": 0,
"privacy_relevant_domain_count": 0
},
"storage_evidence": {
"tracking_key_hints": [],
"local_storage_total": 4,
"session_storage_total": 0
},
"third_party_evidence": [
{
"host": "consent.cookiebot.com",
"category": "Sonstige",
"provider": "consent.cookiebot.com",
"transfer": "Jurisdiktion unklar",
"risk_level": "niedrig",
"request_count": 2,
"resource_types": [
"script"
],
"privacy_relevant": false
},
{
"host": "consentcdn.cookiebot.com",
"category": "Sonstige",
"provider": "consentcdn.cookiebot.com",
"transfer": "Jurisdiktion unklar",
"risk_level": "niedrig",
"request_count": 2,
"resource_types": [
"document",
"xhr"
],
"privacy_relevant": false
},
{
"host": "cms1.stadt.nuernberg.de",
"category": "Sonstige",
"provider": "cms1.stadt.nuernberg.de",
"transfer": "EU/EWR",
"risk_level": "niedrig",
"request_count": 1,
"resource_types": [
"script"
],
"privacy_relevant": false
}
],
"external_script_count": 10,
"consent_state_evidence": [
{
"label": "Erstaufruf",
"cookie_count": 0,
"domain_count": 3,
"request_count": 5,
"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": 3,
"request_count": 8,
"storage_tracking_hint_count": 0,
"privacy_relevant_domain_count": 0
},
{
"label": "GPC-Aufruf",
"cookie_count": 0,
"domain_count": 3,
"request_count": 5,
"storage_tracking_hint_count": 0,
"privacy_relevant_domain_count": 0
}
],
"request_sample_evidence": [
{
"host": "cms1.stadt.nuernberg.de",
"query_keys": [],
"resource_type": "script",
"query_key_count": 0,
"referrer_has_path": false,
"referrer_has_query": false,
"sensitive_query_key_count": 0
},
{
"host": "consent.cookiebot.com",
"query_keys": [],
"resource_type": "script",
"query_key_count": 0,
"referrer_has_path": false,
"referrer_has_query": false,
"sensitive_query_key_count": 0
},
{
"host": "consentcdn.cookiebot.com",
"query_keys": [],
"resource_type": "document",
"query_key_count": 0,
"referrer_has_path": false,
"referrer_has_query": false,
"sensitive_query_key_count": 0
},
{
"host": "consentcdn.cookiebot.com",
"query_keys": [],
"resource_type": "xhr",
"query_key_count": 0,
"referrer_has_path": false,
"referrer_has_query": false,
"sensitive_query_key_count": 0
},
{
"host": "consent.cookiebot.com",
"query_keys": [
"renew",
"referer",
"dnt",
"init",
"culture"
],
"resource_type": "script",
"query_key_count": 5,
"referrer_has_path": false,
"referrer_has_query": false,
"sensitive_query_key_count": 0
}
]
},
"consent_visual_salience_evidence": {
"schema": "https://saferpage.de/schemas/consent-visual-salience-evidence.v1",
"status": "accept_without_visible_reject_signal",
"available": true,
"evidence_level": "dom_viewport_signal_only",
"summary": "Der erste Headless-Chromium-Viewport liefert sichtbare Consent-Control-Signale mit Text, Position, Groesse und typografischen Hinweisen.",
"sample_status": "classified_control_samples",
"classified_sample_count": 4,
"accept_control_count": 1,
"reject_control_count": 0,
"settings_control_count": 4,
"visible_control_count": 27,
"accept_max_area": 11822,
"reject_max_area": 0,
"reject_prominence_ratio": "nicht messbar",
"samples": [
{
"kind": "accept",
"text": "Meine Auswahl erlauben",
"tag": "a",
"width": 240,
"height": 49,
"area": 11822,
"top": 759,
"left": 353,
"font_weight": "400"
},
{
"kind": "settings",
"text": "Meine Auswahl erlauben",
"tag": "a",
"width": 240,
"height": 49,
"area": 11822,
"top": 759,
"left": 353,
"font_weight": "400"
},
{
"kind": "settings",
"text": "Ansicht anpassen",
"tag": "button",
"width": 52,
"height": 64,
"area": 3328,
"top": 0,
"left": 236,
"font_weight": "400"
},
{
"kind": "settings",
"text": "Vorlesen Einstellungen",
"tag": "button",
"width": 30,
"height": 26,
"area": 780,
"top": 639,
"left": 79,
"font_weight": "400"
}
],
"sample_boundary": "Samples enthalten nur klassifizierte Accept-/Reject-/Settings-Controls. Weitere sichtbare Consent-Controls bleiben als Zaehler erhalten, werden aber ohne Klassifizierung nicht als Ablehnen-, Akzeptieren- oder Einstellungsprobe behauptet.",
"claim_boundary": "Consent-Visual-Salienz ist ein DOM-/Viewport-Signal aus dem ersten Browserlauf. Sie ist keine Rechtsbewertung, kein Dark-Pattern-Endurteil und kein Nachweis fuer spaetere Consent-Zustaende, Scrollbereiche, Loginbereiche oder manuelle Betreiberkontexte."
}
}