JSON-Kodierung
Kodieren Sie Lua-Tabellen zu JSON und dekodieren Sie JSON-Strings zu Lua-Werten. Enthält JSON-Schema-Validierung für Datenverifizierung und API-Vertragserzwingung.
Laden
local json = require("json")
Kodierung
Wert kodieren
Kodiert einen Lua-Wert in einen JSON-String.
-- Einfache Werte
json.encode("hello") -- '"hello"'
json.encode(42) -- '42'
json.encode(true) -- 'true'
json.encode(nil) -- 'null'
-- Arrays (sequentielle numerische Schlüssel)
json.encode({1, 2, 3}) -- '[1,2,3]'
json.encode({"a", "b"}) -- '["a","b"]'
-- Objekte (String-Schlüssel)
local user = {name = "Alice", age = 30}
json.encode(user) -- '{"name":"Alice","age":30}'
-- Verschachtelte Strukturen
local order = {
id = "ord-123",
items = {
{sku = "ABC", qty = 2},
{sku = "XYZ", qty = 1}
},
total = 99.50
}
json.encode(order)
-- '{"id":"ord-123","items":[{"sku":"ABC","qty":2},{"sku":"XYZ","qty":1}],"total":99.5}'
| Parameter | Typ | Beschreibung |
|---|---|---|
value |
any | Zu kodierender Lua-Wert |
Gibt zurück: string, error
Kodierungsregeln:
nilwird zunull- Leere Tabellen werden zu
[](oder{}wenn mit String-Schlüsseln erstellt) - Tabellen mit sequentiellen 1-basierten Schlüsseln werden zu Arrays
- Tabellen mit String-Schlüsseln werden zu Objekten
- Gemischte numerische und String-Schlüssel verursachen einen Fehler
- Sparse-Arrays (Lücken in Indizes) verursachen einen Fehler
- Inf/NaN-Zahlen werden zu
null - Rekursive Tabellenreferenzen verursachen einen Fehler
- Maximale Verschachtelungstiefe ist 128 Ebenen
Dekodierung
String dekodieren
Dekodiert einen JSON-String in einen Lua-Wert.
-- Objekt parsen
local user, err = json.decode('{"name":"Bob","active":true}')
if err then
return nil, err
end
print(user.name) -- "Bob"
print(user.active) -- true
-- Array parsen
local items = json.decode('[10, 20, 30]')
print(items[1]) -- 10
print(#items) -- 3
-- Verschachtelte Daten parsen
local response = json.decode([[
{
"status": "ok",
"data": {
"users": [
{"id": 1, "name": "Alice"},
{"id": 2, "name": "Bob"}
]
}
}
]])
print(response.data.users[1].name) -- "Alice"
-- Fehler behandeln
local data, err = json.decode("not valid json")
if err then
print(err:kind()) -- "INTERNAL"
print(err:message()) -- Parse-Fehlerdetails
end
| Parameter | Typ | Beschreibung |
|---|---|---|
str |
string | Zu dekodierender JSON-String |
Gibt zurück: any, error
Schema-Validierung
Wert validieren
Validiert einen Lua-Wert gegen ein JSON-Schema. Verwenden Sie dies, um API-Verträge durchzusetzen oder Benutzereingaben zu validieren.
-- Schema definieren
local user_schema = {
type = "object",
properties = {
name = {type = "string", minLength = 1},
email = {type = "string", format = "email"},
age = {type = "integer", minimum = 0, maximum = 150}
},
required = {"name", "email"}
}
-- Gültige Daten bestehen
local valid, err = json.validate(user_schema, {
name = "Alice",
email = "alice@example.com",
age = 30
})
print(valid) -- true
-- Ungültige Daten scheitern mit Details
local valid, err = json.validate(user_schema, {
name = "",
email = "not-an-email"
})
if not valid then
print(err:message()) -- Validierungsfehlerdetails
end
-- Schema kann auch ein JSON-String sein
local schema_json = '{"type":"number","minimum":0}'
local valid = json.validate(schema_json, 42)
| Parameter | Typ | Beschreibung |
|---|---|---|
schema |
table oder string | JSON-Schema-Definition |
data |
any | Zu validierender Wert |
Gibt zurück: boolean, error
Schemas werden nach Inhalts-Hash für bessere Performance gecacht.
JSON-String validieren
Validiert einen JSON-String gegen ein Schema ohne vorher zu dekodieren. Nützlich, wenn Sie vor dem Parsen validieren müssen.
local schema = {
type = "object",
properties = {
action = {type = "string", enum = {"create", "update", "delete"}}
},
required = {"action"}
}
-- Rohen JSON aus Request-Body validieren
local body = '{"action":"create","data":{}}'
local valid, err = json.validate_string(schema, body)
if not valid then
return nil, errors.new("INVALID", "Invalid request: " .. err:message())
end
-- Jetzt sicher zu dekodieren
local request = json.decode(body)
| Parameter | Typ | Beschreibung |
|---|---|---|
schema |
table oder string | JSON-Schema-Definition |
json_str |
string | Zu validierender JSON-String |
Gibt zurück: boolean, error
Fehler
| Bedingung | Art | Wiederholbar |
|---|---|---|
| Rekursive Tabellenreferenz | errors.INTERNAL |
nein |
| Sparse-Array (Lücken in Indizes) | errors.INTERNAL |
nein |
| Gemischte Schlüsseltypen in Tabelle | errors.INTERNAL |
nein |
| Verschachtelung überschreitet 128 Ebenen | errors.INTERNAL |
nein |
| Ungültige JSON-Syntax | errors.INTERNAL |
nein |
| Schema-Kompilierung fehlgeschlagen | errors.INVALID |
nein |
| Validierung fehlgeschlagen | errors.INVALID |
nein |
Siehe Fehlerbehandlung für die Arbeit mit Fehlern.