SMTP-Anfragemodus
Im Folgenden wird der Ablauf einer SMTP-Sitzung beschrieben.
S: 220 EngageLab Inbound Server ESMTP Haraka 2.2.4 ready
C: ehlo ifaxin.com
S: 250-EngageLab Inbound Server Hello, Haraka is at your service.
S: 250-PIPELINING
S: 250-8BITMIME
S: 250-SIZE 16000000
S: 250 AUTH LOGIN
C: AUTH LOGIN base64(api_user)
S: 334 UGFzc3dvcmQ6
C: base64(api_key)
S: 235 Authentication successful
C: mail FROM:<support@ifaxin.com>
S: 250 sender <support@ifaxin.com> OK
C: rcpt TO:<ben@ifaxin.com>
S: 250 recipient <ben@ifaxin.com> OK
C: data
S: 354 go ahead, make my day
C: ... ...
C: .
S: 250 #1426390015358_15_6484_8661.sc-10_10_127_51-inbound#Queued
C: quit
S: 221 EngageLab Inbound Server closing connection. Have a jolly good day
Hinweis: Der SMTP-Aufruf gibt bei Überschreitung des Limits den Fehler „536 frequency limited“ zurück. Das bedeutet, dass pro API-User maximal 30.000 API- und SMTP-Aufrufe pro Minute zulässig sind (Frequenzbegrenzung).
Verwendung der Label-Funktion für SMTP-Zugriffe
Bei der Authentifizierung wird die Label-ID an den API_USER angehängt.
api_user + '#' + label_id
Ohne Label:
S: 250-EngageLab Inbound Server Hello, Haraka is at your service.
S: 250-PIPELINING
S: 250-8BITMIME
S: 250-SIZE 16000000
S: 250-STARTTLS
S: 250 AUTH LOGIN
C: AUTH LOGIN base64(api_user)
Mit Label:
S: 250-EngageLab Inbound Server Hello, Haraka is at your service.
S: 250-PIPELINING
S: 250-8BITMIME
S: 250-SIZE 16000000
S: 250-STARTTLS
S: 250 AUTH LOGIN
C: AUTH LOGIN base64(api_user + '#' + label_id)
Python-Codebeispiel:
# ohne Label:
s = SMTP('%s:%d' % (HOST, PORT))
s.set_debuglevel(DEBUG_MODE)
if USE_SSL:
s.starttls()
s.login(API_USER, API_KEY)
# mit Label:
s = SMTP('%s:%d' % (HOST, PORT))
s.set_debuglevel(DEBUG_MODE)
if USE_SSL:
s.starttls()
s.login(API_USER + '#' + label_id, API_KEY)
Einbetten von Bildern per SMTP versenden
Codebeispiel:
from email.mime.multipart import MIMEMultipart
from email.mime.text import MIMEText
from email.mime.image import MIMEImage
import smtplib
class MyEmail:
def __init__(self):
self.smtp = smtplib.SMTP()
self.login_username = 'postmaster@testdomain'
self.login_password = '*****'
self.sender = 'postmaster@testdomain' # identisch mit login_username
self.receiver = 'test123@qq.com'
self.host = 'smtp.engagelab.net'
self.port = 25
def connect(self):
self.smtp.connect(self.host)
def login(self):
self.smtp.login(self.login_username, self.login_password)
def send(self):
msg = MIMEMultipart('related')
msg['From'] = self.sender
msg['To'] = self.receiver
email_title = 'python test inline image'
msg['Subject'] = email_title
content = MIMEText('test image content <img src="cid:image1" alt="xxxxx">', 'html', 'utf-8')
msg.attach(content)
fp = open('./test.png','rb')
img = MIMEImage(fp.read())
img.add_header('Content-ID','image1') # Der Wert von Content-ID entspricht der cid im HTML
msg.attach(img)
self.smtp.sendmail(self.sender, self.receiver, msg.as_string())
def quit(self):
self.smtp.quit()
def send():
myemail = MyEmail()
myemail.connect()
myemail.login()
myemail.send()
myemail.quit()
if __name__ == "__main__":
send()
Versand von E-Mails über SMTP-Protokoll verschlüsseln
SSL V3.0 gilt mittlerweile als unsicher und wird nicht mehr unterstützt. Nutzer:innen können daher das Verschlüsselungsprotokoll über SMTP nutzen, das TLS v1.0 bis v1.2 unterstützt. SSL 3.0 oder ältere Versionen werden nicht unterstützt.
Port 25 unterstützt STARTTLS-Verschlüsselung. Nutzer:innen müssen ihrem Code eine Verschlüsselungszeile hinzufügen, z. B. in Java:
props.setProperty("mail.smtp.starttls.enable", "true");
Schlüsselbegriffe: SMTP-Verschlüsselung, E-Mail-Versand, TLS-Unterstützung, API-Authentifizierung, Frequenzbegrenzung

