Quickstart Guide
Erstelle deine erste E-Rechnung in unter 5 Minuten. Kein SDK nötig – nur ein HTTP-Request.
API Key erstellen
Registriere dich kostenlos und hole dir deinen API Key aus dem Dashboard.
Request senden
Sende deine Rechnungsdaten als JSON an unsere API.
E-Rechnung erhalten
Erhalte eine validierte XRechnung oder ZUGFeRD zurück.
API Key erstellen
Erstelle einen kostenlosen Account und generiere deinen API Key im Dashboard. Du erhältst zwei Keys:
- Test
sk_test_...Für Entwicklung und Testing (keine Kosten)
- Live
sk_live_...Für Production (Pay-per-Use)
Dein API Key
sk_test_abc123xyz...Halte deinen API Key geheim. Teile ihn nie öffentlich.
Erste E-Rechnung erstellen
Sende einen POST-Request an /api/v1/invoice/de/xrechnung/generate mit deinen Rechnungsdaten. Hier ein vollständiges Beispiel:
https://service.invoice-api.xhub.io/api/v1/invoice/de/xrechnung/generate1curl -X POST https://service.invoice-api.xhub.io/api/v1/invoice/de/xrechnung/generate \2 -H "Authorization: Bearer sk_test_abc123..." \3 -H "Content-Type: application/json" \4 -d '{5 "invoice": {6 "invoiceNumber": "RE-2026-001",7 "type": "invoice",8 "issueDate": "2026-04-10",9 "dueDate": "2026-05-10",10 "currency": "EUR",11 "seller": {12 "name": "Meine Firma GmbH",13 "vatId": "DE123456789",14 "street": "Musterstraße 1",15 "city": "Berlin",16 "postalCode": "10115",17 "countryCode": "DE"18 },19 "buyer": {20 "name": "Kunde AG",21 "vatId": "DE987654321",22 "street": "Kundenweg 42",23 "city": "München",24 "postalCode": "80331",25 "countryCode": "DE"26 },27 "countrySpecific": { "buyerReference": "BUYER-REF-001" },28 "items": [29 {30 "position": 1,31 "description": "Beratungsleistung",32 "quantity": 10,33 "unit": "HUR",34 "unitPrice": 150.00,35 "taxRate": 19,36 "netAmount": 1500.00,37 "taxAmount": 285.00,38 "grossAmount": 1785.0039 }40 ],41 "subtotal": 1500.00,42 "total": 1785.00,43 "taxSummary": [{ "taxRate": 19, "netAmount": 1500.00, "taxAmount": 285.00 }],44 "paymentTerms": { "dueDays": 30 }45 }46 }'Response verstehen
Bei Erfolg erhältst du einen 200 OK mit der erstellten Rechnung. Die Response enthält die Validierungs-Ergebnisse und Download-URLs:
1{2 "success": true,3 "format": "xrechnung",4 "filename": "invoice-2025-001.xml",5 "mimeType": "application/xml",6 "hash": "sha256:abc123...",7 "data": "PD94bWwgdmVyc2lvbj0iMS4wIj8+...",8 "errors": [],9 "warnings": []10}success
true bedeutet die Rechnung wurde erfolgreich generiert.
data
Base64-kodiertes Dokument (XML oder PDF je nach Format).
errors / warnings
Validierungsfehler und -warnungen als Array.
Code-Beispiele
Node.js / TypeScript
1const response = await fetch('https://service.invoice-api.xhub.io/api/v1/invoice/de/xrechnung/generate', {2 method: 'POST',3 headers: {4 'Authorization': 'Bearer sk_test_abc123...',5 'Content-Type': 'application/json'6 },7 body: JSON.stringify({8 invoice: {9 invoiceNumber: 'RE-2026-001',10 type: 'invoice',11 issueDate: '2026-04-10',12 dueDate: '2026-05-10',13 currency: 'EUR',14 seller: {15 name: 'Meine Firma GmbH', vatId: 'DE123456789',16 street: 'Musterstraße 1', city: 'Berlin', postalCode: '10115', countryCode: 'DE'17 },18 buyer: {19 name: 'Kunde AG', vatId: 'DE987654321',20 street: 'Kundenweg 42', city: 'München', postalCode: '80331', countryCode: 'DE'21 },22 countrySpecific: { buyerReference: 'BUYER-REF-001' },23 items: [24 { position: 1, description: 'Beratungsleistung', quantity: 10, unit: 'HUR',25 unitPrice: 150, taxRate: 19, netAmount: 1500, taxAmount: 285, grossAmount: 1785 }26 ],27 subtotal: 1500, total: 1785,28 taxSummary: [{ taxRate: 19, netAmount: 1500, taxAmount: 285 }],29 paymentTerms: { dueDays: 30 }30 }31 })32});33 34const result = await response.json();35const xmlData = atob(result.data); // Base64 decode to get XMLPython
1import requests2import base643 4response = requests.post(5 'https://service.invoice-api.xhub.io/api/v1/invoice/de/xrechnung/generate',6 headers={7 'Authorization': 'Bearer sk_test_abc123...',8 'Content-Type': 'application/json'9 },10 json={11 'invoice': {12 'invoiceNumber': 'RE-2026-001',13 'type': 'invoice',14 'issueDate': '2026-04-10',15 'dueDate': '2026-05-10',16 'currency': 'EUR',17 'seller': {18 'name': 'Meine Firma GmbH', 'vatId': 'DE123456789',19 'street': 'Musterstraße 1', 'city': 'Berlin', 'postalCode': '10115', 'countryCode': 'DE'20 },21 'buyer': {22 'name': 'Kunde AG', 'vatId': 'DE987654321',23 'street': 'Kundenweg 42', 'city': 'München', 'postalCode': '80331', 'countryCode': 'DE'24 },25 'countrySpecific': {'buyerReference': 'BUYER-REF-001'},26 'items': [27 {'position': 1, 'description': 'Beratungsleistung', 'quantity': 10, 'unit': 'HUR',28 'unitPrice': 150, 'taxRate': 19, 'netAmount': 1500, 'taxAmount': 285, 'grossAmount': 1785}29 ],30 'subtotal': 1500, 'total': 1785,31 'taxSummary': [{'taxRate': 19, 'netAmount': 1500, 'taxAmount': 285}],32 'paymentTerms': {'dueDays': 30}33 }34 }35)36 37result = response.json()38xml_data = base64.b64decode(result['data']) # Base64 decode to get XML