DEV Community

Cover image for Improving user experience with passwordless authentication
Aditya Oberai for Appwrite

Posted on • Originally published at appwrite.io

Improving user experience with passwordless authentication

Today, as concerns about security and user convenience only grow with digital activity, traditional password-based authentication systems are becoming a relic of the past. In recent times, we have seen a rise in passwordless systems, which are increasingly seeing adoption in both small and big companies alike, such as Expensify (whose transition was also covered in a Forbes article in 2023. A survey from Enterprise Strategy Group, a division of TechTarget, in 2022 also revealed that:

  • 31% of respondents picked passwordless authentication as their top identity-related activity
  • 34% of respondents chose passwordless authentication among their top three identity-related activities
  • 54% of respondents have started to transition to passwordless authentication
  • Of organizations transitioning to passwordless strategies, more than 50% experienced a significant positive impact on risk reduction and improved UX
  • Almost two-thirds reported increased efficiency for IT and security teams

Therefore, in this blog, we'll explore what passwordless authentication is, the drawbacks of conventional methods, and how embracing passwordless solutions can be a game-changer.

The drawbacks of traditional password-based systems

As per an article by Lastpass, passwords need to be treated like a user experience today because repeated login attempts, forgotten passwords, mandatory password changes, and looking up passwords in a document or notebook only slow employees down and create friction in their workflow. Traditional password systems, despite their ubiquity, come with significant drawbacks, including:

  • Password fatigue: Users struggle with remembering numerous passwords for different accounts.
  • Security risks: Weak or reused passwords increase vulnerability to hacking and data breaches.
  • User inconvenience: Managing complex passwords is often cumbersome and frustrating and only causes more fatigue.
  • Time-consuming: Resetting forgotten passwords and managing accounts adds unnecessary steps.
  • Phishing vulnerabilities: Traditional passwords are susceptible to phishing attacks and can open up new attack vectors for a product.
  • Limited physical security: Passwords can be easily observed or stolen, especially in public or shared spaces.

What is passwordless authentication?

Passwordless authentication is exactly what it sounds like – a way to authenticate users without the need for passwords. This paradigm shift in user verification employs methods like passkeys (fingerprint, facial scans, or screen lock), magic links (one-time clickable links sent via email or SMS), and one-time passcodes (OTPs) sent to a user's device. These methods are not only innovative but also align with the natural human tendency to seek convenience and simplicity.

Benefits of passwordless authentication for user experience

The transition to passwordless authentication brings a myriad of benefits:

  • Enhanced security: By eliminating passwords, we inherently reduce the risk of password-related breaches.
  • Improved ease of use: Users no longer need to remember or manage a plethora of passwords. This simplifies the login process, leading to a more frictionless user experience.
  • Accelerated process: Authentication becomes quicker, with just a click or a touch, streamlining the user's journey.
  • Higher authentication speed: Users can access services faster, without the delay of typing a password.
  • Enhanced user retention: Easier login processes can lead to lower user drop-off rates.
  • Accessibility for all users: Such methods can be more accessible for users who have difficulty remembering passwords or have physical disabilities that make typing challenging.
  • Lower support costs: A lack of passwords reduces the volume of password reset requests and related support issues, saving an immense amount of IT and support effort and cost.
  • Scalability: Easily adapts to growing user bases without the need for extensive password management systems.
  • Reduced risk of internal threats: Minimizes the risk of password theft or misuse by internal actors within an organization.

Tradeoffs of passwordless authentication

While the benefits are substantial, passwordless authentication isn't without its tradeoffs, such as:

  • Implementation complexity: It can be more challenging and resource-intensive to implement than traditional methods.
  • Hardware dependencies: Some methods require specific hardware, like biometric scanners, which add further costs and may not be as readily accessible everywhere.
  • Privacy and security concerns: The collection of biometric data raises privacy issues for individuals as well as opens up newer security challenges in regard to how the data must be stored.
  • User adaptation: Users are often accustomed to well-set systems and may need time to adapt to new authentication methods.
  • Potential technical issues: Some methods rely on the proper functioning of user devices and external systems (like email or SMS services), which the company may not have control of.

Implementing passwordless authentication using Appwrite

Appwrite Authentication also features three commonly used passwordless authentication methods: magic links, email OTPs, and phone authentication, which can be integrated into applications seamlessly with Appwrite’s client-side SDKs. This approach not only enhances security but also significantly improves the user experience by simplifying and streamlining the login process.

Magic URLs

Magic URL authentication is a two-step process in Appwrite.

First, we initialize the login process by sending an email with the magic URL. If the email has never been used, a new account is also generated.

import { Client, Account, ID } from "appwrite";

const client = new Client()
    .setEndpoint('https://cloud.appwrite.io/v1')
    .setProject('<PROJECT_ID>');

const account = new Account(client);

const user = await account.createMagicURLSession(ID.unique(), 'email@example.com', '<APP_URL>');
Enter fullscreen mode Exit fullscreen mode

After receiving the secret from an email, you can create a session for the user.

const urlParams = new URLSearchParams(window.location.search);
const secret = urlParams.get('secret');
const userId = urlParams.get('userId');

const user = await account.updateMagicURLSession(userId, secret);
Enter fullscreen mode Exit fullscreen mode

Email OTPs

Email OTP authentication is a two-step process in Appwrite.

First, we initialize the login process by sending an email. If the email has never been used, a new account is also generated.

import { Client, Account, ID } from "appwrite";

const client = new Client()
    .setEndpoint('https://cloud.appwrite.io/v1')
    .setProject('<PROJECT_ID>');

const account = new Account(client);

const sessionToken = await account.createEmailToken(
    ID.unique(),
    'email@example.com'
);

const userId = sessionToken.userId;

Enter fullscreen mode Exit fullscreen mode

After receiving the secret (6-digit number) in the email, you can use it along with the returned user ID to confirm the user.

const session = await account.createSession(
    userId,
    '[SECRET]'
);
Enter fullscreen mode Exit fullscreen mode

Phone auth

Phone authentication is a two-step process in Appwrite.

First, we initialize the login process by sending an SMS. If the phone number has never been used, a new account is also generated.

import 'package:appwrite/appwrite.dart';

final client = Client()
    .setEndpoint('https://cloud.appwrite.io/v1')
    .setProject('<PROJECT_ID>');

final account = Account(client);

final sessionToken = await account.createPhoneSession(
    userId: ID.unique(),
    phone: '+14255550123'
);

final userId = sessionToken.userId;
Enter fullscreen mode Exit fullscreen mode

After receiving the secret (6-digit number) in the SMS, you can use it along with the returned user ID to confirm the user.

final session = await account.updatePhoneSession(
    userId: userId,
    secret: '[SECRET]'
);
Enter fullscreen mode Exit fullscreen mode

Passwordless authentication stands at the forefront of a new era in digital security and user experience. My recommendation to all is to embrace the future – say goodbye to passwords and hello to a more secure, convenient digital experience.

Learn more about Appwrite Authentication from our docs and join our Discord community to interact with fellow developers using the same.

Top comments (0)