在线剪贴板CloudPaste

项目简介

一个基于 Cloudflare Workers 的在线剪贴板和文件分享服务。支持 Markdown、密码保护、文件上传等功能。

功能特点

📝 文本分享

  • 支持普通文本和 Markdown 格式

  • Markdown 实时预览和同步滚动

  • 完整的 Markdown 样式支持

    • 优化的列表嵌套显示

    • 美化的表格样式

    • 代码块实时语法高亮

    • 标准的任务列表样式

    • 优化的引用块样式

    • 支持数学公式渲染 (KaTeX)

  • 编辑器支持双向拉伸调整大小

  • 支持密码保护

  • 自定义过期时间

  • 自定义分享链接后缀

  • 同步滚动预览

📁 文件分享

  • 支持拖拽上传

  • 多文件上传

  • 文件大小限制(25MB,自定义不超R2限制就行)

  • 密码保护

  • 自定义过期时间

  • 实时上传进度显示

👨‍💻 管理功能

  • 管理员登录

  • 查看所有分享链接

  • 可管理文本/文件上传(防止被盗刷额度)

  • 分类过滤(文本/文件)

  • 删除分享(带确认提示)

  • 复制分享链接

  • 查看分享统计

  • 监控存储空间使用情况

    • 已用空间

    • 总容量

    • 使用率百分比

    • 存储空间预警提示

  • 修改分享密码(支持文本和文件分享)

  • 编辑文本分享内容

    • 支持实时 Markdown 预览

    • 可切换 Markdown 开关

    • 与主页编辑器相同的编辑体验

    • 分屏预览模式

🔐 访问控制

  • 密码保护

    • 支持文本和文件分享设置密码

    • 管理员可随时修改或移除密码

    • 密码加密存储

  • 文本内容控制

    • 仅管理员可编辑已分享的文本内容

    • 普通用户只能查看

  • 上传控制

    • 管理员可开启/关闭文本上传功能

    • 管理员可开启/关闭文件上传功能

    • 防止恶意上传占用资源

🛡️ 安全特性

  • 密码加密存储

  • 自动过期清理 (每当有请求访问时,检查当前时间,如果是整点(分钟为0),触发清理操作)

  • 访问权限控制

  • CORS 安全配置

🎨 界面优化

  • 全分辨率自适应布局

    • 超大屏幕优化 (>1400px)

    • 大屏幕适配 (1200px-1399px)

    • 中等屏幕适配 (992px-1199px)

    • 小屏幕适配 (768px-991px)

    • 平板适配 (576px-767px)

    • 手机横屏适配 (481px-575px)

    • 手机竖屏适配 (<480px)

  • 响应式编辑器布局

  • 优化的移动端适配

  • 美化的滚动条样式

  • 平滑的动画过渡效果

  • 优化的代码块显示

  • 完整的中文标点符号对齐

  • 列表项完美对齐

🚀 部署步骤

1. 准备工作

  1. 注册 Cloudflare 账号

  2. 进入 Cloudflare 控制台

2. 创建存储资源

  1. 创建 KV 命名空间

    • 名称:PASTE_STORE

    • 用于存储文本内容

  2. 创建 R2 存储桶

    • 名称:cloudpaste-files

    • 用于存储上传的文件

3. 创建 Worker

  1. 创建新的 Worker

  2. 配置环境变量:

ADMIN_USERNAME=你的管理员用户名ADMIN_PASSWORD=你的管理员密码

3. 绑定存储:

  • KV 绑定:

变量名:PASTE_STORE选择创建的 KV 命名空间
  • R2 绑定:

变量名:FILE_STORE选择创建的 R2 存储桶

4. 部署代码

  1. 复制 worker.js 的完整代码

  2. 粘贴到 Worker 的编辑器中

  3. 保存并部署

🔧 代码结构说明

主要组件

  1. worker.js

    • 主要的 Worker 代码

    • 包含路由处理和 API 实现

  2. 工具函数

    • generateId: 生成随机ID

    • hashPassword: 密码加密

    • verifyPassword: 密码验证

    • calculateExpiryTime: 计算过期时间

    • isExpired: 检查是否过期

  3. 前端组件

    • Vue 3 应用

    • Markdown 渲染

    • 代码高亮

    • 文件上传界面

📡 API 端点

  1. 文本相关

POST /api/paste     # 创建文本分享GET  /api/paste/:id # 获取文本内容

2. 文件相关

POST /api/file      # 上传文件GET  /api/file/:id  # 获取文件信息GET  /api/file/:id?download=true # 下载文件

3. 管理相关

POST   /api/admin/login                    # 管理员登录GET    /api/admin/shares                   # 获取分享列表GET    /api/admin/storage                  # 获取存储空间使用情况DELETE /api/admin/paste/:id                # 删除文本分享DELETE /api/admin/file/:id                 # 删除文件分享PUT    /api/admin/paste/:id/content        # 更新文本内容PUT    /api/admin/paste/:id/password       # 修改文本分享密码PUT    /api/admin/file/:id/password        # 修改文件分享密码

项目链接

https://github.com/ling-drag0n/CloudPaste

扫码加入技术交流群,备注开发语言-城市-昵称

合作请注明

 

关注「GitHubStore」公众号

(文:GitHubStore)

欢迎分享

发表评论