Kostenlose IP-API ohne Authentifizierung. Vier Endpunkte liefern IPv4, IPv6, ISP, ASN, Geolokalisierung und Zeitzone — als JSON oder Text.
# Full data (JSON) https://ippubblico.org/?api=1 # IPv4 + IPv6 (plain text, 2 lines) https://ippubblico.org/?text=1 # IPv4 only https://ipv4.ippubblico.org/ # IPv6 only https://ipv6.ippubblico.org/
Gibt ein vollständiges JSON-Objekt mit allen verfügbaren Daten über die IP-Adresse des Aufrufers zurück.
curl https://ippubblico.org/?api=1
{
"status": "ok",
"ip": "93.45.12.88",
"ipv4": "93.45.12.88",
"ipv6": null,
"isp": "Telecom Italia S.p.A.",
"asn": "AS3269",
"timezone": "Europe/Rome",
"datetime": "2026-05-05T12:00:00+02:00",
"geo": {
"city": "Rome",
"region": "Lazio",
"country": "Italy",
"lat": 41.9028,
"lon": 12.4964
},
"headers": { /* HTTP request headers */ },
"cached": false,
"lang": "en"
}
| Feld | Typ | Beschreibung |
|---|---|---|
| status | string | "ok" oder "partial" wenn Geolokalisierung fehlgeschlagen |
| ip | string | Erkannte IP (IPv4 oder IPv6) |
| ipv4 | string | null | IPv4-Adresse falls verfügbar |
| ipv6 | string | null | IPv6-Adresse falls verfügbar |
| isp | string | null | Name des Internetanbieters |
| asn | string | null | Autonome Systemnummer (z.B. "AS3269") |
| timezone | string | null | IANA-Zeitzone (z.B. "Europe/Rome") |
| datetime | string | ISO 8601 Datum/Uhrzeit in der Zeitzone des Aufrufers |
| geo.city | string | null | Ungefährer Stadtname |
| geo.region | string | null | Region / Bundesland |
| geo.country | string | null | Ländername |
| geo.lat / geo.lon | float | null | Ungefähre Koordinaten |
| cached | boolean | true wenn Ergebnis aus 1h-Cache |
Gibt IPv4 und IPv6 in zwei getrennten Zeilen zurück. Gibt NONE zurück, wenn ein Protokoll nicht verfügbar ist.
curl https://ippubblico.org/?text=1
IPv4: 93.45.12.88 IPv6: NONE
Gibt nur die IPv4-Adresse als Klartext zurück, oder NONE wenn nicht verfügbar.
curl https://ipv4.ippubblico.org/
93.45.12.88
Gibt nur die IPv6-Adresse als Klartext zurück, oder NONE wenn nicht verfügbar.
curl https://ipv6.ippubblico.org/
2001:db8::1
# Vollständiges JSON curl https://ippubblico.org/?api=1 # Nur IPv4 MY_IP=$(curl -s https://ipv4.ippubblico.org/) echo "My IPv4: $MY_IP" # Nur IPv6 MY_IPV6=$(curl -s https://ipv6.ippubblico.org/) echo "My IPv6: $MY_IPV6"
// Full JSON const res = await fetch('https://ippubblico.org/?api=1'); const data = await res.json(); console.log(data.ipv4, data.ipv6, data.geo.country); // IPv4 only const ipv4 = await fetch('https://ipv4.ippubblico.org/').then(r => r.text()); console.log('IPv4:', ipv4);
import requests # Full JSON data = requests.get('https://ippubblico.org/?api=1').json() print(data['ipv4'], data['geo']['country']) # IPv4 only ipv4 = requests.get('https://ipv4.ippubblico.org/').text.strip() print(f'IPv4: {ipv4}')
// Full JSON $data = json_decode(file_get_contents('https://ippubblico.org/?api=1'), true); echo $data['ipv4']; // IPv4 only $ipv4 = trim(file_get_contents('https://ipv4.ippubblico.org/'));
resp, _ := http.Get("https://ipv4.ippubblico.org/") body, _ := io.ReadAll(resp.Body) fmt.Println("IPv4:", strings.TrimSpace(string(body)))
$ip = (Invoke-WebRequest 'https://ipv4.ippubblico.org/').Content.Trim() Write-Host "IPv4: $ip"
require 'open-uri' ipv4 = URI.open('https://ipv4.ippubblico.org/').read.strip puts "IPv4: #{ipv4}"
var client = new HttpClient(); var ipv4 = (await client.GetStringAsync("https://ipv4.ippubblico.org/")).Trim(); Console.WriteLine($"IPv4: {ipv4}");
ipv4.ippubblico.org erzwingt IPv4-Verbindung über DNS-A-Eintragipv6.ippubblico.org erzwingt IPv6-Verbindung über DNS-AAAA-EintragDie Website ist in 43 Sprachen verfügbar. Die API selbst ist sprachunabhängig.