Thanks to visit codestin.com
Credit goes to github.com

Skip to content

imzyb/Sub-Hub

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

24 Commits
 
 
 
 

Repository files navigation

Sub-Hub

  • Sub-Hub 是一个基于 Cloudflare Workers 的代理节点订阅管理系统。它提供了一个直观的 Web 界面,让您可以轻松管理多个订阅和节点
  • 基于Cloudflare Worker 搭建,不需要借助VPS进行部署
  • 支持原始格式,BASE64格式,Surge格式、Clash格式(内置模板,需要使用自己的规则可以按需修改)
  • 支持SS、VMess、VLESS(除Surge)、Trojan、SOCKS5、Snell(仅Surge)、Hysteria2、Tuic 格式节点的托管
  • 本项目不使用任何第三方订阅转换,所以可能有部分协议转换不完整,目前支持的协议经过测试没发现太大问题
  • 基于Cursor纯AI代码 越来越屎山了,有问题可以提,但不一定能解决

2025.07.10更新:

  • 新增禁用节点功能,被禁用的节点将不显示在订阅链接中
  • 此次更新需要添加新字段 enabled 到 nodes 表,或者重新部署数据库
ALTER TABLE nodes ADD COLUMN enabled INTEGER DEFAULT 1;

这个命令会在表中添加 enabled 字段,并设置默认值为 1。但是请注意:这个默认值只适用于将来插入的新记录。现有记录不会自动更新。

更新现有记录的 enabled 值为 1

UPDATE nodes SET enabled = 1 WHERE enabled IS NULL;

这个命令会将当前表中所有 enabled 为空的记录设置为 1。

2025.06.15更新:

  • 修复了批量删除时,复选框未对齐问题

2025.05.30更新:

  • 修复了添加节点过多时,节点列表显示不完整的问题

2025.05.29更新:

  • 修复了Clash-for-Android和Stash配置报错的问题
  • 修复了Clash模板中对 VLESS+reality+uTLS+Vision 协议的支持

2025.05.28更新:

  • 新增支持了Hysteria2协议
  • 新增支持了Tuic协议
  • 新增了支持了Clash(内置模板)
  • 新增了一些BUG

功能特点

  • 🚀 支持多种代理协议

    • SS(Shadowsocks)
    • SS2022(Shadowsocks 2022)
    • VMess
    • Trojan
    • VLESS(除 Surge 外)
    • SOCKS5
    • Snell(仅 Surge)
    • Hysteria2
    • Tuic
  • 💼 订阅管理

    • 创建多个独立订阅
    • 自定义订阅路径
    • 支持批量导入节点
    • 节点拖拽排序
  • 🔄 多种订阅格式

    • 原始格式(适用于大多数客户端)
    • Base64 编码格式(/v2ray 路径)
    • Surge 配置格式(/surge 路径)
    • Clash 配置格式(/clash 路径)(内置Clash模板)
  • 🔒 安全特性

    • 管理面板登录认证
    • 会话管理
    • 安全的 Cookie 设置
  • 🎨 现代化界面

    • 响应式设计
    • 直观的操作界面
    • 支持移动设备

部署教程

1. 创建项目

  1. 创建名为“sub-hub”新的 Workers 项目

  2. 创建名为“sub-hub” 的D1 数据库

  3. 将D1数据库与Cloudflare Workers绑定

    变量名称 = "DB" 数据库名称 = "sub-hub"

2. 初始化数据库,在名为“sub-hub” 的D1 数据库“控制台中执行如下代码”

-- 创建订阅表

CREATE TABLE IF NOT EXISTS subscriptions (
 id INTEGER PRIMARY KEY AUTOINCREMENT,
 name TEXT NOT NULL,
 path TEXT NOT NULL UNIQUE
);

-- 创建节点表

CREATE TABLE IF NOT EXISTS nodes (
 id INTEGER PRIMARY KEY AUTOINCREMENT,
 subscription_id INTEGER NOT NULL,
 name TEXT NOT NULL,
 original_link TEXT NOT NULL,
 node_order INTEGER NOT NULL DEFAULT 0,
 enabled INTEGER DEFAULT 1,
 FOREIGN KEY (subscription_id) REFERENCES subscriptions(id) ON DELETE CASCADE
);

-- 创建会话表

CREATE TABLE IF NOT EXISTS sessions (
 session_id TEXT PRIMARY KEY,
 username TEXT NOT NULL,
 expires_at INTEGER NOT NULL
);

-- 创建索引

CREATE INDEX IF NOT EXISTS idx_subscriptions_path ON subscriptions(path);
CREATE INDEX IF NOT EXISTS idx_nodes_subscription_order ON nodes(subscription_id, node_order);
CREATE INDEX IF NOT EXISTS idx_sessions_expires ON sessions(expires_at);

3. 配置环境变量

在 Cloudflare Dashboard 中设置以下环境变量:

  • ADMIN_PATH: 管理面板路径(默认:admin)
  • ADMIN_USERNAME: 管理员用户名(默认:admin)
  • ADMIN_PASSWORD: 管理员密码(默认:password)

4. 部署代码

  1. 将“worker.js”文件内容复制到Cloudflare Workers保存

5. 访问系统

  1. 访问管理面板:

    https://你的域名/ADMIN_PATH
    
  2. 订阅地址格式:

    • 原始格式:https://你的域名/订阅路径
    • Base64 格式:https://你的域名/订阅路径/v2ray
    • Surge 格式:https://你的域名/订阅路径/surge
    • Clash 格式:https://你的域名/订阅路径/clash

使用说明

创建订阅

  1. 登录管理面板
  2. 点击"添加订阅"按钮
  3. 输入订阅名称和路径(路径只能包含小写字母、数字和连字符)
  4. 点击"创建"按钮

管理节点

  1. 在订阅列表中找到目标订阅
  2. 点击"添加节点"按钮添加新节点
  3. 支持以下格式:
    • 单个节点链接
    • 多个节点链接(每行一个)
    • Base64 编码的节点列表

节点排序

  1. 点击"节点列表"按钮查看节点
  2. 拖拽节点行可以调整顺序
  3. 顺序会自动保存

批量操作

  1. 点击"批量删除"按钮进入批量模式
  2. 勾选要删除的节点
  3. 点击"确认删除"执行删除操作

注意事项

  1. 首次部署后请立即修改默认的管理员密码
  2. 定期备份数据库内容
  3. 妥善保管管理面板地址和登录信息
  4. 建议使用强密码提高安全性

技术栈

  • Cloudflare Workers
  • Cloudflare D1 (SQLite)
  • HTML5 + CSS3
  • JavaScript (ES6+)
  • Bootstrap 5
  • Font Awesome
  • SortableJS

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 100.0%