auth0-react

โดย auth0

การตรวจสอบสิทธิ์สำหรับ React SPA โดยใช้ Auth0 Universal Login แบบ redirect-based flows รองรับ React 16–19 กับ Vite หรือ Create React App ห่อหุ้มแอปของคุณด้วย Auth0Provider และเปิดเผย hooks เช่น useAuth0(), loginWithRedirect() และ logout() จัดการเซสชันผู้ใช้ โทเค็นการเข้าถึง และข้อมูลโปรไฟล์โดยอัตโนมัติ SDK จัดการการจัดเก็บโทเค็นอย่างปลอดภัยโดยไม่ต้องจัดการ localStorage ด้วยตนเอง รวมถึง protected routes การฉีด API token และรูปแบบการจัดการข้อผิดพลาดที่บันทึกไว้ในคู่มือการผสานรวม...

npx skills add https://github.com/auth0/agent-skills --skill auth0-react

Auth0 React Integration

Add authentication to React single-page applications using @auth0/auth0-react.


Prerequisites

  • React 16.11+ application (Vite or Create React App) - supports React 16, 17, 18, and 19
  • Auth0 account and application configured
  • If you don't have Auth0 set up yet, use the auth0-quickstart skill first

When NOT to Use

  • Next.js applications - Use auth0-nextjs skill for both App Router and Pages Router
  • React Native mobile apps - Use auth0-react-native skill for iOS/Android
  • Server-side rendered React - Use framework-specific SDK (Next.js, Remix, etc.)
  • Embedded login - This SDK uses Auth0 Universal Login (redirect-based)
  • Backend API authentication - Use express-openid-connect or JWT validation instead

Quick Start Workflow

1. Install SDK

npm install @auth0/auth0-react

2. Configure Environment

For automated setup with Auth0 CLI, see Setup Guide for complete scripts.

For manual setup:

Create .env file:

Vite:

VITE_AUTH0_DOMAIN=your-tenant.auth0.com
VITE_AUTH0_CLIENT_ID=your-client-id

Create React App:

REACT_APP_AUTH0_DOMAIN=your-tenant.auth0.com
REACT_APP_AUTH0_CLIENT_ID=your-client-id

3. Wrap App with Auth0Provider

Update src/main.tsx (Vite) or src/index.tsx (CRA):

import React from 'react';
import ReactDOM from 'react-dom/client';
import { Auth0Provider } from '@auth0/auth0-react';
import App from './App';

ReactDOM.createRoot(document.getElementById('root')!).render(
  <React.StrictMode>
    <Auth0Provider
      domain={import.meta.env.VITE_AUTH0_DOMAIN} // or process.env.REACT_APP_AUTH0_DOMAIN
      clientId={import.meta.env.VITE_AUTH0_CLIENT_ID}
      authorizationParams={{
        redirect_uri: window.location.origin
      }}
    >
      <App />
    </Auth0Provider>
  </React.StrictMode>
);

4. Add Authentication UI

import { useAuth0 } from '@auth0/auth0-react';

export function LoginButton() {
  const { loginWithRedirect, logout, isAuthenticated, user, isLoading } = useAuth0();

  if (isLoading) return <div>Loading...</div>;

  if (isAuthenticated) {
    return (
      <div>
        <span>Welcome, {user?.name}</span>
        <button onClick={() => logout({ logoutParams: { returnTo: window.location.origin } })}>
          Logout
        </button>
      </div>
    );
  }

  return <button onClick={() => loginWithRedirect()}>Login</button>;
}

5. Test Authentication

Start your dev server and test the login flow:

npm run dev  # Vite
# or
npm start    # CRA

Detailed Documentation

  • Setup Guide - Automated setup scripts (Bash/PowerShell), CLI commands, manual configuration
  • Integration Guide - Protected routes, API calls, error handling, advanced patterns
  • API Reference - Complete SDK API, configuration options, hooks reference, testing strategies

Common Mistakes

