API IP pubblica gratuita, senza autenticazione. Quattro endpoint che restituiscono IPv4, IPv6, ISP, ASN, geolocalizzazione e fuso orario — in JSON o testo.
# 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/
Restituisce un oggetto JSON completo con tutti i dati disponibili sull'indirizzo IP del chiamante.
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"
}
| Campo | Tipo | Descrizione |
|---|---|---|
| status | string | "ok" o "partial" se la geolocalizzazione è fallita |
| ip | string | IP rilevato (può essere IPv4 o IPv6) |
| ipv4 | string | null | Indirizzo IPv4 se disponibile |
| ipv6 | string | null | Indirizzo IPv6 se disponibile |
| isp | string | null | Nome del provider internet |
| asn | string | null | Numero di sistema autonomo (es. "AS3269") |
| timezone | string | null | Fuso orario IANA (es. "Europe/Rome") |
| datetime | string | Data/ora ISO 8601 nel fuso orario del chiamante |
| geo.city | string | null | Nome città approssimativo |
| geo.region | string | null | Regione / stato |
| geo.country | string | null | Nome paese |
| geo.lat / geo.lon | float | null | Coordinate approssimative |
| cached | boolean | true se il risultato proviene dalla cache di 1h |
Restituisce IPv4 e IPv6 su due righe separate. Restituisce NONE se un protocollo non è disponibile.
curl https://ippubblico.org/?text=1
IPv4: 93.45.12.88 IPv6: NONE
Restituisce solo l'indirizzo IPv4 come testo semplice, oppure NONE se non disponibile.
curl https://ipv4.ippubblico.org/
93.45.12.88
Restituisce solo l'indirizzo IPv6 come testo semplice, oppure NONE se non disponibile.
curl https://ipv6.ippubblico.org/
2001:db8::1
# JSON completo curl https://ippubblico.org/?api=1 # Solo IPv4 MY_IP=$(curl -s https://ipv4.ippubblico.org/) echo "My IPv4: $MY_IP" # Solo 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 forza la connessione IPv4 tramite solo record DNS Aipv6.ippubblico.org forza la connessione IPv6 tramite solo record DNS AAAAIl sito completo è disponibile in 43 lingue. Le API stesse sono indipendenti dalla lingua.