技术心得:微信小助手之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?是怎么做到登陆的?

相关文章
|
5月前
|
小程序 前端开发 JavaScript
微信小程序全栈开发中的PWA技术应用
【4月更文挑战第12天】本文探讨了微信小程序全栈开发中PWA技术的应用,PWA结合Web的开放性和原生应用的性能,提供离线访问、后台运行、桌面图标和原生体验。开发者可利用Service Worker实现离线访问,Worker处理后台运行,Web App Manifest添加桌面图标,CSS和JavaScript提升原生体验。实践中需注意兼容性、性能优化和用户体验。PWA技术能提升小程序的性能和用户体验,助力开发者打造优质小程序。
177 0
|
3月前
|
小程序
跨端技术问题之为什么在微信小程序中静态转义出didUpdate生命周期可靠程度低
跨端技术问题之为什么在微信小程序中静态转义出didUpdate生命周期可靠程度低
|
9天前
|
存储 监控 容灾
微信技术总监谈架构:微信之道——大道至简(演讲全文)
在技术架构上,微信是如何做到的?日前,在腾讯大讲堂在中山大学校园宣讲活动上,腾讯广研助理总经理、微信技术总监周颢在两小时的演讲中揭开了微信背后的秘密。 周颢把微信的成功归结于腾讯式的“三位一体”策略:即产品精准、项目敏捷、技术支撑。微信的成功是在三个方面的结合比较好,能够超出绝大多数同行或对手,使得微信走到比较前的位置。所谓产品精准,通俗的讲就是在恰当的时机做了恰当的事,推出了重量级功能,在合适的时间以最符合大家需求的方式推出去。他认为在整个微信的成功中,产品精准占了很大一部分权重。
29 1
微信技术总监谈架构:微信之道——大道至简(演讲全文)
|
7天前
|
程序员 数据库 UED
微信也在用的消息时序性技术,你知道多少?
本文由程序员小米撰写,探讨了在个人项目中如何保证消息的时序性。文章详细介绍了消息时序性的概念及其重要性,并提出了三种方案:ID设计(借鉴微信号段与跳跃式生成)、单聊场景下的单点序列化同步,以及群聊场景中的单点序列化处理。此外,还提供了多种优化方法,如消息时序对齐、本地时序记录等,帮助读者更好地解决消息乱序问题。适合所有关心即时通讯和社交应用技术细节的开发者阅读。
19 4
|
3月前
|
开发框架 前端开发 JavaScript
在微信框架模块中,基于Vue&Element前端的事件和内容的管理
在微信框架模块中,基于Vue&Element前端的事件和内容的管理
|
3月前
|
开发框架 移动开发 前端开发
在微信框架模块中,基于Vue&Element前端的后台管理功能介绍
在微信框架模块中,基于Vue&Element前端的后台管理功能介绍
|
2月前
|
小程序 前端开发 JavaScript
微信小程序结合PWA技术,提供离线访问、后台运行、桌面图标及原生体验,增强应用性能与用户交互。
微信小程序结合PWA技术,提供离线访问、后台运行、桌面图标及原生体验,增强应用性能与用户交互。开发者运用Service Worker等实现资源缓存与实时推送,利用Web App Manifest添加快捷方式至桌面,通过CSS3和JavaScript打造流畅动画与手势操作,需注意兼容性与性能优化,为用户创造更佳体验。
59 0
|
3月前
|
开发框架 前端开发 JavaScript
在微信框架模块中,基于Vue&Element前端,通过动态构建投票选项,实现单选、复选的投票操作
在微信框架模块中,基于Vue&Element前端,通过动态构建投票选项,实现单选、复选的投票操作
|
3月前
|
安全 API Windows
支付系统13------支付系统的资料在技术库里的在线支付当中,怎样获取微信平台证书那?怎样获取微信平台证书那?第一步打开我们的微信支付平台的文档中心
支付系统13------支付系统的资料在技术库里的在线支付当中,怎样获取微信平台证书那?怎样获取微信平台证书那?第一步打开我们的微信支付平台的文档中心
|
4月前
|
XML 小程序 前端开发
技术心得记录:微信小程序开发的基本流程
技术心得记录:微信小程序开发的基本流程
36 0

热门文章

最新文章

下一篇
无影云桌面