技术心得:微信小助手之wechaty模块(个人笔记,于人无用)

简介: 技术心得:微信小助手之wechaty模块(个人笔记,于人无用)

//请注意,这是一篇自言自语的笔记,不是科普文。


分一下,就是


2 能够接收别人发送来的信息,也即信息可以被服务端取到。


在github上转了一圈,盯上了一个叫wechaty的开源项目,github.com/wechaty/wechaty,经过一番研究,发现满足了登陆,接收要求,发送的要求,也即箭头所示。


接下来怎么放到我的项目中,可以很优雅的使用呢(egg.js)?


----------待研究


在github上 发现了一个相关项目:


可以研究下在egg下怎么用。


运行不起来,需要端口6379,难道是因为用到了redis的缘故?


经过研究这个项目的router.js,发现好像是通过http接口的形式触发的,那现在我想要启动egg.js的项目时就要启动这个进程~


解决办法,在app.js这里写。


async didLoad() {


// 所有的配置已经加载完毕


// 可以用来加载应用自定义的文件,启动自定义的服务


// 例如:创建自定义应用的示例


this.app.queue = new Queue(this.app.config.queue);


await this.app.queue.init();


}


这个生命周期函数~


现在继续了解下,wechaty这个插件怎么用,要了解插件怎么用,肯定是要上npm官网去了解。


发现:


async didLoad() {


// 所有的配置已经加载完毕


// 可以用来加载应用自定义的文件,启动自定义的服务


// 例如:创建自定义应用的示例


Wechaty.instance() // Global Instance


//代码效果参考:http://www.lyjsj.net.cn/wz/art_23490.html

.on('scan', (qrcode, status) => console.log( Scan QR Code to login: ${status}(qrcode)}))

.on('login', user => console.log(User ${user} logined))


.on('message', message => console.log(Message: ${message}))


.start()


}


启动了之后没有进行登陆操作,很奇怪,难道是因为


不是哦 是可以直接用哦,可能是第一次使用,要用node.js下载什么配置文件?所以现在登录了。


现在要不要拆分成两个启动项目?也即同一个项目,但是不同启动,这样子可以互不干扰?


又在github上逛了一圈,发现了一个宝藏


看到里面的功能,恰好就有


很需要这个定时提醒功能,定时功能底层应该是schdule这个库实现的。


他的另一个库我发现就是合在一起写的,分开写的目的是什么呢?合起来的目的又是什么呢?


现在有个疑惑就是,假设拆分成两个项目,能不能公用哪些service层的代码?


终于明白了分开两个项目的目的,因为wechat是前端部分,koa是后端部分~~~


工具函数应该放在middleWare中。看了一下egg.js文档,middleWare是用来拦截http请求,处理消息的。那是否应该放在extend文件夹下?又浏览了一下,发现extend文件夹下只能放固定的几个文件,而且是自动合并到相关的变量(字段?)上去,不用显性require的。


感觉对egg不是很熟悉,算了,看看有没有前人栽树,github上转了一圈,发现还没有前人,尴尬。


发现egg.js里面有定时任务的配置,不需要另外配置schdule库,猜想应该是内置了。


疑问,怎么把这个项目融进去?


现在遇到个困难,class好像每一次调用都会造成this.data数值改变(js基础都忘了,尴尬)


那就只有弄一个 全局变量存起来先。


发现在extend文件夹下好像可以export一个变量,全局都可以调用。


现在已经把所有代码修改成class的形式了,现在有一个问题,就是bot.on('message',func)的时候,func里面this的绑定的问题,只要用上了()=>func()的时候,func里面执行的this就不再指向wechaty了,这个很糟糕,换成function(msg){return //代码效果参考:http://www.lyjsj.net.cn/wx/art_23488.html

func(msg,ctx)}也是不行,也就是说现在要解决this 的指向问题?如何在事件监听定义这里不改变this的指向?

解决办法就是把wechaty实例传过去。(hhhh)


现在怎么把两个库合在一起?一个是用户库 一个是日程库 一个是wechat


现在就是要把wechat用户的唯一id作为凭证?使用pad的方式登录,详情看


拆分成两个egg项目,这样子就不会两个都崩了。


有一个疑问,wechaty是怎么做到准确无误地把信息发给正在聊天的人的?


就是通过什么记录状态?socket?


现在呢,通过alias查找联系人,并且


现在发现了一个问题,就是下面的问题:


只有异步才能解决异步,是时候看一下es6 //代码效果参考:http://www.lyjsj.net.cn/wz/art_23486.html

promise的知识了。

-----------------还是先了解下wechaty这个模块有哪些api?是怎么做到登陆的?

相关文章
|
9月前
|
小程序 JavaScript
微信小程序-WXS模块
微信小程序-WXS模块
73 0
|
2月前
|
小程序 前端开发 JavaScript
微信小程序全栈开发中的PWA技术应用
【4月更文挑战第12天】本文探讨了微信小程序全栈开发中PWA技术的应用,PWA结合Web的开放性和原生应用的性能,提供离线访问、后台运行、桌面图标和原生体验。开发者可利用Service Worker实现离线访问,Worker处理后台运行,Web App Manifest添加桌面图标,CSS和JavaScript提升原生体验。实践中需注意兼容性、性能优化和用户体验。PWA技术能提升小程序的性能和用户体验,助力开发者打造优质小程序。
|
3天前
|
XML 小程序 前端开发
技术心得记录:微信小程序开发的基本流程
技术心得记录:微信小程序开发的基本流程
|
3天前
|
JSON 缓存 小程序
技术笔记:uniapp微信小程序支付
技术笔记:uniapp微信小程序支付
|
3天前
|
小程序 API
技术心得记录:微信小程序之图片频繁变化,几秒之后输出结果(适用于抽奖)
技术心得记录:微信小程序之图片频繁变化,几秒之后输出结果(适用于抽奖)
|
9天前
|
Java Linux API
微信API:探究Android平台下Hook技术的比较与应用场景分析
微信API:探究Android平台下Hook技术的比较与应用场景分析
|
2月前
|
JavaScript Java 测试技术
基于微信平台健身小助手小程序的+ssmt+vue.js附带文章和源代码设计说明文档ppt
基于微信平台健身小助手小程序的+ssmt+vue.js附带文章和源代码设计说明文档ppt
22 2
|
2月前
|
小程序 JavaScript Java
基于微信小程序的平台健身小助手小程序的设计与实现(源码+lw+部署文档+讲解等)
基于微信小程序的平台健身小助手小程序的设计与实现(源码+lw+部署文档+讲解等)
|
24天前
|
存储 运维 算法
社交软件红包技术解密(十三):微信团队首次揭秘微信红包算法,为何你抢到的是0.01元
本文中,我们将介绍几种主流的IM红包分配算法,相信聪明的你一定能从中窥见微信红包技术实现的一些奥秘。
16 0
|
2月前
|
存储 缓存 算法
IM技术干货:假如你来设计微信的群聊,你该怎么设计?
微信背后的这个IM群聊系统到底是如何实现的呢?这个问题一直困扰着,于是我决定深入了解一下,看看微信的群聊系统背后的设计是怎样的。
55 1