# next-auth **Repository Path**: mirrors_taoqf/next-auth ## Basic Information - **Project Name**: next-auth - **Description**: Authentication for Next.js - **Primary Language**: Unknown - **License**: ISC - **Default Branch**: main - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 0 - **Created**: 2020-12-06 - **Last Updated**: 2026-03-08 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README # NextAuth.js ![Build Test](https://github.com/nextauthjs/next-auth/workflows/Build%20Test/badge.svg) ![Integration Test](https://github.com/nextauthjs/next-auth/workflows/Integration%20Test/badge.svg) ## Overview NextAuth.js is a complete open source authentication solution for [Next.js](http://nextjs.org/) applications. It is designed from the ground up to support Next.js and Serverless. [Follow the examples](https://next-auth.js.org/getting-started/example) to see how easy it is to use NextAuth.js for authentication. Install: `npm i next-auth` See [next-auth.js.org](https://next-auth.js.org) for more information and documentation. ## Features ### Flexible and easy to use * Designed to work with any OAuth service, it supports OAuth 1.0, 1.0A and 2.0 * Built-in support for [many popular sign-in services](https://next-auth.js.org/configuration/providers) * Supports email / passwordless authentication * Supports stateless authentication with any backend (Active Directory, LDAP, etc) * Supports both JSON Web Tokens and database sessions * Designed for Serverless but runs anywhere (AWS Lambda, Docker, Heroku, etc…) ### Own your own data NextAuth.js can be used with or without a database. * An open source solution that allows you to keep control of your data * Supports Bring Your Own Database (BYOD) and can be used with any database * Built-in support for [MySQL, MariaDB, Postgres, Microsoft SQL Server, MongoDB and SQLite](https://next-auth.js.org/configuration/databases) * Works great with databases from popular hosting providers * Can also be used *without a database* (e.g. OAuth + JWT) ### Secure by default * Promotes the use of passwordless sign in mechanisms * Designed to be secure by default and encourage best practice for safeguarding user data * Uses Cross Site Request Forgery Tokens on POST routes (sign in, sign out) * Default cookie policy aims for the most restrictive policy appropriate for each cookie * When JSON Web Tokens are enabled, they are signed by default (JWS) with HS512 * Use JWT encryption (JWE) by setting the option `encryption: true` (defaults to A256GCM) * Auto-generates symmetric signing and encryption keys for developer convenience * Features tab/window syncing and keepalive messages to support short lived sessions * Attempts to implement the latest guidance published by [Open Web Application Security Project](https://owasp.org/) Advanced options allow you to define your own routines to handle controlling what accounts are allowed to sign in, for encoding and decoding JSON Web Tokens and to set custom cookie security policies and session properties, so you can control who is able to sign in and how often sessions have to be re-validated. ### Typescript This library gained Typescript support recently. You can install the types in the following way: ``` $ npm i -D @types/next-auth ``` In you encounter any issue with them, please raise an issue and add the "typescript" label to it, we'll try to help you with it as soon as possible. Alternatively you can raise a PR directly with your fixes on [**DefinitelyTyped**](https://github.com/DefinitelyTyped/DefinitelyTyped/tree/master/types/next-auth). ## Example ### Add API Route ```javascript import NextAuth from 'next-auth' import Providers from 'next-auth/providers' const options = { providers: [ // OAuth authentication providers Providers.Apple({ clientId: process.env.APPLE_ID, clientSecret: process.env.APPLE_SECRET }), Providers.Google({ clientId: process.env.GOOGLE_ID, clientSecret: process.env.GOOGLE_SECRET }), // Sign in with passwordless email link Providers.Email({ server: process.env.MAIL_SERVER, from: '' }), ], // SQL or MongoDB database (or leave empty) database: process.env.DATABASE_URL } export default (req, res) => NextAuth(req, res, options) ``` ### Add React Component ```javascript import React from 'react' import { useSession, signin, signout } from 'next-auth/client' export default function myComponent() { const [ session, loading ] = useSession() return

{!session && <> Not signed in
} {session && <> Signed in as {session.user.email}
}

} ``` ## Acknowledgement [NextAuth.js is possible thanks to its contributors.](https://next-auth.js.org/contributors) ## Getting started [Follow the examples to get started.](https://next-auth.js.org/getting-started/example) ## Contributing If you'd like to contribute to you can find useful information in our [Contributing Guide](https://github.com/iaincollins/next-auth/blob/main/CONTRIBUTING.md).