Verifica Singola Email
Verifica un singolo indirizzo email in tempo reale per controllarne la consegnabilità e validità.
POST
/email-verificationsCorpo della Richiesta
emailstringRequiredIndirizzo email da verificare.
modestringModalità di verifica: fast o full. Predefinito: full. La modalità veloce salta alcuni controlli SMTP e restituisce null per determinati campi.
const response = await fetch('https://api.emailit.com/v2/email-verifications', {
method: 'POST',
headers: {
'Authorization': 'Bearer em_test_51RxCWJ...vS00p61e0qRE',
'Content-Type': 'application/json'
},
body: JSON.stringify({
email: 'utente@esempio.com',
mode: 'full'
})
});
const result = await response.json(); <?php
$curl = curl_init();
curl_setopt_array($curl, [
CURLOPT_URL => 'https://api.emailit.com/v2/email-verifications',
CURLOPT_RETURNTRANSFER => true,
CURLOPT_ENCODING => '',
CURLOPT_MAXREDIRS => 10,
CURLOPT_TIMEOUT => 30,
CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1,
CURLOPT_CUSTOMREQUEST => 'POST',
CURLOPT_POSTFIELDS => json_encode([
'email' => 'utente@esempio.com',
'mode' => 'full'
]),
CURLOPT_HTTPHEADER => [
'Authorization: Bearer em_test_51RxCWJ...vS00p61e0qRE',
'Content-Type: application/json'
],
]);
$response = curl_exec($curl);
$err = curl_error($curl);
curl_close($curl);
if ($err) {
echo "Errore cURL #:" . $err;
} else {
$result = json_decode($response, true);
print_r($result);
} import requests
response = requests.post(
'https://api.emailit.com/v2/email-verifications',
headers={
'Authorization': 'Bearer em_test_51RxCWJ...vS00p61e0qRE',
'Content-Type': 'application/json'
},
json={
'email': 'utente@esempio.com',
'mode': 'full'
}
)
result = response.json()
print(result) require 'net/http'
require 'json'
uri = URI('https://api.emailit.com/v2/email-verifications')
http = Net::HTTP.new(uri.host, uri.port)
http.use_ssl = true
request = Net::HTTP::Post.new(uri)
request['Authorization'] = 'Bearer em_test_51RxCWJ...vS00p61e0qRE'
request['Content-Type'] = 'application/json'
request.body = {
email: 'utente@esempio.com',
mode: 'full'
}.to_json
response = http.request(request)
result = JSON.parse(response.body)
puts result package main
import (
"bytes"
"encoding/json"
"fmt"
"net/http"
)
func main() {
url := "https://api.emailit.com/v2/email-verifications"
data := map[string]interface{}{
"email": "utente@esempio.com",
"mode": "full",
}
jsonData, _ := json.Marshal(data)
req, _ := http.NewRequest("POST", url, bytes.NewBuffer(jsonData))
req.Header.Set("Authorization", "Bearer em_test_51RxCWJ...vS00p61e0qRE")
req.Header.Set("Content-Type", "application/json")
client := &http.Client{}
resp, _ := client.Do(req)
defer resp.Body.Close()
var result map[string]interface{}
json.NewDecoder(resp.Body).Decode(&result)
fmt.Println(result)
} use reqwest;
use serde_json::{json, Value};
#[tokio::main]
async fn main() -> Result<(), Box<dyn std::error::Error>> {
let client = reqwest::Client::new();
let response = client
.post("https://api.emailit.com/v2/email-verifications")
.header("Authorization", "Bearer em_test_51RxCWJ...vS00p61e0qRE")
.header("Content-Type", "application/json")
.json(&json!({
"email": "utente@esempio.com",
"mode": "full"
}))
.send()
.await?;
let result: Value = response.json().await?;
println!("{:?}", result);
Ok(())
} import java.net.http.HttpClient;
import java.net.http.HttpRequest;
import java.net.http.HttpResponse;
import java.net.URI;
import java.net.http.HttpRequest.BodyPublishers;
public class VerifyEmail {
public static void main(String[] args) throws Exception {
HttpClient client = HttpClient.newHttpClient();
String jsonBody = """
{
"email": "utente@esempio.com",
"mode": "full"
}
""";
HttpRequest request = HttpRequest.newBuilder()
.uri(URI.create("https://api.emailit.com/v2/email-verifications"))
.header("Authorization", "Bearer em_test_51RxCWJ...vS00p61e0qRE")
.header("Content-Type", "application/json")
.POST(BodyPublishers.ofString(jsonBody))
.build();
HttpResponse<String> response = client.send(request,
HttpResponse.BodyHandlers.ofString());
System.out.println(response.body());
}
} using System;
using System.Net.Http;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;
public class VerifyEmail
{
public static async Task Main()
{
using (var client = new HttpClient())
{
client.DefaultRequestHeaders.Add("Authorization",
"Bearer em_test_51RxCWJ...vS00p61e0qRE");
var data = new {
email = "utente@esempio.com",
mode = "full"
};
var json = JsonConvert.SerializeObject(data);
var content = new StringContent(json, Encoding.UTF8, "application/json");
var response = await client.PostAsync(
"https://api.emailit.com/v2/email-verifications", content);
var result = await response.Content.ReadAsStringAsync();
Console.WriteLine(result);
}
}
} curl -X POST https://api.emailit.com/v2/email-verifications \
-H "Authorization: Bearer em_test_51RxCWJ...vS00p61e0qRE" \
-H "Content-Type: application/json" \
-d '{
"email": "utente@esempio.com",
"mode": "full"
}' {
"id": "ev_abc123xyz",
"email": "utente@esempio.com",
"status": "completed",
"score": 100,
"risk": "low",
"result": "safe",
"mode": "full",
"checks": {
"valid_syntax": true,
"disposable": false,
"role_account": false,
"inbox_full": false,
"deliverable": true,
"disabled": false,
"free_email": false,
"gibberish": false,
"catch_all": false,
"smtp_connect": true,
"has_mx_records": true,
"domain_age": 5840
},
"address": {
"mailbox": "utente",
"domain": "esempio.com",
"suffix": null,
"root": "utente@esempio.com"
},
"did_you_mean": null,
"mx_records": [
{
"priority": 10,
"exchange": "mail.esempio.com"
}
]
} {
"statusCode": 400,
"error": "Bad Request",
"message": "Formato email non valido"
} {
"statusCode": 402,
"error": "Payment Required",
"message": "Crediti insufficienti per la verifica email"
} Campi della Risposta
Stato della Verifica
| Valore | Descrizione |
|---|---|
| pending | Verifica in coda ma non ancora iniziata |
| processing | Verifica in corso |
| completed | Verifica completata con successo |
| failed | Verifica fallita a causa di un errore |
Risultato della Verifica
| Valore | Descrizione |
|---|---|
| safe | L’email è valida e consegnabile |
| invalid | L’email non è valida (sintassi, dominio o casella) |
| disposable | L’email utilizza un dominio temporaneo/usa e getta |
| disabled | La casella esiste ma è disabilitata |
| inbox_full | La casella è piena e non può ricevere email |
| unknown | Non è stato possibile determinare la consegnabilità |
Livello di Rischio
| Valore | Intervallo Punteggio | Descrizione |
|---|---|---|
| low | 80-100 | Sicuro per l’invio |
| medium | 50-79 | Usare con cautela |
| high | 0-49 | Alto rischio di rimbalzo |
Oggetto Controlli
| Field | Type | Description |
|---|---|---|
| valid_syntax | boolean | Email syntax is valid |
| disposable | boolean | Uses disposable domain |
| role_account | boolean | Role-based address (info@, support@) |
| inbox_full | boolean/null | Mailbox is full |
| deliverable | boolean/null | Email is deliverable |
| disabled | boolean/null | Mailbox is disabled |
| free_email | boolean | Uses free email provider |
| gibberish | boolean | Mailbox appears to be gibberish |
| catch_all | boolean/null | Domain accepts all emails |
| smtp_connect | boolean/null | SMTP connection successful |
| has_mx_records | boolean | Domain has MX records |
| domain_age | integer/null | Domain age in days |
Note: Fields marked as boolean/null or integer/null may return null in fast mode.