API Publique IPPubblico

API IP publique gratuite, sans authentification. Quatre endpoints retournant IPv4, IPv6, ISP, ASN, géolocalisation et fuseau horaire — en JSON ou texte.

✓ Gratuit pour toujours ✓ Pas de clé API ✓ Pas de limite de taux JSON & Plain text CORS enabled

URLs de 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 Réponse JSON complète

Retourne un objet JSON complet avec toutes les données disponibles sur l'adresse IP de l'appelant.

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"
}
ChampTypeDescription
statusstring"ok" ou "partial" si la géolocalisation a échoué
ipstringIP détectée (peut être IPv4 ou IPv6)
ipv4string | nullAdresse IPv4 si disponible
ipv6string | nullAdresse IPv6 si disponible
ispstring | nullNom du fournisseur d'accès Internet
asnstring | nullNuméro de système autonome (ex. "AS3269")
timezonestring | nullFuseau horaire IANA (ex. "Europe/Rome")
datetimestringDate/heure ISO 8601 dans le fuseau de l'appelant
geo.citystring | nullNom de ville approximatif
geo.regionstring | nullRégion / département
geo.countrystring | nullNom du pays
geo.lat / geo.lonfloat | nullCoordonnées approximatives
cachedbooleantrue si résultat servi depuis le cache 1h
GET https://ippubblico.org/?text=1 Texte brut — IPv4 + IPv6

Retourne IPv4 et IPv6 sur deux lignes séparées. Retourne NONE si un protocole est indisponible.

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

Retourne uniquement l'adresse IPv4 en texte brut, ou NONE si non disponible.

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

Retourne uniquement l'adresse IPv6 en texte brut, ou NONE si non disponible.

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

Exemples de code samples

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

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

# IPv6 seulement
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}");

Notes info

  • Pas d'authentification — aucune clé ou jeton API requis
  • CORS activé — utilisable depuis JavaScript navigateur sur tout domaine
  • Cache 1h — données de géolocalisation mises en cache 1 heure par IP
  • Sous-domaine IPv4 — ipv4.ippubblico.org force la connexion IPv4 via enregistrement DNS A
  • Sous-domaine IPv6 — ipv6.ippubblico.org force la connexion IPv6 via enregistrement DNS AAAA
  • Précision de géolocalisation — niveau ville/région approximatif (~50km). Non adapté à des fins légales ou de surveillance.
  • Conservation des données — IP et métadonnées conservées max 90 jours. Pas de partage tiers.

Langues disponibles 43

Le site complet est disponible en 43 langues. L'API elle-même est indépendante de la langue.

🇮🇹 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 עברית