Bezpłatne publiczne API IP bez uwierzytelniania. Cztery endpointy zwracają IPv4, IPv6, ISP, ASN, geolokalizację i strefę czasową — w JSON lub tekście.
# 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/
Zwraca pełny obiekt JSON ze wszystkimi dostępnymi danymi o adresie IP wywołującego.
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"
}
| Pole | Typ | Opis |
|---|---|---|
| status | string | "ok" lub "partial" jeśli geolokalizacja nie powiodła się |
| ip | string | Wykryty IP (może być IPv4 lub IPv6) |
| ipv4 | string | null | Adres IPv4 jeśli dostępny |
| ipv6 | string | null | Adres IPv6 jeśli dostępny |
| isp | string | null | Nazwa dostawcy internetu |
| asn | string | null | Numer systemu autonomicznego (np. "AS3269") |
| timezone | string | null | Strefa czasowa IANA (np. "Europe/Rome") |
| datetime | string | Data/czas ISO 8601 w strefie czasowej wywołującego |
| geo.city | string | null | Przybliżona nazwa miasta |
| geo.region | string | null | Region / województwo |
| geo.country | string | null | Nazwa kraju |
| geo.lat / geo.lon | float | null | Przybliżone współrzędne |
| cached | boolean | true jeśli wynik pochodzi z 1h pamięci podręcznej |
Zwraca IPv4 i IPv6 w dwóch osobnych wierszach. Zwraca NONE, gdy protokół jest niedostępny.
curl https://ippubblico.org/?text=1
IPv4: 93.45.12.88 IPv6: NONE
Zwraca tylko adres IPv4 jako zwykły tekst, lub NONE jeśli niedostępny.
curl https://ipv4.ippubblico.org/
93.45.12.88
Zwraca tylko adres IPv6 jako zwykły tekst, lub NONE jeśli niedostępny.
curl https://ipv6.ippubblico.org/
2001:db8::1
# Pełny JSON curl https://ippubblico.org/?api=1 # Tylko IPv4 MY_IP=$(curl -s https://ipv4.ippubblico.org/) echo "My IPv4: $MY_IP" # Tylko 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 wymusza połączenie IPv4 przez rekord DNS Aipv6.ippubblico.org wymusza połączenie IPv6 przez rekord DNS AAAAPełna strona jest dostępna w 43 językach. Sam API jest niezależny od języka.