微信通知,每天给女朋友发早安、情话、诗句、天气信息等~
前言
之前逛GitHub的时候发现了一个自动签到的小工具,b站、掘金等都可以,我看了下源码发现也是很简洁,也尝试用了一下,配置也都很简单,主要是他有一个自动打卡、抽奖的信息通知到微信的功能,不错过运气爆棚打卡抽奖时的中奖~😛
虽然以前做过钉钉的消息通知,但是钉钉我也就上班用一下,日常很少使用,要说通讯工具在国内还是要微信,笑~😑,所以,第一接收信息通知的工具最好能是微信,懂得都懂~
后来我根据这个功能的逻辑一想,借用这个消息通知的能力,不就可以自定义任何内容推送到微信了吗,嘿嘿嘿,发现事情变的有趣了起来了~
想起之前看过一篇文章是通过邮箱每天给女朋友发土味情话的操作,邮箱哪有微信效果好呀,可不是😎
话不多说直接开整,自己做个每天给女朋友发早安和土味情话的工具,你也可以每天都是暖男~
思路
接下来我们主要做两件事:
- 第一件事:消息通知到微信能力的工具
- 第二件事:消息内容的获取和数据处理
消息通知能力,我调研了下,其他方案或多或少都有限制和不足,采用以上工具中的方案算是当前比较合适的
消息内容获取,一是通过开放API快速使用,二是通过自己编写爬虫脚本获取,出于技术和时间成本考虑,目前优先考虑方案一,方案二可以作为拓展能力
消息通知工具分析
wechaty
文档:wechaty
能做到微信几乎所有的功能和能力,当你有个小号微信时,你完全可以把它交由 wechaty控制,再通过代码设计各种能力,可玩性完全由你的想法决定
自动回复、加群、定时推送、回复、AI接口能力结合等等很多。。。
硬性条件是需要 wechaty官方提供的 token
来获取权限,目前方式有两种
- 方式一:联系相关人员购买
- 方式二:参与开发者计划,贡献项目并被采纳,免费提供
相关文档:https://github.com/juzibot/We...
如果你有加过一些大佬的微信群,应该接触过由该能力实现的自动拉群、自动回复、自动每日播报的机器人
钉钉、飞书、企业微信
这三个工具定位都是企业级应用,企业级应用的好处就是可定制性很高,官方有开放提供很多API接口和权限,机器人、自定义应用、小程序等,可玩性还是蛮大的。
存在问题:
中国社交APP真实情况,排除企业组织使用,个人而言微信第一优先,不管是消息通知还是其他能力,但矛盾的地方是,个人微信限制很多,几乎不提供这种开发API的能力。当然,如果你可以接受钉钉或飞书或企业微信,则不存在这种问题。
新的思路:
企业微信作为微信自己的产品,有着一些天然优势:微信支持在微信内接受企业微信的消息
围绕这个能力我们也可以实现相应的功能需求,首先,我们先在微信内关注我们创建的企业微信,然后允许微信内接受企业微信内的消息。
个人创建企业微信很简单,只需提供手机号即可
钉钉、飞书则使用机器人通知
小结
有条件优先使用 wechaty实现,没条件可以退而求其次采取 企业微信 + 微信 的方式。
准备
1.注册企业
用电脑打开企业微信官网,注册一个企业。有手机号就可以注册,不用营业执照!不用营业执照!不用营业执照!
2.创建应用
注册成功后,点「管理企业」进入管理界面,选择「应用管理」 → 「自建」 → 「创建应用」
应用名称随意填,可见范围可以选择公司名。
创建完成后进入应用详情页,可以得到应用ID( agentid
),应用Secret( secret
)。
3.获取企业ID
进入「我的企业」页面,拉到最下边,可以得到企业ID。
4.推送消息到微信
进入「我的企业」 → 「微信插件」,拉到下边扫描二维码,关注以后即可收到推送的消息。
注:如果出现接口请求正常,企业微信接受消息正常,个人微信无法收到消息的情况:
1.进入「我的企业」 → 「微信插件」,拉到最下方,勾选 “允许成员在微信插件中接收和回复聊天消息”
2.在企业微信客户端 「我」 → 「设置」 → 「新消息通知」中关闭 “仅在企业微信中接受消息” 限制条件
5.添加环境变量
在 Github 的 Secrets 中在添加三个变量:
- Name 是
WX_APP_ID
,Value 是第二步的AgentId
。 - Name 是
WX_APP_SECRET
,Value 是第二步Secret
。 - Name 是
WX_COMPANY_ID
,Value 是第三步的企业ID
。
WX_COMPANY_ID= 企业ID
WX_APP_ID= 应用ID
WX_APP_SECRET= 应用 Secret
TIAN_API_KEY= 天行数据 key
6.GitHub Action每天自动执行
核心代码如下,详细代码见下面仓库链接
schedule:
# `分 时 天 月 周` 时按照标准时间 北京时间=标准时间+8 18表示北京时间早上2点
# 早上 7:30
- cron: '30 23 * * *'
数据赋能API
这里我们可以自己选择第三方开放API进行定制,或者自己定制
注:免费开源接口需要考虑服务稳定性!
目前接口数据能力主要由天行数据提供,随便注册一个账户会员即可,无门槛
- 会员免费接口数量:15个
- 每日赠送次数:100次
注:如果采取该接口,需要在 5.添加环境变量这一步中,再添加Key的变量,作为天行数据接口使用时的必填参数
功能和内容
这里就看个人的想法和思路了,就各种免费接口基本可以提供很多各式各样的信息了,你也可以自己写服务和爬虫脚本等,可玩性真的是很高
目前已添加的功能有:
- 个人定制化信息
- 天气信息
- 每日一言
- 最美宋词
- 雷人笑话
- 土味情话
- 每日英语
- 睡前故事
<!-- - 随机相册照片推送
- 每周电影资讯 -->
内容完全由你发挥,之后还可以开发自己的个人资讯和消息推送等,就很棒~
部分代码
接口代码
class API {
key: string
constructor(key?: string) {
this.key = key || '' // 为了方便,key在 http中统一添加
}
// 最美宋词
async getSongLyrics() {
const res = await getTian<IVerseProps[]>({ url: LoveMsgURL.songLyrics })
return res?.[0]
}
// 每日一句美好英语
async getDayEnglish() {
const res = await getTian<ResEnglishProps[]>({ url: LoveMsgURL.dayEnglish })
return res?.[0]
}
// 获取农历信息
async getLunarDate(date: string) {
const res = await getTian<ResLunarDateProps[]>({ url: LoveMsgURL.lunarDate, params: { date } })
return res?.[0]
}
// 土味情话
async getSaylove() {
const res = await getTian<SayloveProps[]>({ url: LoveMsgURL.saylove })
return res?.[0]
}
}
export default new API()
早安、午安、晚安
const { MESSAGE_TYPE } = process.env
export default function main() {
if (MESSAGE_TYPE === 'goodAfternoon') {
// 午安
goodAfternoon()
} else if (MESSAGE_TYPE === 'goodEvening') {
// 晚安
goodEvening()
} else {
// 早安
goodMorning()
}
}
请求数据-goodMorning
/**
* @name goodMorning
* @description 说早安
*/
// 并行请求,优响相应
const dataSource = await Promise.allSettled([
API.getSaylove(), // 土味情话
API.getCaihongpi(), // 彩虹屁
API.getOneWord(), // 一言
API.getSongLyrics(), // 最美宋词
API.getOneMagazines(), // one杂志
API.getNetEaseCloud(), // 网易云热评
API.getDayEnglish(), // 每日英语
])
// 过滤掉异常数据
const [sayLove, caiHongpi, oneWord, songLyrics, oneMagazines, netEaseCloud, dayEnglish] =
dataSource.map((n) => (n.status === 'fulfilled' ? n.value : null))
效果
天气信息
其他信息
今日笑话:
名作家到我市举行签名活动。一大早我带着儿子来书店买书,请作家签名时,儿子在一旁不解地问:“我们买的书怎么写他的名字?”
一言:
冬天之所以那么冷是为了告诉大家身边人的温暖有多重要。
今日英语(Dec 18 2021):
While there is life, there is hope.
生命不息,希望不止。
代码
本项目使用 TypeScript
开发,包管理工具为 pnpm
完整代码见仓库,已开源 https://github.com/JS-banana/...
欢迎一起交流
开发
复制 .env.example文件重命名为 .env,并按照要求填写对应值,可以直接测试
如果要通过 GitHub Action使用,需要在 Secrets 中一一添加变量
结语
怎么说呢,每天逛GitHub你都能发现很多有趣的项目和小工具,每天抽点时间看看不仅可以了解前言技术,还能第一时间接触到很多优秀的内容和项目,并参考学习,以此积累技术也会不断精进。
这个项目总的来说还是很简单的,比日常工作写业务要简单多了,但是它却是很有趣的,这未尝不是爱上编码的一种方式呢。无聊繁杂的业务工作很容易让人产生厌烦和颓态,但技术本身应是带给我们乐趣和快乐的,不是吗
今天你是暖男了吗😉
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。