MistakeFix
Forgot to add redirect URI in Auth0 DashboardAdd your application URL (e.g., http://localhost:3000, https://app.example.com) to Allowed Callback URLs in Auth0 Dashboard
Using wrong env var prefixVite uses VITE_ prefix, Create React App uses REACT_APP_
Not handling loading stateAlways check isLoading before rendering auth-dependent UI
Storing tokens in localStorageNever manually store tokens - SDK handles secure storage automatically
Missing Auth0Provider wrapperEntire app must be wrapped in <Auth0Provider>
Provider not at root levelAuth0Provider must wrap all components that use auth hooks
Wrong import path for env varsVite uses import.meta.env.VITE_*, CRA uses process.env.REACT_APP_*
Using acr_values redirect for in-app MFAUse useAuth0().mfa API for in-app enrollment/challenge/verify flows
Not catching MfaRequiredErrorWrap getAccessTokenSilently in try/catch and check instanceof MfaRequiredError
Making direct HTTP calls to MFA endpointsUse the mfa property from useAuth0() — it handles token management automatically
Forgetting refresh tokens for step-up MFASet useRefreshTokens={true} on Auth0Provider when using interactiveErrorHandler="popup"

Related Skills

  • auth0-quickstart - Basic Auth0 setup
  • auth0-migration - Migrate from another auth provider
  • auth0-mfa - Add Multi-Factor Authentication
  • auth0-cli - Manage Auth0 resources from the terminal

Quick Reference

Core Hooks:

  • useAuth0() - Main authentication hook
  • isAuthenticated - Check if user is logged in
  • user - User profile information
  • loginWithRedirect() - Initiate login
  • logout() - Log out user
  • getAccessTokenSilently() - Get access token for API calls
  • mfa - MFA API client for enrollment, challenge, and verification
    • mfa.getAuthenticators(mfaToken) - List enrolled authenticators
    • mfa.getEnrollmentFactors(mfaToken) - Get available enrollment factors
    • mfa.enroll(params) - Enroll new authenticator (OTP, SMS, Email, Voice, Push)
    • mfa.challenge(params) - Initiate MFA challenge
    • mfa.verify(params) - Verify MFA challenge and complete authentication

MFA Error Types (import from @auth0/auth0-react):

  • MfaRequiredError - Thrown by getAccessTokenSilently when MFA is needed (has mfa_token and mfa_requirements)
  • MfaEnrollmentError, MfaChallengeError, MfaVerifyError - Thrown by respective mfa.* methods

Common Use Cases:


References

Skills เพิ่มเติมจาก auth0

acul-screen-generator
auth0
สร้างการใช้งานหน้าจอ Auth0 Advanced Custom Universal Login (ACUL) ที่สมบูรณ์และมีแบรนด์ โดยใช้ React หรือ Vanilla JS SDK ใช้เมื่อนักพัฒนาขอให้…
official
auth0-android
auth0
ใช้เมื่อเพิ่มการรับรองความถูกต้องให้กับแอปพลิเคชัน Android (Kotlin/Java) ด้วย Web Auth, ข้อมูลประจำตัวที่ป้องกันด้วยไบโอเมตริกซ์ และ MFA - ผสานรวม…
official
auth0-angular
auth0
ใช้เมื่อเพิ่มการรับรองความถูกต้องให้กับแอปพลิเคชัน Angular พร้อม route guards และ HTTP interceptors - ผสานรวม @auth0/auth0-angular SDK สำหรับ SPA
official
auth0-aspnetcore-api
auth0
ใช้เมื่อรักษาความปลอดภัยปลายทาง ASP.NET Core Web API ด้วยการตรวจสอบ JWT Bearer token, การตรวจสอบขอบเขต/สิทธิ์ หรือการรับรองความถูกต้องแบบไร้สถานะ - ผสานรวม…
official
auth0-cli
auth0
เอกสารอ้างอิงสำหรับคำสั่ง Auth0 CLI — apps, apis, users, roles, organizations, actions, logs, custom domains, universal-login, terraform, raw API mode, และ --json…
official
auth0-expo
auth0
ใช้เมื่อเพิ่มการรับรองความถูกต้องให้กับแอปมือถือ Expo (React Native) — การเข้าสู่ระบบ, การออกจากระบบ, เซสชันผู้ใช้, เส้นทางที่ได้รับการป้องกัน, การยืนยันตัวตนด้วยชีวภาพ, หรือการจัดการโทเค็น ผสานรวม…
official
auth0-express
auth0
ใช้เมื่อเพิ่มการตรวจสอบสิทธิ์ (เข้าสู่ระบบ, ออกจากระบบ, เส้นทางที่ป้องกัน) ให้กับเว็บแอปพลิเคชัน Express.js - ผสานรวม express-openid-connect สำหรับการตรวจสอบสิทธิ์แบบเซสชัน
official
auth0-fastapi-api
auth0
ใช้เมื่อต้องการรักษาความปลอดภัยของ FastAPI API endpoints ด้วยการตรวจสอบ JWT Bearer token, การตรวจสอบ scope/permission หรือ stateless auth - ผสานรวม auth0-fastapi-api สำหรับ REST…
official