Golang个人收藏夹核心是“用户-资源-收藏关系”建模,需绑定用户身份(session/JWT鉴权),通过context传递user.ID;Bookmark结构含UserID、URL(逻辑主键)、Title、CreatedAt;增删查需校验URL格式、去重插入、路径解码删除、倒序分页查询;初期推荐SQLite并建(user_id, url)联合索引。
用 Golang 实现个人收藏夹,核心是“用户-资源-收藏关系”的建模与高效读写。不需要复杂框架,靠标准库 + 简洁结构 + 合理存储就能跑得稳。
收藏功能必须绑定用户,否则数据无法归属。推荐用 session 或 JWT 做基础鉴权,后端通过 user.ID 区分不同用户的收藏行为。不建议用 cookie 直存用户 ID,至少做简单签名或加密。登录成功后,在上下文(context.Context)里塞入用户信息,后续 handler 可直接取用,避免重复查库。
关键不是存“什么被收藏”,而是“谁在什么时候收藏了什么”。典型结构如下:
type Bookmark struct {
ID int64 `json:"id"`
UserID int64 `json:"user_id"` // 关联用户
URL string `json:"url"` // 原始链接(唯一标识资源)
Title string `json:"title"` // 可选:抓取或用户填写的标题
CreatedAt time.Time `json:"created_at"`
}
注意:URL 作为逻辑主键的一部分(配合 UserID),插入前先查是否已存在,避免重复收藏。不用 UUID,URL 字符串本身具备业务唯一性,索引也更高效。
初期用 SQLite 完全够用:单文件、零配置、ACID 支持好,适合个人项目。表加联合索引 (user_id, url) 加速去重和查询。数据量上来后可平滑迁移到 PostgreSQL,只需改 DSN 和微调 SQL(比如 SQLite 的 INSERT OR IGNORE → PostgreSQL 的 INSERT ... ON CONFLICT DO NOTHING)。
基本上就这些。逻辑清晰、边界明确,不复杂但容易忽略 URL 去重和用户上下文传递。