UUID-Generator

Generieren und validieren Sie UUIDs (v1, v4, v5, v7) mit Batch-Unterstützung, vielfältigen Formatierungsoptionen und mehrsprachigen Code-Beispielen.

UUID-Generator

Formatierungsoptionen

UUID-Validator

Verwendungshinweise

UUIDs sind 128-Bit-Identifikatoren, die standardmäßig als 36 Zeichen lange Zeichenfolge mit Bindestrichen dargestellt werden.
UUID v1: Basierend auf Zeitstempel und MAC-Adresse – zeitlich sortierbar, aber kann Zeit/Standort preisgeben.
UUID v4: Zufallsbasiert – am häufigsten genutzt, bietet gute Einzigartigkeit und Privatsphäre.
UUID v7: Basierend auf Unix-Millisekundenzeit + Zufall – natürliche Sortierbarkeit ohne die Privatsphärenprobleme von v1.
UUID v5: Basierend auf einem Namespace-UUID und einem Namen über SHA-1; gleiche Eingaben ergeben immer denselben Wert.
Standardformat: xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx (36 Zeichen).

Funktionen

  • Unterstützt UUID v1, v4, v5, v7
  • Batch-Generierung mit benutzerdefinierter Anzahl
  • Flexibles Formatieren: Großbuchstaben, Bindestriche entfernen, geschweifte Klammern hinzufügen
  • Integrierter Validator mit Versionserkennung
  • Vollständige Internationalisierung und Mehrthemen-Unterstützung

Was ist eine UUID?

UUIDs sind 128-Bit-Identifikatoren, die standardmäßig als 36 Zeichen lange Zeichenfolge mit Bindestrichen dargestellt werden.

UUID v1: Basierend auf Zeitstempel und MAC-Adresse – zeitlich sortierbar, aber kann Zeit/Standort preisgeben.

UUID v4: Zufallsbasiert – am häufigsten genutzt, bietet gute Einzigartigkeit und Privatsphäre.

UUID v7: Basierend auf Unix-Millisekundenzeit + Zufall – natürliche Sortierbarkeit ohne die Privatsphärenprobleme von v1.

UUID v5: Basierend auf einem Namespace-UUID und einem Namen über SHA-1; gleiche Eingaben ergeben immer denselben Wert.

UUID Schnellbeispiele

Standardformat:
550e8400-e29b-41d4-a716-446655440000
Großschreibung:
550E8400-E29B-41D4-A716-446655440000
Ohne Bindestriche:
550e8400e29b41d4a716446655440000
Mit geschweiften Klammern:
{550e8400-e29b-41d4-a716-446655440000}

UUID Häufige Anwendungsfälle

  • Einzigartige Kennungen für Datenbankrecords oder Ressourcen
  • Trace-ID für Protokollierung und Ereignisverfolgung
  • Schwer vorhersagbare öffentliche Identifikatoren
  • Einheitliche Identifikatoren in Schnittstellen zwischen Systemen

UUID Häufige Fragen & Fallstricke

  • v1 und Datenschutz: v1 kann Zeit und Standort preisgeben – bei Datenschutzbedenken empfiehlt sich v4.
  • Groß-/Kleinschreibung gleichwertig?: Ja, Vergleiche sind case-insensitiv.
  • Bindestriche dienen nur der Lesbarkeit – behalten Sie sie, es sei denn, das System verlangt etwas anderes.
  • Die Form mit geschweiften Klammern wird in einigen Umgebungen akzeptiert (z. B. Windows-Registrierung).
  • v5 ist deterministisch (gleicher Namespace + Name → gleiche UUID). Ideal für idempotente Szenarien, nicht geeignet für unvorhersehbare Anforderungen.

Wie man UUIDs in Programmiersprachen verwendet

