⚠️ 官方架设的Android版本 因接口权限停止无法使用 ,建议改用 Server酱³
⚠️ 自架版服务器端需每年更新推送证书,如果之前架设的服务突然无法收到推送,请尝试拉取部署最新代码,或者 手动更新证书PushDeer是一个可以自行架设的无APP推送服务,同时也为因为某些原因无法使用无APP推送方案的同学提供有APP/自制设备方案。
本项目已经实现的方案/端包括:
无APP方案: 轻APP(APP Clip) 有APP方案: iOS客户端 Mac客户端 Android客户端 自制设备方案: DeerESP(ESP8266/ESP32) PushDeer有Mac客户端,亦支持推送。可在Mac应用商店中搜索「PushDeer」安装。
快应用尚在开发,可下载并安装Android测试版APP( GitHub | Gitee )。
通过apple账号(或微信账号·仅Android版支持)登录 切换到「设备」标签页,点击右上角的加号,注册当前设备 切换到「Key」标签页,点击右上角的加号,创建一个Key 通过访问后边的URL即可推送内容: https://api2.pushdeer.com/message/push?pushkey=key&text=要发送的内容 注意注册设备用到了device token,应用一旦重装,device token会变,所以需要重新注册一次。
发送文字:
https://api2.pushdeer.com/message/push?pushkey=key&text=要发送的内容
发送图片:
https://api2.pushdeer.com/message/push?pushkey=<key>&text=<图片URL>&type=image
发送Markdown:
https://api2.pushdeer.com/message/push?pushkey=<key>&text=标题&desp=<markdown>&type=markdown
在URL中可以用
%0A
换行,当参数中有特殊字符时,需要进行urlencode,因此更建议通过函数或者SDK发送。Python SDK by Gao Liang Go SDK by Luoxin Rust SDK by Chi PHP函数:
function pushdeer_send($text, $desp = '', $type='text', $key = '[PUSHKEY]') $postdata = http_build_query(array( 'text' => $text, 'desp' => $desp, 'type' => $type , 'pushkey' => $key )); $opts = array('http' => array( 'method' => 'POST', 'header' => 'Content-type: application/x-www-form-urlencoded', 'content' => $postdata)); $context = stream_context_create($opts); return $result = file_get_contents('https://api2.pushdeer.com/message/push', false, $context);由于 PushDeer 刚开发,很多软件和平台都尚未整合其接口,你可以将 PushDeer 接入Server酱作为通道使用,效果是:
使用 sendkey
调用Server酱接口在 PushDeer 客户端收到通知 接入方式如下:
登入 sct.ftqq.com ,选择「消息通道」页面,选择「推荐通道」中的「PushDeer」 将在PushDeer客户端中生成的Key填入即可 如果你使用的是自架服务器,那么也可以通过「其他通道」中的「自定义」来修改转发格式和文案。具体操作是,在「自定义 WebHook 配置用 json」中填入以下内容:
"url":"<endpoint>/message/push?pushkey=<pushkey>", "values":[ {"type":"markdown"}, {"text":"{{title}} "}, {"desp":"{{desp}} [查看详情]({{url}})"}注意将
<endpoint>
换成你自架服务器的地址,将{{pushkey}}
换成你自己的 PushDeer 账号中的 key,保存即可。可点右侧的测试按钮测试效果。除了使用官方架设的服务器端,你也可以架设自己的服务器端。本仓库支持通过docker部署服务器端。
如果你没有云服务器,可以看看腾讯云30~50元首单的特价服务器
首先请确保服务器(假设其IP或域名为$AAA)上支持docker和docker-compose。
然后运行以下代码:
git clone https://github.com/easychen/pushdeer.git cd pushdeer docker-compose -f docker-compose.self-hosted.yml up --build -d
如果你的服务器连接GitHub有困难,可以使用Gitee的代码,但需要核对是否为最新版本(有可能没同步)
git clone https://gitee.com/easychen/pushdeer.git cd pushdeer docker-compose -f docker-compose.self-hosted.yml up --build -d
如提示docker服务未安装/找不到/未启动,可在 docker-compose 前加 sudo 再试
等待初始化完成后,访问
$AAA(需替换为服务器端IP或域名):8800
,看到扫码提示和图片则说明容器已经启动。
⚠️ 自架服务器端需每年2月拉取一次更新推送证书如果您在部署中遇到问题,可按调试文档定位并发现错误信息。
在苹果商店搜索「PushDeer·自架版」安装并启动。
在启动界面输入
$AAA(需替换为服务器端IP或域名):8800
,点保存。如果通信顺利,即可顺利完成「通过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 源文件, ios/Prototype_version
目录是我边学边写的原型验证版本(SwiftUI+Moya+Codable),很多地方需要重写,仅供参考quickapp: 用于放置快应用源代码 android: 用于放置安卓客户端源代码
git clone https://github.com/easychen/pushdeer.git
运行
docker-compose up -d
,启动API。默认访问地址为http://127.0.0.1:8800
。可修改docker-compose.yml
调整端口。API_BASE=http://127.0.0.1:8800
认证方式:通过登入接口获得
token
,通过post
和get
方式附带token
参数即可自动登入。
GET /login/fake
POST /login/idtoken
Self-hosted
:让有能力和精力的用户可以自行架设,避免因为在线服务下线导致的接口更换风险。非商用免费:不用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 Rust SDK by Chi