一个优雅、快速、易于部署的书签(网址)收藏与分享平台,完全基于 Cloudflare 全家桶构建。
在线体验: https://iori.hidns.vip
---
| 首页 | 后台管理 |
|---|---|
![]() |
![]() |
![]() |
![]() |
| 大卡片 | 小卡片 |
|---|---|
![]() |
![]() |
| 简洁风格 | 夜间模式 |
|---|---|
![]() |
![]() |
卡片的毛玻璃效果和程度可以在后台设置里自定义。后台设置页面为url后加 /admin
- 📱 响应式设计:完美适配桌面、平板和手机等各种设备。
- 🎨 主题美观:界面简洁优雅,支持自定义主色调。
- 🔍 快速搜索:内置站内模糊搜索,迅速定位所需网站。
- 📂 分类清晰:通过分类组织书签,浏览直观高效。
- 🔒 安全后台:基于 KV 的管理员认证,提供完整的书签增删改查后台。
- 📝 用户提交(可配置):支持访客提交书签,经管理员审核后显示,可在环境变量中关闭入口。
- ⚡ 性能卓越:利用 Cloudflare 边缘缓存,实现秒级加载,并极大节省 D1 数据库读取成本。
- 📤 数据管理:支持书签数据的导入与导出,格式兼容,方便迁移。
-
12-25 增加夜间模式,首页设置增加记住上次选择分类
-
12-23 增加私密分类,导入和导出支持私密书签和分类,导入增加覆盖选项和预览框
-
12-20 增加卡片风格设置,首页设置,允许自定义字体,字体大小,颜色,增加首页外部搜索开关
-
12-19 增加360壁纸(速度较慢,轮询推荐bing),分类支持多级分类
-
12-18 布局设置中增加卡片增加毛玻璃效果开关和滑动条设置,背景增加虚化开关和虚化程度设置
-
12-17
- 系统设置增加调整横向菜单和5列布局选项,同时允许隐藏卡片描述,链接,分类等
- 系统设置增加自定义壁纸,通知提供bing在线壁纸选择(推荐使用Spotlight (Windows 聚焦),这个壁纸质量不错)
- 🛡️ 后台会话安全升级:登录
/admin时将颁发 12 小时有效的 HttpOnly 会话 Cookie,凭据不再暴露在 URL 中,并新增一键退出登录。 - 🧹 输入与展示双重校验:新增 URL 规范化、HTML 转义与排序值归一化逻辑,前后台同时防止脏数据和潜在 XSS。
- 🚪 访客投稿可控:通过
ENABLE_PUBLIC_SUBMISSION环境变量即可关闭前台投稿入口,相关接口自动返回 403,方便运营期按需开关。 - ⚙️ 增加AI一键自动生成描述:提供Workers AI,Google Gemini和OpenAI接口。
- 📝 增加logo自动生成:默认使用 https://favicon.im 接口,可在环境变量中自定义
- 📦 导入导出数据:提供书签数据的导入与导出,支持chorme导出的html格式一键导入
准备工作: 你需要一个 Cloudflare 账号。
Fork 项目: 点击上方"Fork on GitHub"按钮,,并点上 Star !!!
点击上方"DEPLOY CLOUDFLARE PAGES"按钮,跳转到Cloudflare,然后选连接到Github,授权后选择刚才fork的项目
点击开始设置后,需要填写 构建输出目录 为:public,其他保持默认即可。 
- 在 Cloudflare 控制台,进入
存储和数据库->D1 SQL数据库。 - 点击
创建数据库,数据库名称输入book,然后创建。
-
在 Cloudflare 控制台,进入 存储和数据库
->Worker KV`。 -
点击
创建命名空间,名称输入NAV_AUTH。 -
创建后,为此 KV 添加两个条目,用于设置后台登录的 用户名 和 密码。
- admin_username: 你的管理员用户名(例如
admin) - admin_password: 你的管理员密码
- admin_username: 你的管理员用户名(例如
- 进入你刚刚创建的 Pages项目 的
设置->绑定。 - 点击
添加绑定,选择D1 数据库:- 变量名称:
NAV_DB - D1 数据库: 选择你创建的
book
- 变量名称:
- 点击
添加绑定,选择KV 命名空间::- 变量名称:
NAV_AUTH - KV 命名空间: 选择你创建的
NAV_AUTH
- 变量名称:
| 变量名 | 默认值 | 必填 | 备注 |
|---|---|---|---|
| ENABLE_PUBLIC_SUBMISSION | false |
❌ | 允许访客添加书签 |
| SITE_NAME | 灰色轨迹 |
❌ | 网站名称以及首页显示名称 |
| SITE_DESCRIPTION | 一个简单易用的书签导航系统 |
❌ | 首页副标题 |
| FOOTER_TEXT | 曾梦想仗剑走天涯 |
❌ | 首页页脚 |
| ICON_API | https://favicon.im/ |
❌ | 图标API |
| AI_REQUEST_DELAY | 1500 | ❌ | AI一键补全描述时的调用间隔 |
| DISPLAY_CATEGORY | 无 | ❌ | 首页默认显示分类,如设置 常用推荐 ,访问首页就默认显示常用推荐的书签 |
注意: 我使用免费的Gemini的api key,模型使用gemini-2.5-flash-lite,限制是15次/1分钟,自己看实际情况进行设置
后台管理页面地址为: https://自定义域名/admin
后台登录凭据依然存放在 NAV_AUTH KV 中的 admin_username 与 admin_password 两个键内。登录 /admin 时需要在页面表单中输入账号与密码,系统会返回一个 12 小时有效的 HttpOnly 会话 Cookie,无需、也不再支持在 URL 查询参数中传递凭据。点击后台右上角的“退出登录”按钮即可立即销毁会话。
- 计算: Cloudflare Workers
- 数据库: Cloudflare D1
- 存储: Cloudflare KV
- 前端框架: TailwindCSS
欢迎通过 Issue 或 Pull Request 为本项目贡献代码、提出问题或建议!
- Fork 本仓库
- 创建你的功能分支 (
git checkout -b feature/amazing-feature) - 提交你的更改 (
git commit -m 'Add some amazing feature') - 推送到你的分支 (
git push origin feature/amazing-feature) - 创建一个 Pull Request













如何确定甲骨文号是否挂了?我的甲骨文账号是否被回收了呢?登录页面的各种错误情况看看是啥意思!甲骨文账号存活情况[…]