同步操作将从 泡沫/wechat-public-account-push 强制同步,此操作会覆盖自 Fork 仓库以来所做的任何修改,且无法恢复!!!
确定后同步将在后台操作,完成时将刷新页面,请耐心等待。
wechat-public-account-push 是一个用于微信公众号/微信测试号给用户执行微信推送的脚本,改编自目前小红书/知乎突然火起来的【给女朋友的七夕浪漫,微信自动推送消息】,用Nodejs实现而成。
目前可被推送模板获取的字段如下:
* 为新增的可配置参数
天气类
参数 | 详细 | 示例 |
---|---|---|
date.DATA | YYYY-MM-DD 星期d | 2022-08-26 星期五 |
* province.DATA | 省份 | 广东 |
city.DATA | 城市 | 惠州 |
weather.DATA | 天气 | 阵雨转多云 |
min_temperature.DATA | 最低气温 | 25℃ |
max_temperature.DATA | 最高气温 | 25℃ |
* wind_direction.DATA | 风向 | 持续东南风 |
* wind_scale.DATA | 风级 | <3级 |
计时类
参数 | 详细 | 示例 |
---|---|---|
love_day.DATA | 在一起N天 | 2674 |
marry_day.DATA | 结婚N天 | 965 |
birthday_message.DATA | 生日消息 | 距离 宝贝 的生日还有122天 |
每日N句
参数 | 详细 | 示例 |
---|---|---|
note_en.DATA | 金山每日一句-英文 | Nothing in this world that's worth having comes easy. |
note_ch.DATA | 金山每日一句-中文 | 这世界上凡是值得拥有的东西,都不易获得。 |
* one_talk.DATA | 每日一言-内容 | 愿你遍布祖国山河,觉得人生也值得 |
* talk_from.DATA | 每日一言-来源 | 晓良 |
推送回执
参数 | 详细 | 示例 |
---|---|---|
* need_post_num.DATA | 共需推送N人 | 4 |
* success_post_num.DATA | 成功推送N人 | 1 |
* fail_post_num.DATA | 推送失败N人 | 3 |
* success_post_ids.DATA | 推送成功的用户 | 老婆0 |
* fail_post_ids.DATA | 推送失败的用户 | 老婆1,老婆2,老婆3 |
目前可参考的推送模板如下:
亲爱的, 早上好
{{date.DATA}}
城市:{{city.DATA}}
天气:{{weather.DATA}}
最低气温: {{min_temperature.DATA}}
最高气温: {{max_temperature.DATA}}
今天是我们恋爱的第{{love_day.DATA}}天
今天是我们结婚的第{{marry_day.DATA}}天
{{birthday_message.DATA}}
{{note_en.DATA}}
{{note_ch.DATA}}
推送提醒
共推送 {{need_post_num.DATA}} 人
成功: {{success_post_num.DATA}} | 失败: {{fail_post_num.DATA}}
成功用户: {{success_post_ids.DATA}}
失败用户: {{fail_post_ids.DATA}}
Github 仓库地址:wangxinleo/wechat-public-account-push
Github 镜像仓库地址(国内备用):wangxinleo/wechat-public-account-push
注意:
运行图示:
wechat-public-account-push 实现自消息推送的原理,是通过调用一系列开放的api实现的, 所以也非常适合初学者学习。
要使用 wechat-public-account-push, 我们只需要做拥有自己的公众号, 得到相关配置信息进行配置即可
浏览器打开并登录 微信公众测试号
登录成功后, 就可以生成微信公众测试号的appID和appsecret这两串数字, 记下备用
扫描测试号二维码关注测试号, 扫描之后, 右边就会出现相应的已关注人员id, 记下备用
新增测试模板, 点击 新增测试模板
, 进行以下设置
这里面的每一个{{***.DATA}}都对应相应的数据,需要就保留,不需要就删掉
更多模板 请查看上方更新内容
模板标题: 自定义,例如: 亲爱的,早上好!
模板内容:
{{date.DATA}}
城市:{{city.DATA}}
天气:{{weather.DATA}}
最低气温: {{min_temperature.DATA}}
最高气温: {{max_temperature.DATA}}
今天是我们恋爱的第{{love_day.DATA}}天
今天是我们结婚的第{{marry_day.DATA}}天
{{birthday_message.DATA}}
{{note_en.DATA}}
{{note_ch.DATA}}
记下模板代码
fork仓库
修改相应配置
按需填入相应配置后保存
启用action脚本
手动启动脚本
查看执行结果
这里的脚本使用的是 github 的 workflow 定时任务, 具体脚本文件放置在:
wechat-public-account-push/.github/workflows/weixin-push-on-time.yml
这里简单说明一下如何更改自动执行时间
目前脚本默认执行时间为 每天的 北京时间上午 8:00
如果想要变更脚本定时任务执行时间,可以更改以下代码段
on:
workflow_dispatch:
schedule:
# 每天国际时间4:00 运行, 即北京时间 12:00 运行
- cron: '0 4 * * *'
Issues(议题)板块可以用来提交Bug和建议;
Discussions(讨论)板块可以用来提问和讨论。
所以如果你有疑问,
如果确认还未解决,可以自己提交 Issue,我会尽快确认并解决。
关于新版本发布后,如何同步最新的内容到自己 Fork 的仓库
目前仅支持 删掉自己的仓库再重新Fork
删掉后重新Fork会导致之前配置过的GitHub Secrets和提交的代码更改全部丢掉,只能重新部署。
使用此方法如果发生代码冲突,还是建议使用重新fork的方式进行更新。避免把自己搞懵。
在自己的项目仓库中选择 "pull requests"
左边选择自己仓库中fork后的项目的master分支, 右边选取源项目的master分支
点击 "Create pull request" 进入页面, 填写信息后提交
点击 "Merge pull request" 合并代码
以后会考虑加入actions 脚本每周自动更新fork仓库,但是目前精力不足,只能采用上述保守方案
建议每个人先看看更新的内容是否是自己需要的再进行更新。
也建议把右上角的 Star 点一下,这样有重要更新时就会有邮件推送了。
如果你有好的想法,欢迎向仓库贡献你的代码,贡献步骤:
搜索查看 Issue,确定是否已有人提过同类问题或者有新的想法
确认没有同类 Issue 后,自己可新建 Issue,描述问题或建议
如果想自己解决,请 Fork 仓库后,在develop 分支进行编码开发,完成后提交 PR 到 develop 分支,并标注解决的 Issue 编号
我会尽快进行代码审核,测试成功后会合并入 main 主分支,提前感谢您的贡献。
文档部分由于我个人精力有限(写文档比写代码累多了),所以有些地方写的很简略,甚至有遗漏和错别字,不能贡献代码的朋友也欢迎来一起维护文档,欢迎 PR 来纠正我,一样都算是对开源做贡献了。
@LordonCN Lordon
感谢所有参与到开发/测试中的朋友们,是大家的帮助让 TA 越来越好! (*´▽`)ノノ
这个仓库只能算是重复实现一下别人的想法, 主要是了解到了这个想法却一直找不到原作者的源码很是苦恼, 结果还遇到了要求加关注的情况
真的非常不喜欢目前国内论坛/某乎/某书/某字母站的博主在分享一些有趣的项目后,甚至是分享了教程之后却不提供源码链接,要求关注公众号或QQ群才进行分享
虽然我无权谴责这些流量变现的做法, 但是我认为作者既然开源自己的作品, 那就是希望其他人能一起体会coding的喜悦, 请部分博主尊重作者意愿, 尊重开源协议
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。