PWA Demos
Biometric Auth

Biometric Authentication with Passkeys - Demo & Code

With the Web Authentication API, users can sign up and log in to your PWA with facial recognition or their fingerprint scanner using a cutting-edge technology called Passkeys.

Biometric Auth Logo


Install this demo PWA, and launch it from your iPhone or Android phone's home screen, tap the Authenticate button below to create a Passkey, and choose an authentication method.

How it works

The Web Authentication API (WebAuthn) allows users to register and authenticate using their device's biometric capabilities, such as fingerprint readers, facial recognition (like iOS FaceID), or other local authenticators like device passwords or external USB Security Keys.

During registration, a unique credential, often referred to as a Passkey is created on the user's device. The ID of this Passkey is then saved against the user's profile in your database.

Later, when users attempt to log in using WebAuthn, your PWA will provide the stored Passkey ID to the Web Authentication API. The user will then authenticate using their previously registered method (e.g., fingerprint or face scan). If the authentication is successful, your app will receive a response confirming the user's identity, which you can then verify server-side.

Note that the actual biometric data (like fingerprints) is never shared with your server. Instead, the biometric data is used locally on the device to verify the user and the corresponding authentication response is shared with your app.

Below you'll find the code of our Passkey authentication demo. While this is a simplified client-side only version, it captures the essence of the functionality.

Browser support

The Web Authentication API is supported by most modern browsers, including Chrome on Android and Safari on iOS.


Links & Documentation

Your app here

Unlock the powers of the web today

Try our PWA toolkit free of charge and without limits for 14 days. No credit card required.

Get started See plans