API Pública IPPubblico

API de IP pública gratuita, sem autenticação. Quatro endpoints devolvendo IPv4, IPv6, ISP, ASN, geolocalização e fuso horário — em JSON ou texto.

✓ Gratuita para sempre ✓ Sem chave API ✓ Sem limite de taxa 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 Resposta JSON completa

Devolve um objeto JSON completo com todos os dados disponíveis sobre o endereço IP do chamador.

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"
}
CampoTipoDescrição
statusstring"ok" ou "partial" se a geolocalização falhou
ipstringIP detetado (pode ser IPv4 ou IPv6)
ipv4string | nullEndereço IPv4 se disponível
ipv6string | nullEndereço IPv6 se disponível
ispstring | nullNome do fornecedor de internet
asnstring | nullNúmero de Sistema Autónomo (ex. "AS3269")
timezonestring | nullFuso horário IANA (ex. "Europe/Rome")
datetimestringData/hora ISO 8601 no fuso do chamador
geo.citystring | nullNome de cidade aproximado
geo.regionstring | nullRegião / estado
geo.countrystring | nullNome do país
geo.lat / geo.lonfloat | nullCoordenadas aproximadas
cachedbooleantrue se resultado servido da cache de 1h
GET https://ippubblico.org/?text=1 Texto simples — IPv4 + IPv6

Devolve IPv4 e IPv6 em duas linhas separadas. Devolve NONE se um protocolo não estiver disponível.

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

Devolve apenas o endereço IPv4 como texto simples, ou NONE se não disponível.

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

Devolve apenas o endereço IPv6 como texto simples, ou NONE se não disponível.

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

Exemplos de código samples

bash / curl
# JSON completo
curl https://ippubblico.org/?api=1

# Apenas IPv4
MY_IP=$(curl -s https://ipv4.ippubblico.org/)
echo "My IPv4: $MY_IP"

# Apenas 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

  • Sem autenticação — não é necessária chave ou token de API
  • CORS ativado — utilizável a partir de JavaScript no navegador em qualquer domínio
  • Cache 1h — dados de geolocalização em cache durante 1 hora por IP
  • Subdomínio IPv4 — ipv4.ippubblico.org força ligação IPv4 via registo DNS A
  • Subdomínio IPv6 — ipv6.ippubblico.org força ligação IPv6 via registo DNS AAAA
  • Precisão de geolocalização — nível cidade/região aproximado (~50km). Não adequado para fins legais ou de vigilância.
  • Retenção de dados — IP e metadados armazenados máx. 90 dias. Sem partilha com terceiros.

Idiomas disponíveis 43

O site completo está disponível em 43 idiomas. A API em si é independente do 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 עברית