In this post you will learn to understand how the DNS protocols SPF, DKIM and DMARC work together to protect your domain from phishers and spammers.
Why deploy SPF, DKIM, and DMARC?
SPF, DKIM, and DMARC are critical email authentication protocols that help prevent email spoofing, phishing attacks, and domain impersonation for outbound email. Enabling these protocols together strengthens your domain’s email authentication mechanisms, improves security, and builds trust with your recipients by ensuring that email sent from your domain is legitimate and trustworthy.
SPF, DKIM and DMARC - Comparison table:
Protocol | Precise Term | Purpose |
---|---|---|
SPF | RFC5321.MailFrom (P1 Sender) |
Sender authorization check |
DKIM | RFC5322.From (P2 Sender) |
Message authenticity verification |
DMARC | RFC5322.From (P2 Sender) |
Final shield on top of SPF and DKIM |
SPF
What is SPF
Sender Policy Framework (SPF) is a protocol that aims to reduce spam. SPF can reduce email spoofing and spam by determining if the sender is authorized to send on behalf of the listed sender.
How SPF works
Imagine that you have an SPF record that looks like:
v=spf1 include:_spf.domain.com ip4:11.222.33.444 -all
If an unauthorized server sends on behalf of your domain, the email will get a spf=fail
in the message header because the IP is not listed in your SPF record.
SPF will pass if the sender’s IP is added to the SPF record for the P1 Sender domain.
P1 vs. P2 - Sender explanation table:
Postal Letter | Precise Term | Protected by |
---|---|---|
Sender on envelope | RFC5321.MailFrom (P1 Sender) |
SPF |
Author on letter | RFC5322.From (P2 Sender) |
DKIM + DMARC |
Implementation of SPF
When you add your domain to Microsoft 365, Microsoft will ask you to provide an SPF record, such as v=spf1 include:spf.protection.outlook.com -all
. If you have more allowed senders, you must include them in the SPF record. For example v=spf1 include:spf.protection.outlook.com include:_spf.domain.com ip4:11.222.33.444 -all
The SPF record will differ for everyone; therefore, it is important to understand the following when implement an SPF- record:
- Can only have 255 characters, but it can be split to multiple strings in a single record, most DNS providers handle this automatically.
- Example:
"v=spf1 first string" "second string -all"
- Example:
- Can take up to a maximum of 10 DNS Lookups like
include:spf.protection.outlook.com
(which currently contains 1 DNS lookup, without child lookups)
CAUTION: If your DNS lookups are going to be around 10/10, you should take steps to stay well under 10 DNS lookups. Because if a vendor decides to add another DNS lookup within its SPF include (child lookup). Your SPF record will become inaccurate because it has reached the DNS lookup limit, which may result in email delivery problems.
Avoiding the 10 DNS Lookups cap, to:
- Flatten your SPF record (not recommended)
- Example:
v=spf1 include:spf.domain.com -all
can bev=spf1 ip4:11.222.33.444 ip4:11.222.33.444 -all
- Example:
The problem with flattening is that email service providers can change or add IP addresses without telling you. Then your SPF record will be inaccurate, leading to email delivery problems.
-
Not using entries like
a
andmx
, these mechanisms are often useless and probably should not be included in your SPF record (and other duplicate SPF mechanisms). -
Where email is incapable of passing DMARC with SPF, configure DKIM for the P2 Sender domain on the sending server or mail provider.
- NOTE: In this scenario, you must to set your SPF record to softfail
~all
, this to ensure that the DMARC and DKIM evaluation will always be performed in the absence of a valid SPF validation.
- NOTE: In this scenario, you must to set your SPF record to softfail
-
Check if providers have the ability to pass SPF on a subdomain on behalf of your primary domain; passing SPF on a subdomain is still DMARC compliant.
-
Move to vendor traffic with the use of subdomains for SPF authentication, subdomain segmentation creates a new domain dedicated to a particular mail stream with its own 10 DNS lookups. Organizations that segment their email streams find there is no need for SPF flattening and will end up with better controls, less attack surface, and limit any spillover effects of a potential cyber incident.
-
Use an SPF macro to limit a third-party service to sending from a specific address, since services like Salesforce are most often limited to sending from a single email address, such as
invoices@yourdomain.com
.
Softfail or Hardfail
SPF can get a softfail or a hardfail, you determine that at the end of the record.
-
With
~all
: The SPF record identifies the host as NOT authorized to send emails on behalf of the domain; however, it instructs email receivers to accept the email but flag it as potentially suspicious. -
With
-all
: The SPF record specifies that the host is NOT authorized to send emails and instructs email receivers to reject them.
Most mailbox providers will treat soft and hard- fails directives similarly, but it is recommended to mirror the DMARC policy as the technology is deployed: use softfail (~all
) if the DMARC policies are “none” and “quarantine”, and use hardfail (-all
) if you have moved to a “reject” policy.
NOTE: If an email cannot pass SPF (e.g. due to relaying), it can be hard rejected at the SMTP level with an SPF hardfail (
-all
), which may prevent DMARC and DKIM evaluation. If you are unsure whether your senders are passing SPF, then consider using an SPF softfail (~all
) along with DMARC set to reject (p=reject
). This ensures that the DMARC and DKIM evaluation is always performed in the absence of a valid SPF validation.
Limitations of SPF
Although SPF works relatively well in theory, there are several flaws in the protocol that mean that SPF alone is not enough to protect a sending domain.
The SPF protocol only protects the P1 sender and not the P2 sender of the email. DKIM was created to protect the P2 sender by adding a signature (SHA-256 hash function) to the email. But then there was the problem that not every mail server has an active policy for DKIM, which is why DMARC was created. With DMARC, the sender specifies on behalf of their domain what should be done with email that does not meet the DMARC requirements. DMARC protects the P2 sender as the last line of defense.
DKIM
What is DKIM
DomainKeys Identified Mail (DKIM) is an authentication-based technique that allows the receiving mail server to verify the authenticity of an email by comparing the received private key with the public key if they match.
How DKIM works
The receiving server makes a DNS request using the sender’s domain name (P2 Sender). In response to the DNS request, the receiving server obtains the public key from a DNS record in the DNS zone of the sending domain, such as selector1._domainkey.yourdomain.com
, and compares it to the private key in the message from the sending server.
DKIM will pass if the sending server’s private key can be confirmed by the receiving server, using the public key in the sending domain’s DNS zone. This public key is published in a TXT
or within a CNAME
record. For example, if in TXT
:
- Hostname:
key1._domainkey.yourdomain.com
(inTXT
) - Value:
v=DKIM1;t=s;p=MIIBIjANBgkqhkiG9w0BA...
(public key)
Implementation of DKIM
You can configure DKIM with a TXT
record in your DNS zone for your sending mail servers (such as postfix or sendmail). A DKIM generator can be used to generate a private key for your server and a public key for your DNS.
Note: that a DKIM record is required for each sending server or mail provider.
How you set up DKIM can vary depending on your mail provider; setting up DKIM for Salesforce differs from Exchange Online in Microsoft Defender for Office 365.
DKIM recommendations
- You must implement DKIM key rotation for each sending service to prevent adversaries from intercepting and decrypting your DKIM keys. DKIM Key rotation helps to minimize the risk of having a private key compromised.
- Recurring: Every six months for a 2048-bit DKIM key.
- The DKIM key length must be at least 2048-bits.
DMARC
What is DMARC
DMARC (Domain-based Message Authentication, Reporting and Conformance) acts as a shield on top of SPF and DKIM. With DMARC, the sender specifies what to do with email on behalf of the domain if it does not meet the requirements of SPF and DKIM.
How DMARC works
Once your domain has a DMARC record, any receiving email server can verify the incoming email based on the instructions in the DMARC policy. If the email passes the DMARC authentication, it will be delivered and can be trusted. If the email fails the check, depending on the instructions in the DMARC record, the email can be delivered, quarantined (flagged as potentially suspicious), or rejected.
DMARC will pass if the P1 Sender and P2 Sender are equal, and/or SPF and DKIM are passed. If the P1 sender is not equal to the P2 sender, then DKIM must pass for the P2 sender domain in order to get a DMARC pass.
Implementation of DMARC
Before using DMARC, you need to know how often it will fail. You should consider monitoring DMARC failures before setting the DMARC policy directly to reject.
There are several monitoring tools that convert the DMARC reports into a clear dashboard. One such tool is Valimail (free for Microsoft 365 users with an Exchange Online plan).
Overview of the Valimail Dashboard:
For heavy mail domains, I recommended monitoring the domain for at least three months with the DMARC policy set to none
:
- Hostname:
_dmarc
- Value:
v=DMARC1; p=none; sp=none; rua=mailto:dmarc_agg@vali.email;
During the monitoring phase, you can adjust your SPF record and set up DKIM for each sender, and then update your DMARC record to reject
once the monitoring phase is complete:
- Value:
v=DMARC1; p=reject; sp=reject; rua=mailto:dmarc_agg@vali.email;
The sp=reject
tag means that subdomains will be included; if you don’t want your subdomains to be included in your domain’s root DMARC policy, you can set this to sp=none
and list a separate DMARC policy for each subdomain (not recommended).
If you do not list the sp=
tag, your subdomains will get the policy from the p=
tag.
DMARC policy explanation
Policy | Value | Meaning |
---|---|---|
None | p=none; |
This policy is essentially a monitoring or reporting mode. It instructs email receivers not to take any action based on the DMARC authentication results. |
Quarantine | p=quarantine; |
This policy instructs email receivers to mark emails that fail DMARC authentication as potentially suspicious, typically delivering them to the recipient’s SPAM folder. As a result, the DMARC quarantine policy does not fully utilize the protective capabilities of DMARC. |
Reject | p=reject; |
This policy instructs email receivers to reject (not deliver) emails that fail DMARC authentication. |
The table on this Microsoft Learn page summarizes the options you have when configuring your DMARC policy.
RUA vs. RUF DMARC Reports
RUA
(Reporting URI for Aggregate reports) reports are the most important and contain information about the authentication status for SPF, DKIM and DMARC. The RUA
report doesn’t contain any sensitive information from the email itself; the data is limited to message counts and email authentication attributes.
RUF
(Reporting URI for Forensic reports) data was initially meant to give domain owners redacted copies of emails failing DMARC compliance. They use forensic reports to identify legitimate email sources needing remediation. However, due to privacy concerns, most DMARC reporters don’t offer RUF
reports due to the potential personally identifiable information (PII) that reports may contain.
You don’t need RUF
Reporting to get a DMARC compliant domain, RUA
is sufficient.
Protect all non-sending domains
To protect all non-sending domains, you should consider:
- A deny all SPF record:
- Name:
@
- Content:
v=spf1 -all
- Type:
TXT
- Name:
- A reject DMARC record:
- Name:
_dmarc
- Content:
v=DMARC1; p=reject;
- Type:
TXT
- Name:
- An unassociated public key as a DKIM wildcard record:
- Name:
*._domainkey
- Content:
v=DKIM1; p=
- Type:
TXT
- Name:
This protects all of your domains from phishers and spammers, as bad actors will actively look for unused domains to exploit.
To Summarize
SPF performs verification that the IP address of the sending server matches the entry in the SPF record from the sending domain.
- SPF protects the P1 sender domain (Envelope sender,
RFC5321.MailFrom
).
DKIM verifies if the public key (DNS record) of a sending domain, matched the private key that came from the sending server. This is a check that the sending domain actually sent the e-mail. DKIM must be configured for each sending server, such as Exchange Online or any other server/SaaS service.
- DKIM protects the P2 sender domain (Letter sender,
RFC5322.From
).
DMARC acts as a shield on top of SPF and DKIM. DMARC ensures that emails that fail the SPF and/or DKIM tests do not get through. If the email is unable to pass DMARC with SPF, DKIM can help pass DMARC for the P2 sender domain. Therefore, it is really important to have DKIM enabled for all your sending servers before setting DMARC to reject
.
- DMARC protects the P2 sender domain (Letter sender,
RFC5322.From
).
Reference
- Dmarcian SPF best practices - Unavailable from the Netherlands
- Dmarcian Concluding the Experiment: SPF Flattening - Unavailable from the Netherlands
- Dmarcian DMARC best practices - Unavailable from the Netherlands
- Dmarcian The Difference in DMARC Reports: RUA and RUF - Unavailable from the Netherlands
- Why Mailhardener recommends SPF softfail over fail
- How to protect domains that do not send email
- SPF is defined in RFC 7208
- DKIM is defined in RFC 6376
- DMARC is defined in RFC 7489
- SPF Policy Tester