docs/self-hosting/migration/v2/auth/migration-internals.zh-CN.mdx
本文档解释 LobeHub 认证迁移的技术原理,适合有数据库和开发经验的用户,帮助理解迁移的底层逻辑。
<Callout type={'info'}> 如需分步迁移指南,请参阅 NextAuth 迁移 或 Clerk 迁移。 </Callout>
理解数据库 Schema 是排查迁移问题的关键。
users 表是认证框架无关的通用用户表,适用于任何认证系统。每条记录代表一个唯一的用户身份及其关联的个人信息。
关键字段:
| 字段 | 说明 |
|---|---|
id | 用户唯一标识(主键) |
email | 用户邮箱地址(唯一) |
avatar, firstName, lastName | 个人资料信息 |
accounts 表存储认证提供商连接。不同的 SSO 提供商和邮箱密码认证都被视为独立的「账号」,关联到同一个用户。
账号示例:
关系:一个用户可以有多个账号(1:N 关系)。
┌─────────────────┐ ┌─────────────────┐
│ users │ │ accounts │
├─────────────────┤ ├─────────────────┤
│ id (PK) │◄───────┤│ user_id (FK) │
│ email (unique) │ │ provider │
│ avatar │ │ provider_id │
│ ... │ │ ... │
└─────────────────┘ └─────────────────┘
│
┌───────┴───────┐
│ │
┌───────▼──┐ ┌──────▼───┐
│ Google │ │ GitHub │
│ Account │ │ Account │
└──────────┘ └──────────┘
<Callout type={'warning'}> 迁移不会保留登录会话。用户在迁移后必须重新登录。 </Callout>
简单迁移只迁移 users 表,忽略 accounts 表。
工作原理:
users 表中accounts 表中创建新的账号记录为什么有效:
当你重置密码或使用 SSO 登录时,如果提供商返回的邮箱与 users 表中的现有邮箱匹配,系统会将你关联到该现有用户。
局限性:
由于没有迁移 accounts 表,系统不知道之前关联的账号信息。
示例场景:
[email protected])和 Microsoft([email protected])关联到同一个用户users 表存储主邮箱:[email protected][email protected] 登录 → ✅ 关联到现有用户[email protected] 登录 → ❌ 创建新用户(没有账号记录将 [email protected] 关联到原用户)完整迁移将账号数据从之前的认证系统迁移到 Better Auth 的 accounts 表。
迁移的数据:
nextauth_accounts 表 → Better Auth accounts 表accounts 表结果:
所有之前关联的账号继续有效。使用 [email protected] 登录将正确关联到现有用户。
这通常发生在简单迁移后使用副邮箱登录时。
诊断步骤:
找到你的原始用户记录
通过主邮箱查询 users 表:
SELECT id, email FROM users WHERE email = '[email protected]';
记下 id 值。
检查关联到该用户的账号
使用用户 ID 查询 accounts 表:
SELECT * FROM accounts WHERE user_id = 'your-user-id';
找到错误创建的账号
如果你使用副邮箱登录并创建了新用户,找到该账号:
SELECT * FROM accounts WHERE provider_account_id = '[email protected]';
-- 或者对于 SSO 提供商,按提供商的用户 ID 搜索
修复方法:
删除错误创建的账号记录:
DELETE FROM accounts WHERE id = 'incorrect-account-id';
如果创建了新用户,可能还需要删除它:
DELETE FROM users WHERE id = 'new-user-id';
使用你的主邮箱(存储在 users 表中的邮箱)登录
登录后,进入 设置 → 个人资料 → 关联账号 重新关联你的副账号
检查:
确保 SSO 提供商已在 AUTH_SSO_PROVIDERS 中配置
验证提供商凭证(AUTH_<PROVIDER>_ID、AUTH_<PROVIDER>_SECRET)
对于完整迁移,验证账号记录是否正确创建:
SELECT * FROM accounts WHERE provider = 'google'; -- 或你的提供商
检查:
验证你使用的邮箱与 users 表中的邮箱匹配
检查你最初是否使用了不同的邮箱或 SSO 提供商
直接查询数据库查找符合条件的用户:
SELECT * FROM users WHERE email LIKE '%your-domain.com';
<Card href={'/zh/docs/self-hosting/migration/v2/auth/clerk-to-betterauth'} title={'Clerk 迁移指南'} />
<Card href={'/zh/docs/self-hosting/auth'} title={'认证服务配置'} /> </Cards>