Referencia para Desarrolladores
Similitud de dominios Documentación API
Similitud de dominios Documentación API: Compara dos dominios para similitud visual y textual utilizando múltiples algoritmos incluyendo distancia de Levenshtein, similitud Jaro-Winkler y análisis visual de homoglifos. Esencial para detectar typosquatting, suplantación de marca y dominios de phishing.
Similitud de dominios
Compara dos dominios para similitud visual y textual utilizando múltiples algoritmos incluyendo distancia de Levenshtein, similitud Jaro-Winkler y análisis visual de homoglifos. Esencial para detectar typosquatting, suplantación de marca y dominios de phishing.
GET
/v1/similarity
Parámetros de consulta
| Parámetro | Tipo | Descripción |
|---|---|---|
| domain1 obligatorio | string | Primer dominio (normalmente el dominio legítimo) |
| domain2 obligatorio | string | Segundo dominio (dominio potencialmente sospechoso) |
Algoritmos de similitud
| Algoritmo | Descripción |
|---|---|
levenshtein | Distancia de edición normalizada (0-1) |
jaro_winkler | Similitud de cadenas ponderada por prefijo |
visual | Detección de homoglifos/caracteres similares |
Solicitud de ejemplo
curl "https://domscan.net/v1/similarity?domain1=paypal.com&domain2=paypa1.com"
import requests
# Check multiple suspicious domains
legit = "paypal.com"
suspects = ["paypa1.com", "paypaI.com", "pаypal.com"] # Note: last one has Cyrillic 'а'
for suspect in suspects:
response = requests.get(
"https://domscan.net/v1/similarity",
params={"domain1": legit, "domain2": suspect}
)
data = response.json()
print(f"{suspect}: {data['typosquatting_risk']} risk (visual: {data['similarity']['visual']:.2f})")
Respuesta de ejemplo
{
"domain1": "paypal.com",
"domain2": "paypa1.com",
"similarity": {
"levenshtein": 0.86,
"jaro_winkler": 0.93,
"visual": 0.95
},
"is_similar": true,
"typosquatting_risk": "high",
"homoglyphs_detected": ["l → 1"],
"risk_factors": ["character_substitution", "high_visual_similarity"]
}
Campos de respuesta
| Campo | Tipo |
|---|---|
domain1 |
string |
domain2 |
string |
similarity_score |
number |
visual_similarity |
number |
textual_similarity |
number |
is_confusable |
boolean |
risk_level |
string |