惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

Google DeepMind News
Google DeepMind News
F
Fortinet All Blogs
阮一峰的网络日志
阮一峰的网络日志
Apple Machine Learning Research
Apple Machine Learning Research
爱范儿
爱范儿
WordPress大学
WordPress大学
让小产品的独立变现更简单 - ezindie.com
让小产品的独立变现更简单 - ezindie.com
J
Java Code Geeks
罗磊的独立博客
S
SegmentFault 最新的问题
V
V2EX
V
Visual Studio Blog
钛媒体:引领未来商业与生活新知
钛媒体:引领未来商业与生活新知
美团技术团队
博客园 - 三生石上(FineUI控件)
Stack Overflow Blog
Stack Overflow Blog
Y
Y Combinator Blog
MyScale Blog
MyScale Blog
D
Docker
Google DeepMind News
Google DeepMind News
Blog — PlanetScale
Blog — PlanetScale
M
Microsoft Research Blog - Microsoft Research
Martin Fowler
Martin Fowler
S
Secure Thoughts
B
Blog
cs.CL updates on arXiv.org
cs.CL updates on arXiv.org
www.infosecurity-magazine.com
www.infosecurity-magazine.com
Recent Announcements
Recent Announcements
MongoDB | Blog
MongoDB | Blog
C
Cisco Blogs
C
CERT Recently Published Vulnerability Notes
T
True Tiger Recordings
GbyAI
GbyAI
P
Proofpoint News Feed
P
Privacy International News Feed
Jina AI
Jina AI
The Cloudflare Blog
I
Intezer
AWS News Blog
AWS News Blog
Hacker News - Newest:
Hacker News - Newest: "LLM"
S
Security Archives - TechRepublic
NISL@THU
NISL@THU
The Register - Security
The Register - Security
Recent Commits to openclaw:main
Recent Commits to openclaw:main
P
Palo Alto Networks Blog
S
Schneier on Security
L
LINUX DO - 热门话题
C
CXSECURITY Database RSS Feed - CXSecurity.com
Security Latest
Security Latest
C
Cybersecurity and Infrastructure Security Agency CISA

博客园_首页

