How to configure DKIM SPF and DMARC

This is part of the Semicolon&Sons Code Diary - consisting of lessons learned on the job. You're in the web-development category.

Last Updated: 2025-01-18

SPF, DKIM and DMARC are email protocols providing ways to prove to ISPs, mail services and other receiving mail servers that the senders were truly authorized to send email.

All three are implemented as DNS TXT records, email headers, and code on the recipient server that must obey these protocols (and major mail servers do - e.g. Gmail, Microsoft)

The problem they solve is that emails, without extra measures, are a bit like letters, in that the sender address can be set to whatever you want - even something not under your control.

The Protocols

SPF - Sender Policy Framework

The DNS text record specifies what IP addresses are allowed to send the email from the mailing domain.

Let's analyze a typical instance:

v=spf1 ip4:10.23.24.25 include:amazonses.com -all

Fields:

WARNING: You cannot have multiple SPF entries for a domain. Instead combine them together into a single entry. E.g.

"v=spf1 a:example.com a:sub.example.net -all"

DKIM - DomainKeys Identified Mail

Let's analyze a typical instance of the DNS records:

myhouse._domainKey.example.net; p=MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBg
QC1TaNgLlSyQMNWVLNLvyY/neDgaL2oqQE8T5illKqCgDtFHc8eHVAU+nlcaGmrKmDMw9dbgiGk1ocgZ56NR4
ycfUHwQhvQPMUZw0cveel/8EAGoi/UyPmqfcPibytH81NFtTMAxUeM4Op8A6iHkvAMj5qLf4YRNsTkKAV

Fields:

Let's also look at the email headers:

DKIM-Signature:
     v=1;
     a=rsa-sha256;
     d=example.net;
     s=myhouse;
     c=relaxed/simple; q=dns/txt; t=1117574938; x=1118006938;
     h=from:to:subject:date:keywords:keywords;
     bh=MTIzNDU2Nzg5MDEyMzQ1Njc4OTAxMjM0NTY3ODkwMTI=;
     b=dzdVyOfAKCdLXdJOc9G2q8LoXSlEniSbav+yuU4zGeeruD00lszZ
              VoG4ZHRNiYzR

In contrast to SPF, it's possible to have multiple DKIM entries for a domain thanks to its selector.

How does it work?

DMARC - Domain-based Message Authentication

Built around SPF and DKIM, it verifies that a sender's message is protected by both. What's more, it tells the receiving mail server what to do if neither of those authentication methods pass. Lastly, you, the domain administrator, get feedback reports from email receivers with copies of these spoofed messages.

What's its purpose? It insures that the SPF and DKIM records match the info contained in the "from" field of the email received.

"v=DMARC1; p=none; rua=mailto:dmarc@yourdomain.com"

Fields:

How to verify that these are working?

One handy way is with Gmail: open an email you have received. On the right upper side there is a button. From there click "show source". The headers will have:

SPF: passed or failed DKIM: passed or failed DMARC: passed or failed

A word on confusions with multiple domains

If you have two domains running on one website (e.g. for whitelisting), then email sent from one of them might appear to be from the right domain but via the other domain because the DKIM was signed by the other domain. That is unless you configure the mail service to use a different DKIM depending on which domain is sending.

Resources