Vai al contenuto
🛠️ToolsShed

SMTP Commands Reference

Riferimento completo dei comandi SMTP, codici di risposta e flusso del protocollo di posta con esempi interattivi.

EHLOsession
EHLO <hostname>

Extended greeting; identifies the client and requests ESMTP extensions.

EHLO mail.example.com
HELOsession
HELO <hostname>

Basic SMTP greeting. Use EHLO for modern servers.

HELO mail.example.com
QUITsession
QUIT

Close the SMTP connection gracefully.

QUIT
STARTTLSsession
STARTTLS

Upgrade the connection to TLS encryption.

STARTTLS
NOOPsession
NOOP

No operation; used to keep the connection alive.

NOOP
RSETsession
RSET

Abort the current mail transaction and reset the session.

RSET
AUTHauth
AUTH <mechanism> [credentials]

Authenticate the client to the server (PLAIN, LOGIN, CRAM-MD5).

AUTH LOGIN
MAIL FROMmessage
MAIL FROM:<address>

Specify the sender envelope address.

MAIL FROM:<sender@example.com>
RCPT TOmessage
RCPT TO:<address>

Specify a recipient envelope address. Can be repeated.

RCPT TO:<recipient@example.com>
DATAmessage
DATA

Begin transmitting the message body. End with a line containing only a period.

DATA
VRFYsession
VRFY <address>

Verify that a mailbox exists (often disabled for security).

VRFY user@example.com
EXPNsession
EXPN <list>

Expand a mailing list (often disabled for security).

EXPN users

Informazioni sullo strumento

SMTP (Simple Mail Transfer Protocol) è il protocollo testuale che i server di posta utilizzano per inoltrare e recapitare le email attraverso Internet. Sia gli sviluppatori che integrano funzioni di posta sia gli amministratori di sistema che eseguono il debug della consegna devono conoscere bene i suoi comandi fondamentali.

Questo riferimento elenca i comandi SMTP essenziali come HELO/EHLO, MAIL FROM, RCPT TO, DATA, STARTTLS, AUTH e QUIT, ciascuno con la sua sintassi, una breve descrizione e un esempio. Puoi usarlo per percorrere una sessione manuale tramite telnet o openssl, diagnosticare perché un messaggio è stato rifiutato oppure semplicemente imparare passo dopo passo come funziona il protocollo.

Tieni presente che i server di posta moderni richiedono quasi sempre STARTTLS per la cifratura e AUTH per l'invio autenticato, quindi le sessioni non cifrate vengono spesso respinte. Considera questa pagina come un supporto allo studio e alla consultazione, non come una guida alla configurazione della posta in produzione.

Domande Frequenti

Implementazione del Codice

import smtplib
from email.mime.text import MIMEText
from email.mime.multipart import MIMEMultipart

def send_email_smtp(
    smtp_host: str,
    smtp_port: int,
    username: str,
    password: str,
    from_addr: str,
    to_addr: str,
    subject: str,
    body: str,
    use_tls: bool = True
) -> bool:
    """Send email using SMTP with manual command flow."""
    try:
        with smtplib.SMTP(smtp_host, smtp_port) as server:
            server.ehlo()  # EHLO command
            if use_tls:
                server.starttls()  # STARTTLS command
                server.ehlo()     # Re-EHLO after TLS
            server.login(username, password)  # AUTH command

            msg = MIMEMultipart()
            msg['From'] = from_addr
            msg['To'] = to_addr
            msg['Subject'] = subject
            msg.attach(MIMEText(body, 'plain'))

            # MAIL FROM, RCPT TO, DATA commands
            server.sendmail(from_addr, to_addr, msg.as_string())
            return True
    except smtplib.SMTPException as e:
        print(f"SMTP Error: {e}")
        return False

# Test SMTP connection manually
def test_smtp_connection(host: str, port: int) -> dict:
    import socket
    try:
        with smtplib.SMTP(host, port, timeout=5) as server:
            banner = server.getwelcome()
            ehlo_resp = server.ehlo()
            return {
                "connected": True,
                "banner": banner.decode(),
                "extensions": list(server.esmtp_features.keys())
            }
    except Exception as e:
        return {"connected": False, "error": str(e)}

result = test_smtp_connection("smtp.gmail.com", 587)
print(result)

Comments & Feedback

Comments are powered by Giscus. Sign in with GitHub to leave a comment.