一个程序员眼中的 AI 核心概念,讲透 LLM 、Agent 、MCP 、Skill 、RAG... CTF 中如何用提示词发挥大模型的最大实力:从聊天助手到大手子 PyTorch KernelAgent 源码解读 ---(6)--- Composer 高光谱拼接算法(一)扫推式成像和航带拼接算法 一文看懂fofa常用语法,告别混淆,精准打击! 从零搭建量化投资系统:用 Qlib 一行代码搞定均线分析 企业 AI 落地,第一件事不是买模型,而是建好企业知识库 如何在Oracle Agent Factory中配置国内厂商的LLM? Codex 换模型太麻烦?这个开源桌面工具帮你一键切换 Avalonia中的动画 2026软考|十大管理超全通俗笔记,备考闭眼记! rv1126b内置phy接hub交换机芯片 React 可拖拽列宽 + 点击行选中 ProTable 封装笔记 五大实锤证据:AI不会终结低代码,只会倒逼技术进化 【硬核脑洞】16位实模式最后的疯狂:我们能否在 640KB 常规内存里手搓一个 MD 模拟器? 基于.Net的NetCoreKevin框架中AgentFramework实现AI智能体Skill和工具动态管理和加载 PostgreSQL 高可用集群 patroni 自动故障转移测试 自己使用C++开发的仿OpenClaw、Hermes智能体工具 记一次 .NET 某集群管理软件 内存暴涨分析 StarBlog番外(5) 从1.6到1.10,基于Avalonia AOT 开发的 Publisher 半年进化之路 Anthropic 把 SOC 误报率从 33% 砍到 7%,真正在干活的不是 Claude SM2演示所有 PEM 功能(生成、加解密、签名/验签) 用 Solon AI 从零构建 MCP 工具服务:让 AI Agent 拥有真实世界的能力 完整学习LLM(一):为什么我要系统学习大模型 Agent Harness Runtime 架构深度解析:工具循环、状态外置与长程任务调度 [对比学习LangChain和MAF-03]完全不同的Agent设计哲学 毫不夸张地说,这将是目前最全的AI测试教程!测试必看! AI Coding 为什么选择 TUI ,前端的新机会在哪里? 无需安装cc switch,10行命令帮你配置Claude Code+deepseek Context Engineering 到 Harness Engineering —— 大模型时代软件工程的新范式 OpenClaw.NET 兼容性目录指南(Compatibility Catalog) Nginx 上游健康检查插件 nginx-healthcheck-module 三角形数 AScript异步执行与await关键字 - rockey627 Vector Quantization for Recommendation 笔记 21. “|”不只是按位或,90%的人不知道 这 3 年做教育相关项目,我把一些经验整理成了一个开源 Agent Skills 项目 2026 西安本土 GEO 测评:灵怡云凭差异化站稳第一梯队 PortSwigger SQL注入LAB7 & LAB8 & LAB9 Splay 学习笔记 这款爆款激光粒度仪凭何全球狂销5000台?揭秘百特Bettersize2600“常青树”背后的硬核实力 十分钟学习 TypeScript 【学习笔记】《Python编程 从入门到实践》第1章学习笔记:Python环境搭建与Hello World(完整版) 初试 vibe coding:Tauri + React + Rust 构建的 windows 本地番茄钟 从 Vibecoding 入门,到 Agent 差点入土 IDEA Maven 手动替换第三方Jar包完整教程 填充与积累:积分与面积的可视化 告别 Django Admin!这个 NodeJS 全栈框架让你在 DTO 中直接配置 Table/Form 渲染 重建 AI 认知第 1 篇:基础认知——一张地图看懂 AI Landscape VAPD AgentKit:可组合 Agent 前端通用库实践 SolonCode v2026.5.21 发布,Web 能看项目,IM 能找队友 从 LangGraph 回到 Model-Tool Loop:更聪明的模型,正在让 Agent 架构重新变简单 从人工同步到自动闭环:跨 Java/.NET 代码转换工具的工程化实践 你的显卡能跑多少算子?用 55 个检查项,给 PyTorch GPU 环境做一次冒烟测试 Claude Code 快速开始 2分钟搞定全网巡检:一个脚本+五大必备 Python 库,让你一天干别人一周的活 最近面完 30 个想转 AI 测试的人,我麻了:80% 都踩了这 4 个坑! 4.3、多体交叉存储器、Cache的基本原理、相联存储器、 Cache地址映射与变换方法 简译项目的项目落地 OpenClaw Dreaming 记忆流水线底层架构:状态分层、证据留痕与检索回流 .NET 10 桌面 UI 框架的范式演进:Jalium.UI 与 MewUI 架构深度对比 [对比学习LangChain和MAF-02]基本编程模式的差异(下篇) 我的编程经历,从天桥地摊Basic到西藏阿里的.Net AOT。(续二) House of botcake与IOFILE任意读写 Markdown锚点跳转失败的解决办法 力扣之路01—两数之和 "Sample Is Feature: Beyond Item-Level, Toward Sample-Level Tokens for Unified Large Recommender Models" 论文笔记 拒绝宕机!用 Python 优雅榨干百万级 GIS 点矢量的裁剪极限 PyTorch KernelAgent 源码解读 ---(5)--- Dispatcher LIS续:动态规划 Windows端安装perry.ts 20. AI大模型输出转JSON,原来这么简单! 龙芯2k0300 - 智能车走马观碑组目标检测算法(下) Windows 应用自动上架 Microsoft Store 的自动化实践 很多企业做了 SBOM,为什么依然管不住依赖? 近 3 年浙江事业单位进面分一览,查分前心里有数! 详解 Docker 环境变量技术,以及如何通过环境变量一键部署客服系统 Claude Code 扩展体系 别让AI再从零写一堆优美的屎山了 A 股回测中的复权与 Point-in-Time 偏差:一次数据泄露的工程复盘 一文理清 HarmonyOS 6.0.2 涵盖的十个升级点 深度学习进阶(二十四)Swin 的二维 RPE Codex CLI 完全使用手册:从入门到精通 一次线上故障带你看懂 MySQL InnoDB 缓冲池 Rocky9.3 UEFI 引导崩溃解决办法 盘古石2026计算机pc手搓复现wp(刘洋加黄志远) 告别 Typora 后的新欢:我把所有笔记迁移到了 Obsidian 这个“第二大脑” 2026 高效客户管理系统,提升企业管理效率实现翻倍增长 11.3、网络身份认证的过程、数字签名、秘钥分发中心(KDC)、公钥认证中心(CA)、安全电子邮件 智驾仿真测试团队必看:ADAS HiL测试引入3DGS的ROI测算与结论! 2026年我做了一个大胆的决定:我要收徒弟了! dubbo服务调用源码 [对比学习LangChain和MAF-01]基本编程模式的差异(上篇) 工良吐槽篇:万字长文细说 AI 落地之笑谈 面向开发者的 AI 资源入口:Agent996 的 MCP 广场和 Skill 专区 2、BellMan-Ford算法 学习理论:在线弃权学习 《图解HTTP》第4章 返回结果的HTTP状态码 GDB 调试命令完整指南(ARM Cortex-M 嵌入式版) 用户自定义配置管理最佳实践
AnyDrop 一款自部署的内容共享工具
Kop-Elan · 2026-05-17 · via 博客园_首页

