Next.js Basic Authentication

0.1.3 · maintenance · verified Wed Apr 22

nextjs-basic-auth provides a straightforward method for integrating HTTP Basic Authentication directly into Next.js applications on a per-route basis. Currently at version 0.1.3, this package is designed for simplicity, offering an `initializeBasicAuth` function that returns a check function to be awaited within `getServerSideProps`. It explicitly requires developers to opt out of Next.js's static generation for any authenticated pages, as it needs a server-side context to perform credential checks for each request. Its release cadence appears stable and infrequent, focusing on a specific, well-defined security concern for Next.js page routes. Key differentiators include its direct integration with `getServerSideProps` for page-level protection, in contrast to middleware-based solutions (like `nextjs-basic-auth-middleware`) or more comprehensive authentication libraries (like NextAuth.js) that handle broader authentication flows including sessions, OAuth, and database integration.

Common errors

Warnings

Install

Imports

Quickstart

Demonstrates initializing basic authentication with a list of users and applying it to a Next.js page using `getServerSideProps` to protect the route.

import initializeBasicAuth from 'nextjs-basic-auth';

const users = [
  { user: 'user1', password: 'toocool' },
  { user: 'admin', password: process.env.ADMIN_PASSWORD ?? 'password' }, // Use env vars for production!
];

// Initialize the basic auth checker once globally or per module
const basicAuthCheck = initializeBasicAuth({
  users: users
});

// In your Next.js page file (e.g., pages/protected.js or app/protected/page.js for Pages Router or App Router with getServerSideProps emulation)
export async function getServerSideProps(ctx) {
  const { req, res } = ctx;

  // Await the auth check. If authentication fails, it will send a 401 response and prompt the user.
  await basicAuthCheck(req, res);

  // If authentication passes, proceed with rendering the page
  return {
    props: {},
  };
}

// If using the App Router, this pattern is less direct and would typically involve server components or middleware.
// This example is primarily for the Pages Router where getServerSideProps is common.

view raw JSON →