easychen / pushdeer
开放源码的无App推送服务,iOS14+扫码即用。亦支持快应用/iOS和Mac客户端、Android客户端、自制设备
AI Architecture Analysis
This repository is indexed by RepoMind. By analyzing easychen/pushdeer in our AI interface, you can instantly generate complete architecture diagrams, visualize control flows, and perform automated security audits across the entire codebase.
Our Agentic Context Augmented Generation (Agentic CAG) engine loads full source files into context on-demand, avoiding the fragmentation of traditional RAG systems. Ask questions about the architecture, dependencies, or specific features to see it in action.
Repository Overview (README excerpt)
Crawler view> ⚠️ 官方架设的Android版本因接口权限停止无法使用,部分早期开发者退出,社区也不活跃,本项目已不在维护。官方 api 服务器继续服务,但客户端和 api 均不再更新新功能。建议改用持续维护的 Server酱³服务 > ⚠️ 自架版服务器端需每年更新推送证书,如果之前架设的服务突然无法收到推送,请尝试拉取部署最新代码,或者手动更新证书 PushDeer是一个可以自行架设的无APP推送服务,同时也为因为某些原因无法使用无APP推送方案的同学提供有APP/自制设备方案。 🐙🐱 GitHub仓库 🔮 中国大陆镜像仓库@Gitee 本项目已经实现的方案/端包括: • 无APP方案: • 轻APP(APP Clip) • 快应用 • 有APP方案: • iOS客户端 • Mac客户端 • Android客户端 • 自制设备方案: • DeerESP(ESP8266/ESP32) 👉点此查看如何将PushDeer消息推送到成本不到40元的自制设备上 --- |登入|设备|Key|消息|设置| |-|-|-|-|-| | | | | | 子项目和核心贡献者 |功能|核心贡献人|预期完成时间|最低版本兼容|本周进度| |-|-|-|-|-| |iOS客户端/Mac客户端/轻APP|Hext123|已完成|iOS14|第一版完成,代码在iOS目录下| |Android客户端|WolfHugo|已完成|5.1|第一版开发完成,release页面可下载。Websocket方案准备中| |快应用|7YHong|已完成|-|代码在quickapp目录下,可自行上架| |物联网版本DeerESP|Easy |已完成|-|代码在iot目录下,专用设备PCB和外壳设计中| |API|Easy 古俊杰|已完成|-|-| |gorush的mi push版本|SinTod|已完成|-|代码在push/gorush-with-mipush目录下| 试用 使用官方在线版本 官方在线版不用自行架设服务器端,只需启动客户端即可 iOS14+ 苹果手机(iOS 14+)用系统摄像头扫描上边的码即可拉起轻应用。亦可在苹果商店搜索「PushDeer」安装。 > 注意:这里不要安装PushDeer自架版 MacOS 11+ PushDeer有Mac客户端,亦支持推送。可在Mac应用商店中搜索「PushDeer」安装。 Android 快应用尚在开发,可下载并安装Android测试版APP(GitHub|Gitee)。 发送消息 • 通过apple账号(或微信账号·仅Android版支持)登录 • 切换到「设备」标签页,点击右上角的加号,注册当前设备 • 切换到「Key」标签页,点击右上角的加号,创建一个Key • 通过访问后边的URL即可推送内容:https://api2.pushdeer.com/message/push?pushkey=key&text=要发送的内容 > 注意注册设备用到了device token,应用一旦重装,device token会变,所以需要重新注册一次。 发送实例 发送文字: 发送图片: 发送Markdown: 在URL中可以用 换行,当参数中有特殊字符时,需要进行urlencode,因此更建议通过函数或者SDK发送。 • Python SDK by Gao Liang • Go SDK by Luoxin • Rust SDK by Chi PHP函数: 将 PushDeer 接入 ServerChan 由于 PushDeer 刚开发,很多软件和平台都尚未整合其接口,你可以将 PushDeer 接入Server酱作为通道使用,效果是: • 使用 调用Server酱接口 • 在 PushDeer 客户端收到通知 接入方式如下: • 登入 sct.ftqq.com ,选择「消息通道」页面,选择「推荐通道」中的「PushDeer」 • 将在PushDeer客户端中生成的Key填入即可 如果你使用的是自架服务器,那么也可以通过「其他通道」中的「自定义」来修改转发格式和文案。具体操作是,在「自定义 WebHook 配置用 json」中填入以下内容: 注意将 换成你自架服务器的地址,将 换成你自己的 PushDeer 账号中的 key,保存即可。可点右侧的测试按钮测试效果。 使用自架服务器端和自架版客户端 自架服务器端 除了使用官方架设的服务器端,你也可以架设自己的服务器端。本仓库支持通过docker部署服务器端。 如果你没有云服务器,可以看看腾讯云30~50元首单的特价服务器 Docker-compose 首先请确保服务器(假设其IP或域名为$AAA)上支持docker和docker-compose。 然后运行以下代码: 如果你的服务器连接GitHub有困难,可以使用Gitee的代码,但需要核对是否为最新版本(有可能没同步) > 如提示docker服务未安装/找不到/未启动,可在 docker-compose 前加 sudo 再试 等待初始化完成后,访问 ,看到扫码提示和图片则说明容器已经启动。 > ⚠️ 自架服务器端需每年2月拉取一次更新推送证书 如果您在部署中遇到问题,可按调试文档定位并发现错误信息。 使用自架版客户端 在苹果商店搜索「PushDeer·自架版」安装并启动。 在启动界面输入 ,点保存。如果通信顺利,即可顺利完成「通过Apple登录」。如输入错误,可点击「重置API endpoint」重新输入。 登入成功后,亦可随时在设置页面重置 API endpoint。 生产环境的配置强化/优化 参见𐂂安装文档 关于轻应用 > 轻应用找不到了怎么办? 在搜索框搜索pushdeer就能找到。 > 轻应用怎么清理掉?占空间么? 系统设置里边有一个轻应用管理,在里边可以清理。30天不用会自动清理掉。注意重新安装后设备id会变动,需要再手动注册一遍。 开发说明 视频版设计文档: 📼 项目视频说明 📼 项目架构和模块说明 目录说明 • api: Laravel实现的API接口,点此查看请求和返回demo • docker: API实现的docker封装,一键启动,方便使用 • doc: 文档目录,包括界面设计源文件(Adobe XD)和资源文件(logo和avatar) • push: 基于 gorush 架设的推送微服务,配置文件开启 async 可以提升发送速度 • ios: 用于放置 iOS 源文件, 目录是我边学边写的原型验证版本(SwiftUI+Moya+Codable),很多地方需要重写,仅供参考 • quickapp: 用于放置快应用源代码 • android: 用于放置安卓客户端源代码 开发环境搭建 下载代码 启动docker环境 运行 ,启动API。默认访问地址为 。可修改 调整端口。 API 说明 在线文档(Swagger) API_BASE=http://127.0.0.1:8800 认证方式:通过登入接口获得 ,通过 和 方式附带 参数即可自动登入。 模拟登入(环境变量APP_DEBUG=true时可用) 通过苹果 idToken 登入 |参数|说明|备注| |-|-|-| |idToken|Sign in with Apple 中得到的 idToken| 通过微信 oauth code 登入 |参数|说明|备注| |-|-|-| |code|客户端微信授权得到的code| 合并用户并将旧用户删除 |参数|说明|备注| |-|-|-| |token|认证token| |type|字符串,必须为 apple 或者 wechat| |tokenorcode|type 为 apple时此字段为 idToken,否则为 微信code | 获得当前用户的基本信息 |参数|说明|备注| |-|-|-| |token|认证token| 注册设备 |参数|说明|备注| |-|-|-| |token|认证token| |name|设备名称| |device_id|device token(推送用)| |is_clip|是否轻应用|0为APP| 设备列表 |参数|说明|备注| |-|-|-| |token|认证token| 重命名设备 |参数|说明|备注| |-|-|-| |token|认证token| |id|设备id| |name|设备新名称| 移除设备 |参数|说明|备注| |-|-|-| |token|认证token| |id|设备id| 生成一个新Key |参数|说明|备注| |-|-|-| |token|认证token| 重命名Key |参数|说明|备注| |-|-|-| |token|认证token| |id|Key ID| |name|Key新名称| 重置一个Key |参数|说明|备注| |-|-|-| |token|认证token| |id|Key ID| 获取当前用户的Key列表 |参数|说明|备注| |-|-|-| |token|认证token| 删除Key |参数|说明|备注| |-|-|-| |token|认证token| |id|Key ID| 推送消息 |参数|说明|备注| |-|-|-| |pushkey|PushKey|多个key用 隔开,在线版最多10个,自架版默认最多100个| |text|推送消息内容| |desp|消息内容第二部分,选填| |type|格式,选填|文本=text,markdown,图片=image,默认为markdown| type 为 image 时,text 中为要发送图片的URL。 获得当前用户的消息列表 |参数|说明|备注| |-|-|-| |token|认证token| |limit|消息条数|默认为10,最大100 删除消息 |参数|说明|备注| |-|-|-| |token|认证token| |id|消息ID| 清除全部消息 |参数|说明|备注| |-|-|-| |token|认证token| Simple token > 为了方便客户端永久保持登入状态,我们提供了一个永不失效的Token,即 Simple token 获取 Simple token 通过 上文中的「获得当前用户的基本信息」接口( ) 得到 通过 Simple token 登入 |参数|说明|备注| |-|-|-| |stoken|Simple token| 登入成功返回认证token。 重置 Simple token |参数|说明|备注| |-|-|-| |token|认证token| 清空 Simple token |参数|说明|备注| |-|-|-| |token|认证token| 更详细的请求和返回值可以参考这里 通用返回格式: 产品设计文档 产品定义 PushDeer的**核心价值**,包括:「易用」、「可控」和「渐进」。 易用 易用性表现在两个方面: • 易安装:采用无APP方案,直接**去掉安装步骤** • 易调用:只需输入URL,**无需阅读文档**,就可以发送消息 可控 • :让有能力和精力的用户可以自行架设,避免因为在线服务下线导致的接口更换风险。 • 非商用免费:不用PushDeer挣钱,就无需支付费用 • 不依赖微信消息接口:不像Server酱那样受腾讯政策影响 渐进 • 通过URL即可发送基本的文本消息;通过更多参数,可以对消息的样式等细节进行调整 • 无APP不能实现的功能不能覆盖的机型,后期可以通过APP来补充 商业模式 PushDeer是一个商业开源项目,采用「开放源码」、「自用免费」、「在线服务收费」的方式进行运作。 具体实现 PushDeer是一个以盈利为目的的商业项目,品牌和源码所有权都由「方糖君」公司持有,但和纯商业项目不同的地方在于: • 它开放源代码,所有人都可以在非商业前提下按GPLv2授权使用 • 它接受社区贡献代码,作为回报,它会从商业收益中拿出部分来赞助项目贡献人 • 如果商业收益够大,它会尝试雇佣项目贡献人以兼职或者全职的方式为项目工作 这里边有一些细节: • 为了避免某些个人或者公司使用源码搭建在线竞品服务收费,我们限制了源码不能商用 • 在刚开始的时候,项目并没有商业收入,而却是开发工作量最大的。所以首先我们会承担产品和界面设计、API设计和开发等工作;并通过众筹的方式筹集了一些资金给其他大模块的贡献人 开放源码形式保证了其他代码贡献人在非商业场景下对源码的可控: • 如果社区和代码贡献人不满意「方糖君」主导的商业化,可以 Fork 一个版本,继续在非商用的前提下自行运营 • 如果「方糖君」之后不再开放源代码,普通用户依然可以按之前的协议使用修改协议前的源码 用户细分 PushDeer主要面向以下三类用户 • 高阶电脑用户 • 开发者 • 公司或自媒体 高阶电脑用户 具有一定电脑操作技能的高阶用户,比如: • NAS 用户 • 站长 • 电脑技术爱好者 他们使用PushDeer的场景包括但不限于: • 推送路由器和 NAS 的状态、公网 IP 等信息 • 推送 Wordpress 最新的评论 • 推送加密货币达到特定价格的通知 • 在多台设备上推送文本 • 自动化工具推送定期汇报 开发者 使用PushDeer的场景包括但不限于: • 推送报错和调试信息 • 推送服务器异常 • 推送定时任务输出 • 在自己的软件发送消息到手机(引导用户填入PushDeer的key) 公司或自媒体 使用PushDeer的场景包括但不限于: • 面向自己的用户推送通知、内容和营销信息(类似公众号,但不受微信限制) 授权 本项目禁止商用(包括但不限于搭建后挂广告或售卖会员、打包后上架商店销售等),在非商用的情况下遵循GPL v2,当两者冲突时,以非商用原则优先。 相关项目 • C# SDK by MrBread • Java SDK by MrBread • Python SDK by Gao Liang • API的Go实现 by iepngs • API的Node实现 by DouDou • 浏览器插件 by DouDou • Rus…