Exploring Anti-Phishing Measures in Microsoft 365

In this post we will explore some of the anti-phishing measures employed by Microsoft 365 (formally Office 365) as well as their weaknesses. Certitude was able to identify an issue in that allows malicious actors to bypass anti-phishing measures.

When an Outlook user receives an e-mail from an address they don’t typically communicate with, Outlook shows an alert which reads “You don’t often get email from xyz@example.com. Learn why this is important”. This is what Microsoft calls the First Contact Safety Tip, and it is one of the various anti-phishing measures available in Exchange Online Protection (EOP) and Microsoft Defender to organizations using Office 365:

The First Contact Safety Tip is prepended to the body of an HTML email, which means it is possible to alter the way it is displayed through the use of CSS style tags.

As a proof of concept, let’s demonstrate an HTML email which “hides” the First Contact Safety Tip from the user. Although applying some more common CSS rules such as display: none, height: 0px, and opacity: 0 to the table itself doesn’t seem to work (either due to the inline CSS in the elements, or due to lack of support by the rendering engine Outlook uses), it is possible to change the background and font colors to white so that the alert is effectively invisible when rendered to the end user viewing the email:

<head>
</head>
<head>
    <style>
        a {
            display: none;
        }
        td div {
            color: white;
            font-size: 0px;
        }
        table tbody tr td {
            background-color: white !important;
            color: white !important;
        }
    </style>
</head>

...[SNIP]...

By using this HTML code in an e-mail, the alert does not show up in the email body anymore!

Note that the e-mail preview (highlighted in red) still begins with the Safety Tip.

One Step Further

Since we’re already on the topic of phishing, we can take this a step further, and spoof the icons Microsoft Outlook adds to emails that are encrypted and/or signed:

...[SNIP]...
        #mainTable {
            width: 100%;
            z-index: 1;
            margin-bottom: 1em;
        }
        #signedBy {
            font-size: 0.9em;
        }
        .badge {
            width: 2.8em;
            text-align: right;
        }
    </style>
</head>
<table id="mainTable">
    <tr>
        <td id="signedBy" style="color:#666 !important;">
            Signed By &nbsp;&nbsp;nimmerrichtermarc@gmail․com
        </td>
        <td class="badge">
            <img src=""/>
        </td>
        <td class="badge">
            <img src=""/>
        </td>
    </tr>
</table>

One thing to note here is that the ‘.’ character in ‘Signed By nimmerrichtermarc@gmail.com’ is actually the Unicode character U+2024, and not a regular period. This is because when left as a period, Outlook will automatically detect nimmerrichtermarc@gmail.com as an email address and generate a mailto link, which would look noticeably different from the original text we are trying to spoof.

When compared to an email which is actually signed and encrypted, more attentive users will of course notice a difference in formatting, however some users will not. It only takes one person to fall for the phishing attack for an adversary to gain a foothold in the organization!

Responsible Disclosure

After developing a proof of concept, and preparing an advisory, we made Microsoft aware of these issues through the Microsoft Researcher Portal (MSRC). Microsoft chose to not address this behavior for now:

We determined your finding is valid but does not meet our bar for immediate servicing considering this is mainly applicable for phishing attacks. However, we have still marked your finding for future review as an opportunity to improve our products.

Microsoft MSRC, 14.02.2024

Authors

This research was conducted by William Moody and Wolfgang Ettlinger.