经常会遇到一些场景,需要记录一些文字、连接或者多媒体信息抑或是一些隐私性的信息,虽然可以通过聊天工具,或者一些其他的工具,但个人用下来的感受就是要么不够隐私,要么太麻烦,有的只能发文字,有的只能发文件,所以AnyDrop应运而生。

Github连接:https://github.com/KOPElan/anydrop

私有、自托管的跨设备内容共享应用,基于 .NET 10 + Blazor 构建。

通过浏览器即可在任意设备间安全地保存与获取文字、图片、文件和链接,实时同步,无需依赖任何第三方云服务。


功能特点

  • 跨设备实时同步 — 基于 SignalR(WebSocket),消息推送即时到达所有已登录设备
  • 多类型内容 — 支持文字、图片、视频、任意文件、链接(含 OG 元数据预览)
  • 主题分组 — 将内容按主题(频道)组织,支持置顶、归档、删除
  • 主题搜索 — 全文搜索、按日期查找、按类型(图片/视频/文件/链接)分类浏览
  • 阅后即焚 — 消息可设为"阅后即焚",阅读后自动销毁
  • 单用户私有部署 — 首次访问完成初始化设置,密码保存在本地数据库,不外发
  • 容器化就绪 — 提供 Dockerfile 与 docker-compose.yml,一命令启动

record


技术栈

技术
框架 .NET 10 · Blazor Web App(Interactive Server)
数据库 SQLite(EF Core)
实时通信 ASP.NET Core SignalR
样式 Tailwind CSS v4
认证 JWT Bearer + Cookie
容器 Docker / Docker Compose

快速开始

服务端

方式一: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/: Minimal API 扩展方法与请求 DTO(按资源分文件组织,路由前缀 /api/v1/)。
    • Components/: Blazor 组件与页面(Interactive Server 模式)。Razor 组件应尽量使用 code-behind .razor.cs 分离复杂逻辑。
    • Data/: 包含 AnyDropDbContext.cs 与数据库迁移文件(SQLite)。
    • Hubs/: SignalR Hub(ShareHub)用于实时推送消息到已连接的客户端。
    • Services/: 核心业务实现(接口 + 实现),禁止直接依赖 Razor 组件。
    • wwwroot/: Tailwind 编译后样式、JS 及其它静态资源。
  • AnyDrop.App/: 跨平台移动/桌面客户端(MAUI),用于在手机/桌面上接入 AnyDrop 服务并同步内容。

    • MAUI 项目使用 net10 目标框架,平台代码放在 Platforms/,UI 放在 UI/Components/
  • AnyDrop.Shared/: 跨项目共享 DTO 与类型定义。

  • Tests.Unit/Tests.E2E/: 单元与端到端测试代码。


服务端简介

  • 框架与角色: 服务端为 AnyDrop 项目,基于 .NET 10、Minimal API 与 Kestrel。API 路由以 /api/v1/ 命名空间暴露,认证采用 JWT + Cookie 混合方案。
  • 持久化: 使用 SQLite(文件存储),默认数据目录为 data/,包含数据库文件与上传的文件目录。
  • 实时同步: 通过 SignalR Hub(Hubs/ShareHub.cs)实现消息广播与客户端订阅。Hub 只负责转发与鉴权,业务逻辑放在 Services/ 中处理。
  • 配置: 推荐通过环境变量或 dotnet user-secrets 设置敏感配置(如 Auth__JwtSecret)。容器部署时通过 .env 或容器环境变量注入。

移动端(MAUI)简介

  • 项目: AnyDrop.App 为 MAUI 应用,支持 Android、iOS、Windows 等(按平台包含在 Platforms/)。
  • 目的: 提供原生体验的接入端,可在移动端快速浏览、上传与接收任意类型内容,并通过 SignalR 保持实时连接。
  • 开发: 在本机开发时,可在 IDE(Visual Studio)中启动 AnyDrop.App,或使用 dotnet build / dotnet run 针对特定平台进行调试。移动端通过配置的 API 地址与服务端通信,开发时请确保服务端可访问(ASPNETCORE_URLS 设置为可被设备/模拟器访问的地址)。

Tailwind 开发监听

项目包含两个 Tailwind 输入源:

  • 服务端(Blazor): AnyDrop/wwwroot/app.css → 输出 AnyDrop/wwwroot/tailwind.css
  • 移动端/静态(MAUI/SPA): 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

License

GPL-3.0