Learn if and how passkeys / WebAuthn work in incognito or private browsing modes of Chrome, Safari, Edge, and Firefox.
Vincent
Created: July 22, 2024
Updated: December 18, 2024
Our mission is to make the Internet a safer place, and the new login standard passkeys provides a superior solution to achieve that. That's why we want to keep you up to date on the latest developments in the industry.
3.1 Passkeys on Windows 10 and Incognito / Edge InPrivate Mode
3.2 Passkeys on Windows 11 and Incognito / Edge InPrivate Mode
3.3 Passkeys on Android and Chrome Incognito / Edge InPrivate Mode
More and more companies are implementing passkeys into their websites and apps. While doing so, many software developers and product managers question themselves if passkeys work in in incognito or private browsing modes, as this has major influence on the overall user experience.
With this blog post, we try to answer the following questions:
This knowledge ensures a smooth user experience across different browsers and operating systems, positioning your application at the forefront of security and convenience.
Passkeys are essentially cryptographic keys used for authenticating users without the need for traditional passwords. They offer enhanced security by eliminating the risks associated with password theft and phishing attacks.
Typically, passkeys are stored securely within the device, and their functionality remains consistent even in incognito or private modes for most operating systems apart from Windows 10 (see below), provided the device is passkey-ready.
Subscribe to our Passkeys Substack for the latest news, insights and strategies.
SubscribeIncognito or private modes are commonly used to browse the internet without leaving a trace. This feature is valuable for users who prioritize privacy, and it's essential that authentication methods, such as passkeys, work seamlessly within these modes.
In the history of WebAuthn development, however, there have been ongoing discussions and improvements as the behavior used to be quite confusing and inconsistent among operating systems and browser (see these old discussions and bug reports for reference here, here and here).
Understanding the behavior of passkeys in various browsers and operating systems helps in ensuring compatibility and a smooth user experience.
Do passkeys work in incognito / private browsing mode?
Windows 10 | Windows 11 | Android 14 | iOS 17.5 | macOS 14 | |
---|---|---|---|---|---|
Chrome | ❌ | ✅ (with extra screen) | ✅ | ✅ | ✅ |
Edge | ❌ | ✅ (with extra screen | ✅ | ✅ | ✅ |
Safari | n/a | n/a | n/a | ✅ | ✅ |
Firefox | ✅ | ✅ | ✅ | ✅ | ✅ |
On Windows 10 (22H2), we discovered the only exception for passkeys not reliably working and got the two following screenshots when trying to use a platform authenticator (Windows Hello):
Chrome incognito mode passkey error message on Windows 10
Edge inPrivate mode passkey error message on Windows 10
When we switched into the regular browsing mode, everything worked as expected, so the error message in the popup is misleading.
Moreover, if we tried to use a cross-platform authenticator (e.g. hardware security key, like YubiKey, or Cross-Device Authentication via QR code / Bluetooth) this worked.
When digging further down into the issue and executing the following two commands in the browser console to determine if the platform authenticator (PublicKeyCredential.isUserVerifyingPlatformAuthenticatorAvailable()
) and Conditional UI (PublicKeyCredential.isConditionalMediationAvailable()
) was available, we made an interesting discovery: the first promise returned false
, while the second one returned true
, which didn’t make any sense, as platform authenticators are required for Conditional UI to work.
Become part of our Passkeys Community for updates and support.
JoinStarting from Chrome 129 (and similarly in Edge, which is Chromium-based), PublicKeyCredential.isUserVerifyingPlatformAuthenticatorAvailable()
returns true
even in Incognito / InPrivate mode on Windows 10. Previously, this was false
in incognito. Despite now returning true
, the platform authenticator remains unavailable for creating new passkeys, causing a broken user flow.
Below is a table that shows the return values of PublicKeyCredential.isUserVerifyingPlatformAuthenticatorAvailable()
on Windows 10 in different Chrome/Edge versions and modes:
Browser/Version | Normal Mode (W10) | Incognito/Private Mode (W10) | Behavior in UI |
---|---|---|---|
Chrome ≤ 128 (pre-change) | true | false | No platform authenticator in Incognito |
Chrome ≥ 129 | true | true | Prompts for security key instead of platform authenticator |
Edge ≤ 128 (pre-change) | true | false | No platform authenticator in InPrivate |
Edge ≥ 129 | true | true | Prompts for security key instead of platform authenticator |
Observed Behavior:
true
, the platform authenticator does not show up for passkey creation.Impact of Change:
This effectively breaks the flow for adding passkeys to the platform authenticator in Incognito/InPrivate mode. The adjustment in Chrome 129+ was primarily made to enable login functionality with passkeys in Incognito mode. Login flows use the same detection mechanism to check for passkey support (PublicKeyCredential.isUserVerifyingPlatformAuthenticatorAvailable()
), and this change ensures that logins can proceed smoothly. However, the unintended consequence is the broken experience for creating passkeys with the platform authenticator in private browsing modes.
Further details about this change can be found in the Chromium Source Code Review and the associated issue tracker discussion. For websites aiming to provide optimal support for passkeys, detecting incognito mode is currently the only way to mitigate this issue. By identifying when a user is in Incognito/InPrivate mode on Windows 10 with Chrome/Edge, websites can preemptively avoid offering platform authenticator options for passkey creation.
When using Windows Hello as platform authenticator, a security pop-up appears during passkey creation in incognito mode (on Chrome) / inPrivate mode (on Edge), alerting users that the passkey will be stored and usable later in non-incognito mode (this behavior was tested on Windows 11 22H2). Considering one of the use-cases of incognito mode, where a user wants to create an account without the trace of any information, this warning makes sense.
On Android and using the incognito mode (on Chrome) / inPrivate mode (on Edge), the behavior is similarly to Windows 11, as there is an informational popup shown that tells the user that the passkey will be saved in the password manager and anyone with access to the password manager will also have access to the passkey.
In summary, passkeys function reliably in incognito and private modes across major browsers and operating systems, with some specific exceptions on Windows 10 for creation of passkeys. By leveraging Corbado's solutions, developers can implement passkeys efficiently, and product managers can enhance user experiences without compromising on security.
Table of Contents
Enjoyed this read?
🤝 Join our Passkeys Community
Share passkeys implementation tips and get support to free the world from passwords.
🚀 Subscribe to Substack
Get the latest news, strategies, and insights about passkeys sent straight to your inbox.
We provide UI components, SDKs and guides to help you add passkeys to your app in <1 hour
Start for free