JavaScript
Generieren
// UUID v4 (simple)
function uuidv4(){
  return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, c => {
    const r = Math.random()*16|0, v = c === 'x' ? r : (r&0x3|0x8);
    return v.toString(16);
  });
}
const id = uuidv4();
UUID v7 (Unix-Zeit + Zufall)
// UUID v7 (Unix ms + randomness)
function uuidv7(){
  const cryptoObj = (globalThis.crypto || globalThis.msCrypto);
  const rb = n => { const a = new Uint8Array(n); cryptoObj?.getRandomValues ? cryptoObj.getRandomValues(a) : a.forEach((_,i)=>a[i]=Math.random()*256|0); return a; };
  const hex = b => Array.from(b).map(x=>x.toString(16).padStart(2,'0')).join('');
  const ts = BigInt(Date.now()).toString(16).padStart(12,'0');
  const ver = rb(2); ver[0] = (ver[0] & 0x0f) | 0x70;    // set version 7
  const vrn = rb(2); vrn[0] = (vrn[0] & 0x3f) | 0x80;    // RFC4122 variant
  const tail = rb(6);
  return `${ts.slice(0,8)}-${ts.slice(8,12)}-${hex(ver)}-${hex(vrn)}-${hex(tail)}`;
}
const id7 = uuidv7();
Validieren
const re=/^[0-9a-f]{8}-[0-9a-f]{4}-[1-57][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}$/i;
re.test(id); // true/false
PHP
Generieren
<?php
// v4 using random_bytes
function uuidv4(){
  $data = random_bytes(16);
  $data[6] = chr((ord($data[6]) & 0x0f) | 0x40);
  $data[8] = chr((ord($data[8]) & 0x3f) | 0x80);
  return vsprintf('%s%s-%s-%s-%s-%s%s%s', str_split(bin2hex($data), 4));
}
$id = uuidv4();
UUID v7 (Unix-Zeit + Zufall)
<?php
// composer require ramsey/uuid:^4.7
use Ramsey\Uuid\Uuid;

$uuid7 = Uuid::uuid7();
Validieren
<?php
$re = '/^[0-9a-f]{8}-[0-9a-f]{4}-[1-57][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}$/i';
preg_match($re, $id) === 1; // true/false
Python
Generieren
import uuid
# v4
uid = uuid.uuid4()
# v1
uid1 = uuid.uuid1()
UUID v7 (Unix-Zeit + Zufall)
# pip install uuid6
from uuid6 import uuid7

uid7 = uuid7()
Validieren
import re
re_uuid = re.compile(r'^[0-9a-f]{8}-[0-9a-f]{4}-[1-57][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}$', re.I)
bool(re_uuid.match(str(uid)))
Go
Generieren
// go get github.com/google/uuid
import "github.com/google/uuid"

id := uuid.New()     // v4
id1 := uuid.NewUUID() // v1 (may return error)
UUID v7 (Unix-Zeit + Zufall)
// go get github.com/gofrs/uuid/v5
import (
  uuid "github.com/gofrs/uuid/v5"
)

id7, err := uuid.NewV7()
Validieren
import "github.com/google/uuid"
_, err := uuid.Parse(id.String()) // err == nil means valid
Rust
Generieren
// Cargo.toml: uuid = { version = "1", features = ["v4", "v1"] }
use uuid::Uuid;

let v4 = Uuid::new_v4();
// v1 requires a context/ts, often via external crate; shown for completeness
UUID v7 (Unix-Zeit + Zufall)
// Cargo.toml: uuid = { version = "1", features = ["v7"] }
use uuid::Uuid;

let v7 = Uuid::now_v7();
Validieren
use uuid::Uuid;
let ok = Uuid::parse_str(v4.to_string().as_str()).is_ok();
Java
Generieren
import java.util.UUID;

UUID id = UUID.randomUUID(); // v4
UUID v7 (Unix-Zeit + Zufall)
// Maven: com.github.f4b6a3:uuid-creator
import com.github.f4b6a3.uuid.UuidCreator;

UUID v7 = UuidCreator.getTimeOrderedEpoch(); // UUIDv7
Validieren
import java.util.UUID;

try { UUID.fromString(id.toString()); /* valid */ } catch (IllegalArgumentException ex) { /* invalid */ }