Australian flagJoin us at the FIDO seminar in Melbourne – Feb 7, 2025!
passkeys incognito mode coverWebAuthn Know-How

Do Passkeys Work in Incognito Mode?

Learn if and how passkeys / WebAuthn work in incognito or private browsing modes of Chrome, Safari, Edge, and Firefox.

Vincent Delitz

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.

Overview#

1. Introduction#

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:

  1. Do passkeys work in incognito / private browsing mode?
  2. What is the behavior of passkey authentication in incognito / private mode in Chrome, Safari, Edge and Firefox?

This knowledge ensures a smooth user experience across different browsers and operating systems, positioning your application at the forefront of security and convenience.

2. Passkeys and Incognito Mode: An Overview#

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.

Substack Icon

Subscribe to our Passkeys Substack for the latest news, insights and strategies.

Subscribe

Incognito 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).

3. Behavior of Passkeys in Different Browsers and Operating Systems#

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 10Windows 11Android 14iOS 17.5macOS 14
Chrome✅ (with extra screen)
Edge✅ (with extra screen
Safarin/an/an/a
Firefox

3.1 Passkeys on Windows 10 and Chrome Incognito / Edge InPrivate Mode until Version 129#

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):

passkeys windows 10 chrome incognito modeChrome incognito mode passkey error message on Windows 10

passkeys windows 10 edge inprivate modeEdge 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.

Slack Icon

Become part of our Passkeys Community for updates and support.

Join

3.2 Passkeys on Windows 10 and Chrome Incognito / Edge InPrivate Mode (129+)#

Starting 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/VersionNormal Mode (W10)Incognito/Private Mode (W10)Behavior in UI
Chrome ≤ 128 (pre-change)truefalseNo platform authenticator in Incognito
Chrome ≥ 129truetruePrompts for security key instead of platform authenticator
Edge ≤ 128 (pre-change)truefalseNo platform authenticator in InPrivate
Edge ≥ 129truetruePrompts for security key instead of platform authenticator

Observed Behavior:

  • In Chrome/Edge Incognito on Windows 10, despite the promise returning true, the platform authenticator does not show up for passkey creation.
  • Users are instead prompted to add a security key (e.g., YubiKey)
  • While hardware security keys still work for passkey creation, this is not the expected flow when using platform authenticators such as Windows Hello.

passkeys windows10 chrome incognito passkey create error

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.

3.3 Passkeys on Windows 11 and Incognito / Edge InPrivate Mode#

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.

passkeys windows 11 chrome incognito edge inprivate mode

3.4 Passkeys on Android and Chrome Incognito / Edge InPrivate Mode#

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.

passkeys android 14 chrome incognito edge inprivate mode

4. Conclusion#

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.

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