window.nitroFragments['2f66f9a155b7a85308b498ba19513c84'] = {"isLazyLoaded":true,"content":"<div class="container_wrap container_wrap_first main_color sidebar_right nitro-lazy-render" nitro-fragment-parent> <div class='container template-blog template-single-blog'> <main class='content units av-content-small alpha  av-blog-meta-comments-disabled av-blog-meta-tag-disabled av-main-single'> <div class="table-content"><div class='table-of-contents'><span class='toc-headline'>Table Of Contents</span><span class='toggle-toc custom-setting' title='collapse'>−</span><ul><li><a href="#spf-record-syntax">SPF Record Syntax</a></li><li><a href="#simplify-spf-record-syntax-with-powerdmarc">Simplify SPF Record Syntax with PowerDMARC!</a></li><li><a href="#simplify-spf-with-powerdmarc">Simplify SPF with PowerDMARC!</a></li><li><a href="#spf-record-syntax-mechanisms">SPF Record Syntax Mechanisms&nbsp;</a></li><li><a href="#spf-record-syntax-modifiers">SPF Record Syntax Modifiers</a></li><li><a href="#what-is-an-spf-record">What is an SPF Record?</a></li><li><a href="#1-creating-an-spf-record-syntax">1. Creating an SPF Record Syntax</a></li></ul></div></div><article class="post-entry post-entry-type-standard post-entry-36420 post-loop-1 post-parity-odd post-entry-last single-big with-slider post-36420 post type-post status-publish format-standard has-post-thumbnail hentry category-blogs"><div class="blog-meta"></div><div class='entry-content-wrapper clearfix standard-content'><header class="entry-content-header" aria-label="Post: SPF Record Syntax"><div class="av-heading-wrapper"></div></header><span class="av-vertical-delimiter"></span><div class="entry-content"><p><span style="font-weight:400;">The Sender Policy Framework (<a href="https://powerdmarc.com/what-is-spf/" data-wpel-link="internal" target="_self" rel="follow">SPF</a>) record is an important part of the </span><a href="https://powerdmarc.com/" data-wpel-link="internal" target="_self" rel="follow"><span style="font-weight:400;">DMARC</span></a><span style="font-weight:400;">&nbsp;protocol that specifies a method to prevent sender address forgery.</span></p> <p><span style="font-weight:400;">SPF records are complex to set up and implementation issues can occur if they are not properly configured. Also, SPF Record Syntax uses some specific terms that can be confusing when first encountered. Therefore, in this blog post, we look at SPF record syntax and what you need to consider when you configure them.</span></p> <p></p> <div style="background:white;border:1px solid #ddd;border-radius:8px;box-shadow:2px 2px 10px rgba(0,0,0,.1);padding:20px 30px 20px 20px;max-width:600px;margin:20px auto;"> <p style="font-size:20px;font-weight:bold;margin-bottom:10px;">Key Takeaways</p> <ol style="padding-left:20px;margin-right:10px;"> <li>SPF prevents email spoofing by authorizing specific mail servers to send emails on your behalf.</li> <li>SPF records use directives, qualifiers, and mechanisms to define authorized senders and actions on failed checks.</li> <li>The recipient’s server checks the SPF record via DNS lookup to verify the sender’s authorization.</li> <li>SPF results in Pass, Neutral, or Fail to determine if the email is legitimate.</li> <li>SPF modifiers like &#8220;exp&#8221; and &#8220;redirect&#8221; offer additional customization for email validation and handling.</li> </ol> </div> <p></p> <h2 id="spf-record-syntax"><span style="font-weight:400;">SPF Record Syntax</span></h2> <p><span style="font-weight:400;">The SPF record syntax comprises several elements–Directives, Qualifiers, and Mechanisms.</span></p> <p><span style="font-weight:400;">Directives are the first part of an SPF record syntax. They indicate how to interpret the rest of the record. Three directives can appear in an SPF record: v=spf1, a, and mx. The v directive indicates that this record is an SPFv1 record; the a directive indicates that this record is an SPFv2-style authentication failure report; the mx directive specifies a list of mail exchange servers for a domain.</span></p> <p><span style="font-weight:400;">Qualifiers specify where in your DNS zone you want to place your SPF records: exim4, enduser, or _spf. These qualifiers tell mail receivers where to look for your SPF records when they&#8217;re checking them against their DNS records.</span></p> <p><span style="font-weight:400;">Mechanisms are used to indicate how you want to handle email addresses that fail your <a id="link_juicer" href="https://powerdmarc.com/spf-record-lookup/" data-wpel-link="internal" target="_self" rel="follow">SPF check</a>. You can choose from several mechanisms: all, none, softfail, neutralize, or reject.</span></p> <ul> <li><i><span style="font-weight:400;">all</span></i><span style="font-weight:400;"> mechanism will accept all emails from senders who have passed your SPF check;</span></li> <li><i><span style="font-weight:400;">none</span></i><span style="font-weight:400;"> will reject everything from senders who have passed your SPF check;</span></li> <li><i><span style="font-weight:400;">softfail</span></i><span style="font-weight:400;"> will accept emails from senders who have failed an SPF check, but mark them as suspicious;</span></li> <li><i><span style="font-weight:400;">neutral</span></i><span style="font-weight:400;"> states that you&#8217;re neither rejecting nor accepting messages sent from your domain—it&#8217;s essentially a &#8220;no opinion&#8221; stance on whether the message should be accepted or rejected;</span></li> <li><i><span style="font-weight:400;">reject</span></i><span style="font-weight:400;"> will reject emails that failed the SPF check.</span></li> </ul> <div class='hr av-1zspwmc-3552f039bd582b0ec01eaab99f5789b2 hr-invisible  avia-builder-el-0  el_before_av_buttonrow  avia-builder-el-first'><span class='hr-inner'><span class="hr-inner-style"></span></span></div> <h2 style="text-align:center;" id="simplify-spf-record-syntax-with-powerdmarc"><strong>Simplify SPF Record Syntax with PowerDMARC!</strong></h2> <div class='avia-buttonrow-wrap av-tpjcrs-b04d460599174e0c7f2fe8361f9c0ec5 avia-buttonrow-center  avia-builder-el-1  el_after_av_hr  el_before_av_hr'> <a href="https://app.powerdmarc.com/en/members/register" class="avia-button av-m2nbzt8f-920d527a12282367b206ba6e64d16fae avia-icon_select-no avia-size-x-large avia-color-black" aria-label="Start 15-day trial" data-wpel-link="external" target="_blank"><span class='avia_iconbox_title'>Start 15-day trial</span></a> <a href="https://powerdmarc.com/book-a-demo/" class="avia-button av-m2nbzt8f-2-828d32fdd5277c82d1e479ee3d6511da avia-icon_select-no avia-size-x-large avia-color-blue" aria-label="Book a demo" data-wpel-link="internal" target="_self" rel="follow"><span class='avia_iconbox_title'>Book a demo</span></a> </div> <p>&lt;h2&gt;<span style="font-weight:400;">SPF Record Syntax Qualifiers</span></p> <p><b>&nbsp;</b><span style="font-weight:400;">The &#8220;qualifiers&#8221; in an SPF record syntax help to indicate the scope of the SPF record. These are primarily used to indicate whether or not a specific IP address is authorized to send emails on behalf of your domain.&nbsp;</span></p> <table> <tbody> <tr> <td><span style="font-weight:400;">Qualifier</span></td> <td><span style="font-weight:400;">Result Code</span></td> <td><span style="font-weight:400;">Explanation</span></td> </tr> <tr> <td><span style="font-weight:400;">+</span></td> <td><span style="font-weight:400;">Pass</span></td> <td><span style="font-weight:400;">the only qualifier with no negative connotation. It indicates that the domain name&#8217;s security record contains no errors or warnings and is considered secure.</span></td> </tr> <tr> <td><span style="font-weight:400;">&#8211;</span></td> <td><span style="font-weight:400;">Fail</span></td> <td><span style="font-weight:400;">indicates that the domain name&#8217;s security record contains errors or warnings that prevent it from being considered secure.</span><p></p> <p><span style="font-weight:400;">&nbsp;</span></p></td> </tr> <tr> <td><span style="font-weight:400;">~</span></td> <td><span style="font-weight:400;">Softfail</span></td> <td><span style="font-weight:400;">indicates that the domain name&#8217;s security record contains errors or warnings that do not prevent it from being considered secure, but may indicate problems with DNS resolution or other issues related to DNS trust anchors.</span></td> </tr> <tr> <td><span style="font-weight:400;">?</span></td> <td><span style="font-weight:400;">Neutral</span></td> <td><span style="font-weight:400;">Indicates that the domain has no SPF record or its record was syntactically correct but did not match any sending servers when checked against one (or more) sending servers in your list of trusted IP addresses for that domain.</span></td> </tr> </tbody> </table> <div class='hr av-1gzlmbo-f58b298aba59af129c0c07f3a3927a37 hr-invisible  avia-builder-el-2  el_after_av_buttonrow  el_before_av_buttonrow'><span class='hr-inner'><span class="hr-inner-style"></span></span></div> <h2 style="text-align:center;" id="simplify-spf-with-powerdmarc"><strong>Simplify SPF with PowerDMARC!</strong></h2> <div class='avia-buttonrow-wrap av-tpjcrs-3-a34c56117f680f75080227ae66a058cd avia-buttonrow-center  avia-builder-el-3  el_after_av_hr  el_before_av_hr'> <a href="https://app.powerdmarc.com/en/members/register" class="avia-button av-m2nbzt8f-2-1-4f6e9c3b70535fa47e1de143796b3d28 avia-icon_select-no avia-size-x-large avia-color-black" aria-label="Start 15-day trial" data-wpel-link="external" target="_blank"><span class='avia_iconbox_title'>Start 15-day trial</span></a> <a href="https://powerdmarc.com/book-a-demo/" class="avia-button av-m2nbzt8f-2-1-1-bce8acad2f0b3444448eea10461e7279 avia-icon_select-no avia-size-x-large avia-color-blue" aria-label="Book a demo" data-wpel-link="internal" target="_self" rel="follow"><span class='avia_iconbox_title'>Book a demo</span></a> </div> <h2 id="spf-record-syntax-mechanisms"><span style="font-weight:400;">SPF Record Syntax Mechanisms&nbsp;</span></h2> <p><span style="font-weight:400;">Mechanisms are used in the SPF record syntax to tell the receiving server what kind of authentication mechanism should be used. There are two types of mechanisms:&nbsp;</span></p> <ul> <li><span style="font-weight:400;"> &nbsp; &nbsp; &nbsp; </span><span style="font-weight:400;">the sender can specify a specific set of mechanisms;</span></li> <li><span style="font-weight:400;"> &nbsp; &nbsp; &nbsp; </span><span style="font-weight:400;">Or it can specify that all mechanisms are allowed.&nbsp;</span></li> </ul> <table> <tbody> <tr> <td><b class="nitro-lazy">Mechanism</b></td> <td><b>Purpose</b></td> <td><b>Directive Applies When</b></td> <td><b>Implementation</b></td> </tr> <tr> <td><span style="font-weight:400;">a</span></td> <td><span style="font-weight:400;">defines the DNS A record of the domain as authorized. If this directive is unspecified, then the current domain is used.</span><p></p> <p><span style="font-weight:400;">&nbsp;</span></p> <p><span style="font-weight:400;">&nbsp;</span></p></td> <td><span style="font-weight:400;">can be applied when queried for an A or AAAA record in a domain that contains the sender&#8217;s IP address.</span></td> <td><span style="font-weight:400;">a</span><p></p> <p><span style="font-weight:400;">a/&lt;prefix-length&gt;</span></p> <p><span style="font-weight:400;">a:&lt;domain&gt;</span></p> <p><span style="font-weight:400;">a:&lt;domain&gt;/&lt;prefix-length&gt;</span></p></td> </tr> <tr> <td><span style="font-weight:400;">all</span></td> <td><span style="font-weight:400;">The all directive is always matched, and it defines the policy for all other sources.</span></td> <td><span style="font-weight:400;">This mechanism should always be applied, and this mechanism always matches.</span></td> <td><span style="font-weight:400;">all</span></td> </tr> <tr> <td><span style="font-weight:400;">exists</span></td> <td><span style="font-weight:400;">Checks whether or not an A record is valid for a given domain. It works by looking at all A records on that domain and seeing if any of them match the criteria set out in your SPF record.</span></td> <td><span style="font-weight:400;">Applies when there is any A record on said domain or if other criteria, according to RFC7208, were authorized.</span></td> <td><span style="font-weight:400;">exists:&lt;domain&gt;</span></td> </tr> <tr> <td><span style="font-weight:400;">include</span></td> <td><span style="font-weight:400;">The purpose of this mechanism is to specify the domain and search for a match, as well as to return a permanent error if the domain does not have a valid SPF record.</span></td> <td><span style="font-weight:400;">The &#8220;include&#8221; mechanism in SPF records can be used to include other SPF records within a domain&#8217;s record. If a domain does not have an SPF record, but another domain does and that other domain has an IP address that matches the IP address of the sender, then the &#8220;include&#8221; mechanism will cause the domain with the matching IP address to be used for authorization purposes.</span><p></p> <p><span style="font-weight:400;">&nbsp;</span></p></td> <td><span style="font-weight:400;">include:&lt;domain&gt;</span></td> </tr> <tr> <td><span style="font-weight:400;">ip4</span></td> <td><span style="font-weight:400;">You can specify an IPv4 range with the &#8220;ip4&#8221; directive, along with a prefix that denotes the length of the range. If no prefix is specified, /32 is assumed.</span></td> <td><span style="font-weight:400;">The &#8220;ip4&#8221; mechanism will apply if any of these conditions are true:</span><p></p> <p><span style="font-weight:400;">&nbsp;</span></p> <p><span style="font-weight:400;">&#8211; The specified IPv4 address matches that of an IP address in your SPF record.</span></p> <p><span style="font-weight:400;">&nbsp;</span></p> <p><span style="font-weight:400;">&#8211; The specified IPv4 subnet contains the sender&#8217;s IP address.</span></p></td> <td><span style="font-weight:400;">ip4:&lt;ip4-address&gt;</span><p></p> <p><span style="font-weight:400;">ip4:&lt;ip4-network&gt;/&lt;prefix-length&gt;</span></p></td> </tr> <tr> <td><span style="font-weight:400;">ip6</span></td> <td><span style="font-weight:400;">You can specify an IPv6 range with the &#8220;ip4&#8221; directive, along with a prefix that denotes the length of the range. If no prefix is specified, /128 is assumed.</span></td> <td><span style="font-weight:400;">The &#8220;ip6&#8221; mechanism will apply if any of these conditions are true:</span><p></p> <p><span style="font-weight:400;">&nbsp;</span></p> <p><span style="font-weight:400;">&#8211; The specified IPv6 address matches that of an IP address in your SPF record.</span></p> <p><span style="font-weight:400;">&nbsp;</span></p> <p><span style="font-weight:400;">&#8211; The specified <a href="https://uptimerobot.com/knowledge-hub/devops/ipv4-ipv6/" rel="noopener" data-wpel-link="external" target="_blank">IPv6 subnet</a> contains the sender&#8217;s IP address.</span></p></td> <td><span style="font-weight:400;">ip6:&lt;ip6-address&gt;</span><p></p> <p><span style="font-weight:400;">ip6:&lt;ip6-network&gt;/&lt;prefix-length&gt;</span></p></td> </tr> <tr> <td><span style="font-weight:400;">mx</span></td> <td><span style="font-weight:400;"> The &#8220;mx&#8221; mechanism, as defined in the SPF record, defines the Domain Name System (DNS) Mail Exchanger (MX) record of a domain as authorized.</span></td> <td><span style="font-weight:400;">The DNS MX record determines which server is responsible for accepting email messages on behalf of the domain. The DNS MX record contains an IP address and a priority value for each server that can be used to accept messages.</span><p></p> <p><span style="font-weight:400;">&nbsp;</span></p> <p><span style="font-weight:400;">When an MX record of a domain contains an IP address that matches the sender&#8217;s IP address, then this indicates that this sender is authorized to send emails on behalf of this domain.</span></p></td> <td><span style="font-weight:400;">mx</span><p></p> <p><span style="font-weight:400;">mx/&lt;prefix-length&gt;</span></p> <p><span style="font-weight:400;">mx:&lt;domain&gt;</span></p> <p><span style="font-weight:400;">mx:&lt;domain&gt;/&lt;prefix-length&gt;</span></p></td> </tr> <tr> <td><span style="font-weight:400;">ptr</span></td> <td><span style="font-weight:400;">The ptr mechanism uses the reverse hostname or subdomain of the sending IP address to define the target domain name.</span></td> <td><span style="font-weight:400;">Only applies if there is at least one MX record for the queried or specified domain and that MX record contains a <a id="link_juicer" href="https://powerdmarc.com/what-is-a-dns-ptr-record/" data-wpel-link="internal" target="_self" rel="follow">PTR record</a> with an FQDN for the sender’s IP address.</span></td> <td><span style="font-weight:400;">ptr</span><p></p> <p><span style="font-weight:400;">ptr:&lt;domain&gt;</span></p></td> </tr> </tbody> </table> <div class='hr av-17vys4k-27b3bb1da2f8cb4371b8c9fdcb96b0a6 hr-invisible  avia-builder-el-4  el_after_av_buttonrow  el_before_av_hr'><span class='hr-inner'><span class="hr-inner-style"></span></span></div> <h2 id="spf-record-syntax-modifiers"><span style="font-weight:400;">SPF Record Syntax Modifiers</span></h2> <p><span style="font-weight:400;">In the SPF record syntax, modifiers can be used to change the default behavior of an SPF record. Modifiers may be used to specify exceptions to the rules, or they may be used to provide additional information to the receiver.</span></p> <table> <tbody> <tr> <td><span style="font-weight:400;">Modifier</span></td> <td><span style="font-weight:400;">Purpose</span></td> <td><span style="font-weight:400;">Implementation</span></td> </tr> <tr> <td><span style="font-weight:400;">exp</span></td> <td><span style="font-weight:400;"> The &#8220;exp&#8221; modifier is a value that specifies an explanation for why a message was rejected. It is intended to help senders avoid certain kinds of issues, and can be used to inform them about the specific reason their message was not accepted by the receiving server.</span></td> <td><span style="font-weight:400;">exp=&lt;domain&gt;</span></td> </tr> <tr> <td><span style="font-weight:400;">redirect</span></td> <td><span style="font-weight:400;">The redirect modifier is a string that replaces the entire domain name in the SPF record. The purpose of this modifier is to redirect all mail sent to the domain to another server. This may be useful for domains with multiple MX records or for domains that have been re-assigned to another company but are still using the same email addresses.</span></td> <td><span style="font-weight:400;">redirect=&lt;domain&gt;</span></td> </tr> </tbody> </table> <div class='hr av-wzjzb8-ce78f04adda5ee29aad808fe31acbeb4 hr-invisible  avia-builder-el-5  el_after_av_hr  avia-builder-el-last'><span class='hr-inner'><span class="hr-inner-style"></span></span></div> <h2 id="what-is-an-spf-record"><strong>What is an SPF Record?</strong></h2> <p><span style="font-weight:400;">An SPF record is a type of DNS record that identifies which servers are allowed to send an email on behalf of your domain. It does this by listing the servers that have been authorized to send emails for your domain; if any other server tries to send an email on behalf of your domain, it will be rejected as an unauthorized sender.</span></p> <p><span style="font-weight:400;">The purpose of an SPF record is to prevent malicious users from sending forged email messages with your domain in the From field. This can happen if an attacker sends out mass amounts of <a id="link_juicer" href="https://powerdmarc.com/what-is-spam-email/" data-wpel-link="internal" target="_self" rel="follow">spam emails</a> from your server by spoofing or forging your domain</span></p> <p><strong>How does SPF work?</strong></p> <h2 id="1-creating-an-spf-record-syntax"><b style="font-size:16px;">1. Creating an SPF Record Syntax</b></h2> <p><span style="font-weight:400;">You create an SPF record syntax in your DNS server that specifies which IP addresses are permitted to send emails from your domain. This means that if someone were trying to send spoofed emails from your domain, their messages would fail because the IP address of their mail server would not be listed as one of the approved servers.</span></p> <p><span style="font-weight:400;">For example, if you want only Gmail accounts to be able to send mail from your domain name, but not Outlook accounts, then you would add the following line to your SPF record:</span></p> <p><span style="font-weight:400;">&nbsp;v=spf1 a mx include:_spf.google.com ~all</span></p> <p><span style="font-weight:400;">&nbsp;This tells servers that any messages sent from any host whose IP address ends with _spf.google.com should be considered valid (m), whereas all other messages should be discarded (a).&nbsp;</span></p> <p><span style="font-weight:400;">You can use our </span><a href="https://powerdmarc.com/spf-record-generator/" data-wpel-link="internal" target="_self" rel="follow"><span style="font-weight:400;">SPF record generator</span></a><span style="font-weight:400;"> tool to start creating a free record now! </span></p> <p><b>2. DNS Lookup</b></p> <p><span style="font-weight:400;">When an email sender attempts to send a message, the recipient server performs a DNS lookup on the sending domain to see if there is an SPF record—this is called &#8220;authentication.&#8221;There is a limit of 10 lookups allowed per query, exceeding which leads to </span><a href="https://powerdmarc.com/spf-permerror-too-many-dns-lookups/" data-wpel-link="internal" target="_self" rel="follow"><span style="font-weight:400;">SPF permerror</span></a><span style="font-weight:400;">.&nbsp;</span></p> <p><span style="font-weight:400;">If there is no SPF record, then authentication fails and the message is not delivered. If there is an SPF record, then the SPF server checks for IP addresses in the TXT record at the hostname specified in the SPF record.</span></p> <p><span style="font-weight:400;">&nbsp;If there are no IP addresses specified, then it will fail authentication. Otherwise, it will perform an A query for each IP address specified in the order of appearance in the TXT record.</span></p> <p><span style="font-weight:400;">The IP address that returns a result code of NXDOMAIN or NOERROR will be considered authorized by the SPF server and its hostname will be added to a list of authorized sending hosts for that domain. </span></p> <p><b>3. Authentication Outcome</b></p> <p><span style="font-weight:400;">The mail server either delivers the message to the recipient or flags it for rejection based on the rules specified in the SPF record.</span></p> <p><span style="font-weight:400;">Authentication outcomes can take three forms: Pass, Neutral, or Fail.</span></p> <p><span style="font-weight:400;">Pass means that the mail server accepts the message as legitimate and allows it to be delivered. Neutral means that there is either no record at all or an invalid one for that domain in DNS, so there is no way of knowing whether or not this is a legitimate message from that domain. Fail means that something about this message was not authentic enough for it to be delivered.</span></p> <p><span style="font-weight:400;">For example, a mail server with IP address &#8216;234.2.1.2&#8217; sends an email from &#8216;<a href="/cdn-cgi/l/email-protection" class="__cf_email__" data-cfemail="4c262325220c2d3c3c2029622f2321">[email&#160;protected]</a>&#8217;. The inbound server will consult the domain name service (<a href="https://en.wikipedia.org/wiki/Domain_Name_System" rel="nofollow noopener" data-wpel-link="external" target="_blank">DNS</a>) to determine if this IP address is authorized to send emails on behalf of the &#8216;apple.com&#8217; domain. If so, the message will be delivered; otherwise, it will be discarded or marked as spam i.e sorted according to the mechanism specified in the SPF record.</span></p> <p><strong>Wrapping Up</strong></p> <p><span style="font-weight:400;">The SPF record is an important part of your domain&#8217;s DNS records. It tells other mail servers how to authenticate messages that claim to be from you, which means that it&#8217;s important for you to have a properly configured SPF record. However, make sure you pair SPF with DMARC for enhanced protection against email compromise and spoofing.&nbsp;</span></p> <p><span style="font-weight:400;">The</span><a href="https://powerdmarc.com/power-dmarc-toolbox/" data-wpel-link="internal" target="_self" rel="follow"> <span style="font-weight:400;">SPF Record Lookup Tool</span></a><span style="font-weight:400;"> can help you do just that. The lookup tool will give you a quick overview of what your current SPF record looks like, including whether or not it&#8217;s missing any required fields.The generator will let you create an SPF record syntax from scratch, complete with all required fields so that it can be added to your DNS records right away.</span></p> <p><a href="https://app.powerdmarc.com/en/members/register" class="custom-link no-lightbox" title="" aria-label="" onclick="event.stopPropagation()" target="_self" rel="" data-wpel-link="external"><img alt="" width="875" height="295" title="SPF Record Syntax" sizes="(max-width: 875px) 100vw, 875px" nitro-lazy-srcset="https://cdn-caklk.nitrocdn.com/sJCpruYkVvovUsWvtAEzkQwTuXjDDQLL/assets/images/optimized/rev-1ef354f/powerdmarc.com/wp-content/uploads/2022/06/CTA-.png 875w, https://cdn-caklk.nitrocdn.com/sJCpruYkVvovUsWvtAEzkQwTuXjDDQLL/assets/images/optimized/rev-1ef354f/powerdmarc.com/wp-content/uploads/2022/06/CTA--300x101.png 300w, https://cdn-caklk.nitrocdn.com/sJCpruYkVvovUsWvtAEzkQwTuXjDDQLL/assets/images/optimized/rev-1ef354f/powerdmarc.com/wp-content/uploads/2022/06/CTA--768x259.png 768w, https://cdn-caklk.nitrocdn.com/sJCpruYkVvovUsWvtAEzkQwTuXjDDQLL/assets/images/optimized/rev-1ef354f/powerdmarc.com/wp-content/uploads/2022/06/CTA--705x238.png 705w" nitro-lazy-src="https://cdn-caklk.nitrocdn.com/sJCpruYkVvovUsWvtAEzkQwTuXjDDQLL/assets/images/optimized/rev-1ef354f/powerdmarc.com/wp-content/uploads/2022/06/CTA-.png" class="alignnone size-full wp-image-38512 nitro-lazy" decoding="async" nitro-lazy-empty id="MTUwNzo3MTk=-1" src="data:image/svg+xml;nitro-empty-id=MTUwNzo3MTk=-1;base64,PHN2ZyB2aWV3Qm94PSIwIDAgODc1IDI5NSIgd2lkdGg9Ijg3NSIgaGVpZ2h0PSIyOTUiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+PC9zdmc+" /></a></p> <div class="abh_box abh_box_down abh_box_business"><ul class="abh_tabs"> <li class="abh_about abh_active"><a href="#abh_about">About</a></li> <li class="abh_posts"><a href="#abh_posts">Latest Posts</a></li></ul><div class="abh_tab_content"><section class="vcard author abh_about_tab abh_tab" itemscope itemprop="author" itemtype="http://schema.org/Person" style="display:block;"><div class="abh_image" itemscope itemtype="http://schema.org/ImageObject"><a href="https://powerdmarc.com/author/ahona-rudra/" class="fn url" target="_blank" title="Ahona Rudra" rel="nofollow" data-wpel-link="internal"> <img alt='' width='250' style='max-width:250px;' nitro-lazy-src="https://cdn-caklk.nitrocdn.com/sJCpruYkVvovUsWvtAEzkQwTuXjDDQLL/assets/images/optimized/rev-1ef354f/powerdmarc.com/wp-content/uploads/gravatar/whatsapp-image-2022-05-06-at-2.34.00-pm-1.jpeg" class="avatar avatar-250 photo nitro-lazy" decoding="async" nitro-lazy-empty id="MTUwOTo4MDk=-1" src="data:image/svg+xml;nitro-empty-id=MTUwOTo4MDk=-1;base64,PHN2ZyB2aWV3Qm94PSIwIDAgMjM1IDI1MCIgd2lkdGg9IjIzNSIgaGVpZ2h0PSIyNTAiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+PC9zdmc+" /></a> </div><div class="abh_social"> <a itemprop="sameAs" href="https://www.linkedin.com/in/ahona-rudra-96b636156/" title="LinkedIn" class="abh_linkedin" target="_blank" rel="nofollow" data-wpel-link="external"></a></div><div class="abh_text"><div class="abh_name fn name" itemprop="name"><a href="https://powerdmarc.com/author/ahona-rudra/" class="url" target="_blank" rel="nofollow" data-wpel-link="internal">Ahona Rudra</a></div><div class="abh_job"><span class="title">Domain & Email Security Expert</span> at <span class="org"><a href="https://powerdmarc.com" target="_blank" data-wpel-link="internal" rel="follow">PowerDMARC</a></span></div><div class="description note abh_description" itemprop="description">Ahona is the Marketing Manager at PowerDMARC, with 5+ years of experience in writing about cybersecurity topics, specializing in domain and email security. Ahona holds a post-graduation degree in Journalism and Communications, solidifying her career in the security sector since 2019.</div></div> </section><section class="abh_posts_tab abh_tab"><div class="abh_image"><a href="https://powerdmarc.com/author/ahona-rudra/" class="url" target="_blank" title="Ahona Rudra" rel="nofollow" data-wpel-link="internal"><img alt='' width='250' style='max-width:250px;' nitro-lazy-src="https://cdn-caklk.nitrocdn.com/sJCpruYkVvovUsWvtAEzkQwTuXjDDQLL/assets/images/optimized/rev-1ef354f/powerdmarc.com/wp-content/uploads/gravatar/whatsapp-image-2022-05-06-at-2.34.00-pm-1.jpeg" class="avatar avatar-250 photo nitro-lazy" decoding="async" nitro-lazy-empty id="MTUwOToyMjI3-1" src="data:image/svg+xml;nitro-empty-id=MTUwOToyMjI3-1;base64,PHN2ZyB2aWV3Qm94PSIwIDAgMjM1IDI1MCIgd2lkdGg9IjIzNSIgaGVpZ2h0PSIyNTAiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+PC9zdmc+" /></a></div><div class="abh_social"> <a href="https://www.linkedin.com/in/ahona-rudra-96b636156/" title="LinkedIn" class="abh_linkedin" target="_blank" rel="nofollow" data-wpel-link="external"></a></div><div class="abh_text"><div class="abh_name">Latest posts by Ahona Rudra <span class="abh_allposts">(<a href="https://powerdmarc.com/author/ahona-rudra/" data-wpel-link="internal" target="_self" rel="follow">see all</a>)</span></div><div class="abh_description note"><ul> <li> <a href="https://powerdmarc.com/dmarc-msp-case-study-1-msp/" data-wpel-link="internal" target="_self" rel="follow">DMARC MSP Case Study: 1-MSP Elevates Client Security &#038; Brand Identity with PowerDMARC</a><span> - May 19, 2025</span> </li> <li> <a href="https://powerdmarc.com/microsoft-sender-requirements/" data-wpel-link="internal" target="_self" rel="follow">Microsoft Sender Requirements Enforced— How to Avoid 550 5.7.15 Rejections</a><span> - April 30, 2025</span> </li> <li> <a href="https://powerdmarc.com/how-to-prevent-spyware/" data-wpel-link="internal" target="_self" rel="follow">How to Prevent Spyware?</a><span> - April 25, 2025</span> </li></ul></div></div> </section></div> </div></div><span class="post-meta-infos"></span><footer class="entry-footer"><div class='av-social-sharing-box av-social-sharing-box-default av-social-sharing-box-fullwidth'></div></footer><div class='post_delimiter'></div></div><div class="post_author_timeline"></div></article><div class='single-big'></div> <div class='comment-entry post-entry'> </div>  </main> <aside class='sidebar sidebar_right  smartphones_sidebar_active alpha units' aria-label="Sidebar"><div class="inner_sidebar extralight-border"><section id="custom_html-8" class="widget_text widget clearfix widget_custom_html"><div class="textwidget custom-html-widget"><div class="container" style="padding:50px 20px 50px 20px;background-color:#f2f6f9;"> <p style="color:#1c73e8;text-align:center;"> <strong>Secure Your Email</strong> </p> <p style="color:#282963;text-align:center;"> Stop Email Spoofing and Improve Email Deliverability </p> <p style="color:#282963;text-align:center;"> <strong>15-day Free trial!</strong> </p> <br /> <div class="but" style="display:flex;justify-content:center;"> <a href="https://app.powerdmarc.com/en/members/register" data-wpel-link="external" target="_blank"><button type="button" style="padding:20px 35px 20px 35px;background-color:black;color:white;font-size:20px;border-radius:40px;border:none;"><strong>Sign Up Free!</strong></button></a> </div> </div> </div><span class="seperator extralight-border"></span></section><section id="social_share_widget-2" class="widget clearfix widget_social_share_widget"><p class="widgettitle">Share</p><ul class="custom-share-buttons"><li><a target="_blank" href="https://www.facebook.com/sharer.php?u=https://powerdmarc.com/spf-record-syntax/" class="btn--share share-facebook" data-wpel-link="external"><i class="ct-icon-facebook"></i></a></li><li><a href="https://www.linkedin.com/shareArticle?mini=true&amp;url=https%3A%2F%2Fpowerdmarc.com%2Fspf-record-syntax%2F" class="btn--share share-linkedin" target="_blank" data-wpel-link="external"><i class="ct-icon-linkedin2"></i></a></li><li><a target="_blank" href="//twitter.com/share?text=SPF Record Syntax&amp;url=https://powerdmarc.com/spf-record-syntax/" class="btn--share share-twitter" data-wpel-link="external"><i class="ct-icon-x"></i></a></li></ul><span class="seperator extralight-border"></span></section><section id="search-3" class="widget clearfix widget_search"> <search> <form action="https://powerdmarc.com/" id="searchform" method="get" class="av_disable_ajax_search"> <div> <span class='av_searchform_search avia-svg-icon avia-font-svg_entypo-fontello' data-av_svg_icon='search' data-av_iconset='svg_entypo-fontello'><svg version="1.1" xmlns="http://www.w3.org/2000/svg" width="25" height="32" viewbox="0 0 25 32" preserveaspectratio="xMidYMid meet" aria-labelledby='av-svg-title-1' aria-describedby='av-svg-desc-1' role="graphics-symbol" aria-hidden="true"> <title id='av-svg-title-1'>Search</title> <desc id='av-svg-desc-1'>Search</desc> <path d="M24.704 24.704q0.96 1.088 0.192 1.984l-1.472 1.472q-1.152 1.024-2.176 0l-6.080-6.080q-2.368 1.344-4.992 1.344-4.096 0-7.136-3.040t-3.040-7.136 2.88-7.008 6.976-2.912 7.168 3.040 3.072 7.136q0 2.816-1.472 5.184zM3.008 13.248q0 2.816 2.176 4.992t4.992 2.176 4.832-2.016 2.016-4.896q0-2.816-2.176-4.96t-4.992-2.144-4.832 2.016-2.016 4.832z"></path> </svg></span> <input type="submit" value="" id="searchsubmit" class="button" title="Click to start search" /> <input type="search" id="s" name="s" value="" aria-label='Search' placeholder='Search' required /> </div> </form> </search> <span class="seperator extralight-border"></span></section><section id="newsbox-2" class="widget clearfix avia-widget-container newsbox"><h3 class="widgettitle">Latest Blogs</h3><ul class="news-wrap image_size_widget"><li class="news-content post-format-standard"><div class="news-link"><a class="news-thumb" title="Read: DMARCbis Explained – What’s Changing and How to Prepare" href="https://powerdmarc.com/dmarcbis-explained/" data-wpel-link="internal" target="_self" rel="follow"><img fetchpriority="high" width="36" height="36" alt="" sizes="(max-width: 36px) 100vw, 36px" title="DMARCbis Explained – What’s Changing and How to Prepare" nitro-lazy-srcset="https://cdn-caklk.nitrocdn.com/sJCpruYkVvovUsWvtAEzkQwTuXjDDQLL/assets/images/optimized/rev-1ef354f/powerdmarc.com/wp-content/uploads/2025/05/DMARCbis-Explained-%E2%80%93-Whats-Changing-and-How-to-Prepare--36x36.jpg 36w, https://cdn-caklk.nitrocdn.com/sJCpruYkVvovUsWvtAEzkQwTuXjDDQLL/assets/images/optimized/rev-1ef354f/powerdmarc.com/wp-content/uploads/2025/05/DMARCbis-Explained-%E2%80%93-Whats-Changing-and-How-to-Prepare--80x80.jpg 80w, https://cdn-caklk.nitrocdn.com/sJCpruYkVvovUsWvtAEzkQwTuXjDDQLL/assets/images/optimized/rev-1ef354f/powerdmarc.com/wp-content/uploads/2025/05/DMARCbis-Explained-%E2%80%93-Whats-Changing-and-How-to-Prepare--180x180.jpg 180w" nitro-lazy-src="https://cdn-caklk.nitrocdn.com/sJCpruYkVvovUsWvtAEzkQwTuXjDDQLL/assets/images/optimized/rev-1ef354f/powerdmarc.com/wp-content/uploads/2025/05/DMARCbis-Explained-%E2%80%93-Whats-Changing-and-How-to-Prepare--36x36.jpg" class="wp-image-65780 attachment-widget size-widget wp-post-image nitro-lazy" decoding="async" nitro-lazy-empty id="MTU0ODoxMjY5-1" src="data:image/svg+xml;nitro-empty-id=MTU0ODoxMjY5-1;base64,PHN2ZyB2aWV3Qm94PSIwIDAgMzYgMzYiIHdpZHRoPSIzNiIgaGVpZ2h0PSIzNiIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj48L3N2Zz4=" /></a><div class="news-headline"><a class="news-title" title="Read: DMARCbis Explained – What’s Changing and How to Prepare" href="https://powerdmarc.com/dmarcbis-explained/" data-wpel-link="internal" target="_self" rel="follow">DMARCbis Explained – What’s Changing and How to Prepare</a><span class="news-time">May 19, 2025 - 8:32 am</span></div></div></li><li class="news-content post-format-standard"><div class="news-link"><a class="news-thumb" title="Read: DMARC MSP Case Study: 1-MSP Elevates Client Security &#038; Brand Identity with PowerDMARC" href="https://powerdmarc.com/dmarc-msp-case-study-1-msp/" data-wpel-link="internal" target="_self" rel="follow"><img fetchpriority="high" width="36" height="36" alt="1msp-powerdmarc-success-story" sizes="(max-width: 36px) 100vw, 36px" title="DMARC MSP Case Study: 1-MSP Elevates Client Security &amp; Brand Identity with PowerDMARC" nitro-lazy-srcset="https://cdn-caklk.nitrocdn.com/sJCpruYkVvovUsWvtAEzkQwTuXjDDQLL/assets/images/optimized/rev-1ef354f/powerdmarc.com/wp-content/uploads/2025/05/1msp-powerdmarc-success-story-36x36.jpg 36w, https://cdn-caklk.nitrocdn.com/sJCpruYkVvovUsWvtAEzkQwTuXjDDQLL/assets/images/optimized/rev-1ef354f/powerdmarc.com/wp-content/uploads/2025/05/1msp-powerdmarc-success-story-80x80.jpg 80w, https://cdn-caklk.nitrocdn.com/sJCpruYkVvovUsWvtAEzkQwTuXjDDQLL/assets/images/optimized/rev-1ef354f/powerdmarc.com/wp-content/uploads/2025/05/1msp-powerdmarc-success-story-180x180.jpg 180w" nitro-lazy-src="https://cdn-caklk.nitrocdn.com/sJCpruYkVvovUsWvtAEzkQwTuXjDDQLL/assets/images/optimized/rev-1ef354f/powerdmarc.com/wp-content/uploads/2025/05/1msp-powerdmarc-success-story-36x36.jpg" class="wp-image-65842 attachment-widget size-widget wp-post-image nitro-lazy" decoding="async" nitro-lazy-empty id="MTU0ODoyNjcw-1" src="data:image/svg+xml;nitro-empty-id=MTU0ODoyNjcw-1;base64,PHN2ZyB2aWV3Qm94PSIwIDAgMzYgMzYiIHdpZHRoPSIzNiIgaGVpZ2h0PSIzNiIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj48L3N2Zz4=" /></a><div class="news-headline"><a class="news-title" title="Read: DMARC MSP Case Study: 1-MSP Elevates Client Security &#038; Brand Identity with PowerDMARC" href="https://powerdmarc.com/dmarc-msp-case-study-1-msp/" data-wpel-link="internal" target="_self" rel="follow">DMARC MSP Case Study: 1-MSP Elevates Client Security &#038; Brand Identity with PowerDMARC</a><span class="news-time">May 19, 2025 - 6:36 am</span></div></div></li><li class="news-content post-format-standard"><div class="news-link"><a class="news-thumb" title="Read: DKIM in TXT vs. CNAME – Key Differences &#038; Best Practices" href="https://powerdmarc.com/dkim-txt-vs-cname/" data-wpel-link="internal" target="_self" rel="follow"><img fetchpriority="high" width="36" height="36" alt="" sizes="(max-width: 36px) 100vw, 36px" title="DKIM in TXT vs. CNAME – Key Differences &amp; Best Practices" nitro-lazy-srcset="https://cdn-caklk.nitrocdn.com/sJCpruYkVvovUsWvtAEzkQwTuXjDDQLL/assets/images/optimized/rev-1ef354f/powerdmarc.com/wp-content/uploads/2025/05/DKIM-in-TXT-vs.-CNAME-36x36.jpg 36w, https://cdn-caklk.nitrocdn.com/sJCpruYkVvovUsWvtAEzkQwTuXjDDQLL/assets/images/optimized/rev-1ef354f/powerdmarc.com/wp-content/uploads/2025/05/DKIM-in-TXT-vs.-CNAME-80x80.jpg 80w, https://cdn-caklk.nitrocdn.com/sJCpruYkVvovUsWvtAEzkQwTuXjDDQLL/assets/images/optimized/rev-1ef354f/powerdmarc.com/wp-content/uploads/2025/05/DKIM-in-TXT-vs.-CNAME-180x180.jpg 180w" nitro-lazy-src="https://cdn-caklk.nitrocdn.com/sJCpruYkVvovUsWvtAEzkQwTuXjDDQLL/assets/images/optimized/rev-1ef354f/powerdmarc.com/wp-content/uploads/2025/05/DKIM-in-TXT-vs.-CNAME-36x36.jpg" class="wp-image-65706 attachment-widget size-widget wp-post-image nitro-lazy" decoding="async" nitro-lazy-empty id="MTU0ODo0MDE3-1" src="data:image/svg+xml;nitro-empty-id=MTU0ODo0MDE3-1;base64,PHN2ZyB2aWV3Qm94PSIwIDAgMzYgMzYiIHdpZHRoPSIzNiIgaGVpZ2h0PSIzNiIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj48L3N2Zz4=" /></a><div class="news-headline"><a class="news-title" title="Read: DKIM in TXT vs. CNAME – Key Differences &#038; Best Practices" href="https://powerdmarc.com/dkim-txt-vs-cname/" data-wpel-link="internal" target="_self" rel="follow">DKIM in TXT vs. CNAME – Key Differences &#038; Best Practices</a><span class="news-time">May 14, 2025 - 7:32 am</span></div></div></li><li class="news-content post-format-standard"><div class="news-link"><a class="news-thumb" title="Read: Recipient Address Rejected: Access Denied – Causes &#038; Fixes (SMTP 550 5.7.1)" href="https://powerdmarc.com/recipient-address-rejected-access-denied/" data-wpel-link="internal" target="_self" rel="follow"><img fetchpriority="high" width="36" height="36" alt="Recipient-Address-Rejected" sizes="(max-width: 36px) 100vw, 36px" title="Recipient Address Rejected: Access Denied – Causes &amp; Fixes (SMTP 550 5.7.1)" nitro-lazy-srcset="https://cdn-caklk.nitrocdn.com/sJCpruYkVvovUsWvtAEzkQwTuXjDDQLL/assets/images/optimized/rev-1ef354f/powerdmarc.com/wp-content/uploads/2025/05/Recipient-Address-Rejected-36x36.jpg 36w, https://cdn-caklk.nitrocdn.com/sJCpruYkVvovUsWvtAEzkQwTuXjDDQLL/assets/images/optimized/rev-1ef354f/powerdmarc.com/wp-content/uploads/2025/05/Recipient-Address-Rejected-80x80.jpg 80w, https://cdn-caklk.nitrocdn.com/sJCpruYkVvovUsWvtAEzkQwTuXjDDQLL/assets/images/optimized/rev-1ef354f/powerdmarc.com/wp-content/uploads/2025/05/Recipient-Address-Rejected-180x180.jpg 180w" nitro-lazy-src="https://cdn-caklk.nitrocdn.com/sJCpruYkVvovUsWvtAEzkQwTuXjDDQLL/assets/images/optimized/rev-1ef354f/powerdmarc.com/wp-content/uploads/2025/05/Recipient-Address-Rejected-36x36.jpg" class="wp-image-65668 attachment-widget size-widget wp-post-image nitro-lazy" decoding="async" nitro-lazy-empty id="MTU0ODo1NDA4-1" src="data:image/svg+xml;nitro-empty-id=MTU0ODo1NDA4-1;base64,PHN2ZyB2aWV3Qm94PSIwIDAgMzYgMzYiIHdpZHRoPSIzNiIgaGVpZ2h0PSIzNiIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj48L3N2Zz4=" /></a><div class="news-headline"><a class="news-title" title="Read: Recipient Address Rejected: Access Denied – Causes &#038; Fixes (SMTP 550 5.7.1)" href="https://powerdmarc.com/recipient-address-rejected-access-denied/" data-wpel-link="internal" target="_self" rel="follow">Recipient Address Rejected: Access Denied – Causes &#038; Fixes (SMTP 550 5.7.1)</a><span class="news-time">May 9, 2025 - 5:53 am</span></div></div></li></ul><span class="seperator extralight-border"></span></section><section id="categories-3" class="widget clearfix widget_categories"><h3 class="widgettitle">Categories</h3> <ul> <li class="cat-item cat-item-69"><a href="https://powerdmarc.com/blogs/" data-wpel-link="internal" target="_self" rel="follow">Blog</a> </li> <li class="cat-item cat-item-2163"><a href="https://powerdmarc.com/blogs/cybersecurity/" data-wpel-link="internal" target="_self" rel="follow">Cybersecurity</a> </li> <li class="cat-item cat-item-2161"><a href="https://powerdmarc.com/blogs/dkim/" data-wpel-link="internal" target="_self" rel="follow">DKIM</a> </li> <li class="cat-item cat-item-2160"><a href="https://powerdmarc.com/blogs/dmarc/" data-wpel-link="internal" target="_self" rel="follow">DMARC</a> </li> <li class="cat-item cat-item-2159"><a href="https://powerdmarc.com/blogs/email-security/" data-wpel-link="internal" target="_self" rel="follow">Email Security</a> </li> <li class="cat-item cat-item-2164"><a href="https://powerdmarc.com/blogs/esp-alignment/" data-wpel-link="internal" target="_self" rel="follow">ESP Alignment</a> </li> <li class="cat-item cat-item-71"><a href="https://powerdmarc.com/news/" data-wpel-link="internal" target="_self" rel="follow">News</a> </li> <li class="cat-item cat-item-73"><a href="https://powerdmarc.com/press-releases/" data-wpel-link="internal" target="_self" rel="follow">Press Releases</a> </li> <li class="cat-item cat-item-2162"><a href="https://powerdmarc.com/blogs/spf/" data-wpel-link="internal" target="_self" rel="follow">SPF</a> </li> <li class="cat-item cat-item-2155"><a href="https://powerdmarc.com/success-stories/" data-wpel-link="internal" target="_self" rel="follow">Success Stories</a> </li> </ul> <span class="seperator extralight-border"></span></section></div></aside> </div> </div>"}; window.dispatchEvent(new CustomEvent('nitrofragmentloaded', {detail: "2f66f9a155b7a85308b498ba19513c84"}));