























经常会遇到一些场景,需要记录一些文字、连接或者多媒体信息抑或是一些隐私性的信息,虽然可以通过聊天工具,或者一些其他的工具,但个人用下来的感受就是要么不够隐私,要么太麻烦,有的只能发文字,有的只能发文件,所以AnyDrop应运而生。
Github连接:https://github.com/KOPElan/anydrop
私有、自托管的跨设备内容共享应用,基于 .NET 10 + Blazor 构建。
通过浏览器即可在任意设备间安全地保存与获取文字、图片、文件和链接,实时同步,无需依赖任何第三方云服务。

| 层 | 技术 |
|---|---|
| 框架 | .NET 10 · Blazor Web App(Interactive Server) |
| 数据库 | SQLite(EF Core) |
| 实时通信 | ASP.NET Core SignalR |
| 样式 | Tailwind CSS v4 |
| 认证 | JWT Bearer + Cookie |
| 容器 | Docker / Docker Compose |
1. 克隆仓库
git clone https://github.com/KOPElan/anydrop.git
cd anydrop
2. 创建环境变量文件
cp .env.example .env # 若不存在则手动创建
.env 文件内容示例:
# 必填:JWT 签名密钥(建议 32 位以上随机字符串)
ANYDROP_JWT_SECRET=your-very-long-random-secret-key
# 可选:上传文件大小上限(字节),默认 100 MB
ANYDROP_MAX_FILE_SIZE=104857600
# 可选:登录令牌有效期(小时),默认 24 小时
ANYDROP_TOKEN_EXPIRY_HOURS=24
3. 启动服务
docker compose up -d
如果要更新服务请使用build命令
git pull
docker compose down
docker compose up -d --build
4. 初始化账号
首次启动后,在浏览器访问 http://localhost:8080/setup,设置登录密码。
数据(SQLite 数据库 + 上传文件)持久化到 Docker volume
anydrop-data,容器重启不会丢失。
# 1. 克隆仓库
git clone https://github.com/KOPElan/anydrop.git
cd anydrop
# 2. 安装前端依赖(Tailwind CSS)
npm install
# 3. 配置 JWT 密钥(推荐使用 .NET User Secrets,避免提交密钥到版本库)
cd AnyDrop
dotnet user-secrets set "Auth:JwtSecret" "your-very-long-random-secret-key"
cd ..
# 4. 启动应用
dotnet run --project AnyDrop
应用默认监听 http://localhost:5002。
首次运行请访问 http://localhost:5002/setup 完成初始化。
AnyDrop/: 服务端主项目,包含 Minimal API、SignalR Hub、EF Core 上下文与前端静态资源。
/api/v1/)。.razor.cs 分离复杂逻辑。AnyDropDbContext.cs 与数据库迁移文件(SQLite)。ShareHub)用于实时推送消息到已连接的客户端。AnyDrop.App/: 跨平台移动/桌面客户端(MAUI),用于在手机/桌面上接入 AnyDrop 服务并同步内容。
net10 目标框架,平台代码放在 Platforms/,UI 放在 UI/ 与 Components/。AnyDrop.Shared/: 跨项目共享 DTO 与类型定义。
Tests.Unit/ 与 Tests.E2E/: 单元与端到端测试代码。
AnyDrop 项目,基于 .NET 10、Minimal API 与 Kestrel。API 路由以 /api/v1/ 命名空间暴露,认证采用 JWT + Cookie 混合方案。data/,包含数据库文件与上传的文件目录。Hubs/ShareHub.cs)实现消息广播与客户端订阅。Hub 只负责转发与鉴权,业务逻辑放在 Services/ 中处理。dotnet user-secrets 设置敏感配置(如 Auth__JwtSecret)。容器部署时通过 .env 或容器环境变量注入。AnyDrop.App 为 MAUI 应用,支持 Android、iOS、Windows 等(按平台包含在 Platforms/)。AnyDrop.App,或使用 dotnet build / dotnet run 针对特定平台进行调试。移动端通过配置的 API 地址与服务端通信,开发时请确保服务端可访问(ASPNETCORE_URLS 设置为可被设备/模拟器访问的地址)。项目包含两个 Tailwind 输入源:
AnyDrop/wwwroot/app.css → 输出 AnyDrop/wwwroot/tailwind.css。AnyDrop.App/wwwroot/css/input.css → 输出 AnyDrop.App/wwwroot/css/tailwind.css。分别构建或监听方式如下:
# 服务端:构建 / 监听
npm run css:build:server
npm run css:watch:server
# 移动端:构建 / 监听
npm run css:build:app
npm run css:watch:app
| 变量名 | 说明 | 默认值 |
|---|---|---|
Auth__JwtSecret |
JWT 签名密钥(必填) | — |
Auth__TokenExpiryHours |
登录令牌有效期(小时) | 24 |
Auth__LoginMaxFailures |
登录失败锁定阈值 | 5 |
Auth__LoginCooldownSeconds |
登录冷却时间(秒) | 60 |
Storage__DatabasePath |
SQLite 数据库路径 | data/anydrop.db |
Storage__BasePath |
上传文件存储目录 | data/files |
Storage__MaxFileSizeBytes |
单文件大小上限(字节) | 104857600(100 MB) |
ASPNETCORE_URLS |
Kestrel 监听地址 | http://+:5002(容器内为 http://+:8080) |
持久化数据存放在 Docker volume anydrop-data(挂载到容器的 /data),包含:
/data/anydrop.db — SQLite 数据库(用户、主题、消息元数据)/data/files/ — 上传的文件备份示例:
docker run --rm \
-v anydrop-data:/data:ro \
-v $(pwd)/backup:/backup \
alpine tar czf /backup/anydrop-backup-$(date +%Y%m%d).tar.gz /data
# 单元测试
dotnet test AnyDrop.Tests.Unit
# E2E 测试(需先启动应用)
dotnet test AnyDrop.Tests.E2E
# 添加新迁移
dotnet ef migrations add <MigrationName> --project AnyDrop
# 应用迁移
dotnet ef database update --project AnyDrop
docker build -t anydrop .
docker run -p 8080:8080 -e Auth__JwtSecret=your-secret anydrop
此内容由惯性聚合(RSS阅读器)自动聚合整理,仅供阅读参考。 原文来自 — 版权归原作者所有。