React 实现 JWT 登录验证的最小可运行示例

下面是一个用 React 实现 JWT 登录验证的最小可运行示例,包含:

  • React 前端:登录、保存 Token、获取用户数据。
  • 模拟后端:用 mock API(你也可以接真后端)。

🧱 技术栈

  • React(使用 Vite)
  • axios 发送请求
  • localStorage 保存 JWT
  • 使用一个假的后端 API(模拟 JWT 认证)

🚀 最终效果

  1. 用户输入用户名和密码登录;
  2. 服务器返回 JWT;
  3. 前端保存 JWT;
  4. 访问受保护的用户信息页时,携带 JWT 请求头访问。

🛠️ 第一步:初始化项目

bash 复制代码
npm create vite@latest jwt-demo -- --template react
cd jwt-demo
npm install
npm install axios

📁 目录结构

复制代码
src/
├─ App.jsx
├─ pages/
│  ├─ Login.jsx
│  └─ Profile.jsx
├─ api.js
└─ main.jsx

✏️ 第二步:代码实现

🔹 src/api.js(模拟 API)

js 复制代码
import axios from 'axios';

const mockToken = "fake-jwt-token-123456";

export async function login(username, password) {
  if (username === 'admin' && password === '123456') {
    return { token: mockToken };
  } else {
    throw new Error('登录失败');
  }
}

export async function getProfile(token) {
  if (token === mockToken) {
    return { username: 'admin', email: 'admin@example.com' };
  } else {
    throw new Error('无效Token');
  }
}

🔹 src/pages/Login.jsx

js 复制代码
import { useState } from 'react';
import { login } from '../api';

export default function Login({ onLogin }) {
  const [username, setUsername] = useState('');
  const [password, setPassword] = useState('');
  const [error, setError] = useState('');

  const handleLogin = async () => {
    try {
      const res = await login(username, password);
      localStorage.setItem('token', res.token);
      onLogin();
    } catch (e) {
      setError('用户名或密码错误');
    }
  };

  return (
    <div>
      <h2>登录</h2>
      <input placeholder="用户名" value={username} onChange={e => setUsername(e.target.value)} /><br />
      <input type="password" placeholder="密码" value={password} onChange={e => setPassword(e.target.value)} /><br />
      <button onClick={handleLogin}>登录</button>
      {error && <p style={{ color: 'red' }}>{error}</p>}
    </div>
  );
}

🔹 src/pages/Profile.jsx

js 复制代码
import { useEffect, useState } from 'react';
import { getProfile } from '../api';

export default function Profile() {
  const [profile, setProfile] = useState(null);
  const [error, setError] = useState('');

  useEffect(() => {
    const token = localStorage.getItem('token');
    getProfile(token)
      .then(data => setProfile(data))
      .catch(err => setError('认证失败,请重新登录'));
  }, []);

  if (error) return <p>{error}</p>;
  if (!profile) return <p>加载中...</p>;

  return (
    <div>
      <h2>用户信息</h2>
      <p>用户名: {profile.username}</p>
      <p>邮箱: {profile.email}</p>
    </div>
  );
}

🔹 src/App.jsx

js 复制代码
import { useState } from 'react';
import Login from './pages/Login';
import Profile from './pages/Profile';

export default function App() {
  const [isLoggedIn, setIsLoggedIn] = useState(!!localStorage.getItem('token'));

  const handleLogout = () => {
    localStorage.removeItem('token');
    setIsLoggedIn(false);
  };

  return (
    <div>
      {isLoggedIn ? (
        <>
          <Profile />
          <button onClick={handleLogout}>退出登录</button>
        </>
      ) : (
        <Login onLogin={() => setIsLoggedIn(true)} />
      )}
    </div>
  );
}

✅ 运行

bash 复制代码
npm run dev

访问 http://localhost:5173,输入:

  • 用户名:admin
  • 密码:123456

然后你将登录并看到用户信息页,JWT 被保存在 localStorage


后面重启后就不用再输入密码了

相关推荐
燐妤6 分钟前
前端HTML编程5:JavaScript完全指南
前端·javascript·html
3D探路人14 分钟前
模灵 大模型聚合API 转发流程技术实现
java·大数据·开发语言·前端·人工智能·计算机视觉
烛阴30 分钟前
Unity资源加载进化论:从AssetBundle到Addressables,一文带你吃透手游资源管理
前端·c#·unity3d
TO_WebNow40 分钟前
使用thinkPHP8.x 访问接口提示跨域
前端·php
掘金一周41 分钟前
回家的时候用车,不回家感觉又没啥用,这车还要不要买 | 沸点周刊 5.14
前端
梦想的颜色1 小时前
前端UI宝藏SKILL——UI/UX Pro Max
前端·ui·ux
無名路人1 小时前
uniApp 小程序 vue3 app.vue静默登录其他页面等待登录完成方式二
前端·微信小程序·ai编程
CoCo的编程之路1 小时前
2026 前端效能飞跃:深度解析智能助手的页面构建最大化方案
前端·人工智能·ai编程·智能编程助手·文心快码baiducomate
JavaAgent架构师2 小时前
前端AI工程化(一):AI通信协议深度解析
前端·人工智能
林恒smileZAZ2 小时前
前端如何让图片、视频、pdf等文件在浏览器直接下载而非预览
前端·pdf