API Pública IPPubblico

API de IP pública gratuita, sin autenticación. Cuatro endpoints que devuelven IPv4, IPv6, ISP, ASN, geolocalización y zona horaria — en JSON o texto.

✓ Gratis para siempre ✓ Sin clave API ✓ Sin límite de velocidad JSON & Plain text CORS enabled

URLs base endpoints

endpoints
# 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/

Endpoints reference

GET https://ippubblico.org/?api=1 Respuesta JSON completa

Devuelve un objeto JSON completo con todos los datos disponibles sobre la IP del llamante.

curl
curl https://ippubblico.org/?api=1
Response — application/json
{
  "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"
}
CampoTipoDescripción
statusstring"ok" o "partial" si la geolocalización falló
ipstringIP detectada (puede ser IPv4 o IPv6)
ipv4string | nullDirección IPv4 si está disponible
ipv6string | nullDirección IPv6 si está disponible
ispstring | nullNombre del proveedor de servicios de Internet
asnstring | nullNúmero de Sistema Autónomo (ej. "AS3269")
timezonestring | nullZona horaria IANA (ej. "Europe/Rome")
datetimestringFecha/hora ISO 8601 en la zona horaria del llamante
geo.citystring | nullNombre de ciudad aproximado
geo.regionstring | nullRegión / estado
geo.countrystring | nullNombre del país
geo.lat / geo.lonfloat | nullCoordenadas aproximadas
cachedbooleantrue si el resultado se sirve desde caché de 1h
GET https://ippubblico.org/?text=1 Texto plano — IPv4 + IPv6

Devuelve IPv4 e IPv6 en dos líneas separadas. Devuelve NONE si un protocolo no está disponible.

curl
curl https://ippubblico.org/?text=1
Response — text/plain
IPv4: 93.45.12.88
IPv6: NONE
GET https://ipv4.ippubblico.org/ Solo IPv4

Devuelve solo la dirección IPv4 como texto plano, o NONE si no está disponible.

curl
curl https://ipv4.ippubblico.org/
Response — text/plain
93.45.12.88
GET https://ipv6.ippubblico.org/ Solo IPv6

Devuelve solo la dirección IPv6 como texto plano, o NONE si no está disponible.

curl
curl https://ipv6.ippubblico.org/
Response — text/plain
2001:db8::1

Ejemplos de código samples

bash / curl
# 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"
JavaScript (fetch)
// 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);
Python
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}')
PHP
// 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/'));
Go
resp, _ := http.Get("https://ipv4.ippubblico.org/")
body, _ := io.ReadAll(resp.Body)
fmt.Println("IPv4:", strings.TrimSpace(string(body)))
PowerShell
$ip = (Invoke-WebRequest 'https://ipv4.ippubblico.org/').Content.Trim()
Write-Host "IPv4: $ip"
Ruby
require 'open-uri'
ipv4 = URI.open('https://ipv4.ippubblico.org/').read.strip
puts "IPv4: #{ipv4}"
C# / .NET
var client = new HttpClient();
var ipv4 = (await client.GetStringAsync("https://ipv4.ippubblico.org/")).Trim();
Console.WriteLine($"IPv4: {ipv4}");

Notas info

  • Sin autenticación — no se requiere clave ni token de API
  • CORS habilitado — utilizable desde JavaScript del navegador en cualquier dominio
  • Caché 1h — datos de geolocalización en caché durante 1 hora por IP
  • Subdominio IPv4 — ipv4.ippubblico.org fuerza conexión IPv4 solo mediante registro DNS A
  • Subdominio IPv6 — ipv6.ippubblico.org fuerza conexión IPv6 solo mediante registro DNS AAAA
  • Precisión de geolocalización — nivel ciudad/región aproximado (~50km). No apta para fines legales o de vigilancia.
  • Retención de datos — IP y metadatos almacenados máx. 90 días. Sin compartir con terceros.

Idiomas disponibles 43

El sitio completo está disponible en 43 idiomas. La API en sí es independiente del idioma.

🇮🇹 IT Italiano
🇬🇧 EN English
🇩🇪 DE Deutsch
🇫🇷 FR Français
🇪🇸 ES Español
🇵🇹 PT Português
🇳🇱 NL Nederlands
🇵🇱 PL Polski
🇷🇴 RO Română
🇨🇿 CS Čeština
🇸🇪 SV Svenska
🇩🇰 DA Dansk
🇫🇮 FI Suomi
🇭🇺 HU Magyar
🇸🇰 SK Slovenčina
🇧🇬 BG Български
🇭🇷 HR Hrvatski
🇸🇮 SL Slovenščina
🇪🇪 ET Eesti
🇱🇻 LV Latviešu
🇱🇹 LT Lietuvių
🇬🇷 EL Ελληνικά
🇲🇹 MT Malti
🇮🇪 GA Gaeilge
🇷🇺 RU Русский
🇺🇦 UK Українська
🇯🇵 JA 日本語
🇨🇳 ZH 中文
🇮🇳 HI हिन्दी
🇸🇦 AR العربية
🇰🇷 KO 한국어
🇹🇷 TR Türkçe
🇮🇩 ID Bahasa Indonesia
🇻🇳 VI Tiếng Việt
🇹🇭 TH ภาษาไทย
🇲🇾 MS Bahasa Melayu
🇳🇴 NB Norsk Bokmål
🇵🇰 UR اردو
🇰🇪 SW Kiswahili
🇮🇷 FA فارسی
🇧🇩 BN বাংলা
🇵🇭 TL Filipino
🇮🇱 HE עברית