微信带备注群发真好玩!
时间:2022-07-23
本文章向大家介绍微信带备注群发真好玩!,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
为了迎接即将到来的春节, 我研究了下微信机器人相关
1.wechaty
JS操作个人微信的一个库 github:https://github.com/Chatie/wechaty
wechaty
2.环境配置
由于这个库用到了puppeteer, 所以需要下载chromium, 国内有点麻烦, 所以官方给了解决方法 https://github.com/Chatie/wechaty-puppet-puppeteer#note-for-developers-in-china
npm
user
npm config set registry https://registry.npm.taobao.org
npm config set disturl https://npm.taobao.org/dist
npm config set puppeteer_download_host https://npm.taobao.org/mirrors
then you can check your $HOME/.npmrc
yarn
user
yarn config set registry https://registry.npm.taobao.org
yarn config set disturl https://npm.taobao.org/dist
yarn config set puppeteer_download_host https://npm.taobao.org/mirrors
3.安装
$ npm init
$ npm install wechaty --save
4.群发程序
const {
Contact,
log,
Wechaty
} = require('wechaty')
const contactArr = require('./contactArr').contactArr // 自己定义的, 指定群发对象的数组
// 定义
const bot = new Wechaty({
name: 'zzes-wechat-bot'
})
// 注册事件
bot
.on('login', onLogin) // 登录回调
.on('logout', onLogout) // 登出回调
.on('scan', onScan) // 扫描二维码回调
.on('error', onError) // 错误回调
.on('message', onMessage) // 接收信息回调
// 启动
bot
.start()
.catch(async e => {
console.error('bot start fail: ', e)
await bot.stop()
process.exit(-1)
})
// 事件定义
// 扫码
function onScan (qrcode, status) {
require('qrcode-terminal').generate(qrcode, { small: true }) // show qrcode on console
const qrcodeImageUrl = [
'https://api.qrserver.com/v1/create-qr-code/?data=',
encodeURIComponent(qrcode),
].join('')
console.log(qrcodeImageUrl)
}
// 登录
function onLogin (user) {
console.log(`${user.name()} login`)
bot.say('Wechaty login').catch(console.error)
main() // 群发
}
function onLogout (user) {
console.log(`${user.name()} logouted`)
}
function onError (e) {
console.error('bot error:', e)
}
// 接收信息
async function onMessage (msg) {
console.log(msg.toString())
}
/**
* 群发函数
*/
async function main() {
// 此处注意, 由于网页版获取完整的好友列表需要一定时间, 需要加一点延时, 再获取
setTimeout(function(){
contactArr.forEach(async (v) => {
const contact = await bot.Contact.find({alias: v}) // 通过配置的备注寻找好友
await contact.say(`${v}, 怎么样, 加入治电, 投入学习吧!`) // 带备注发消息
})
},6000);
}
可维护的群发列表 contactArr.js
const contactArr = [
'张三', '李四'
]
exports.contactArr = contactArr
5.参考资料
- wechaty文档: https://chatie.io/wechaty/
- Microsoft training Kits
- C#与yaml解析
- WordPress中的jQuery库不起作用的相关问题
- 人工智能时代家长不必做“虎妈”
- WCF 消息帧格式
- C#以post方式调用struts rest-plugin service的问题
- Web前端开发初级阶段需要学习的知识有哪些?
- 作为TensorFlow的底层语言,你会用C+构建深度神经网络吗?
- 企业应用中使用Silverlight 3
- oracle:db-link使用
- 5个炫酷的Python工具,你都用过么?
- 保护ASP.NET 应用免受 CSRF 攻击
- .NET:Entity Framework 笔记
- redis 学习笔记(1)-编译、启动、停止
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- JSP 开发环境搭建与项目运行(二)
- Activity启动时生命周期汇总
- 「程序员」Flutter:从网络获取数据遇到的坑
- 程序员:拿到新电脑如何配置Git环境
- What?数据量巨大还不分库分表?JDBC 入门与项目实战
- 简书:如何去掉图片下面烦人的“图片发自简书App”
- 命令行shell复制并以当前时间重命名文件夹
- 如何获取PHP命令行参数
- 学习PHP弱引用的知识
- 「okhttp」Gradle引用改jar包引用(一波三折)
- 「问答」解决CSV文件用Excel打开乱码问题
- 「问答」解决jar包运行时相对路径问题
- 「Eclipse」生成能用命令行运行的jar包
- 「AndroidStudio」fastjson导包报错:Could not resolve com.alibaba:fastjson:1.1.56.android
- 「Android」通过注解自动生成类文件:APT实战(AbstractProcessor)