写在前面
Emmm...五六年前,还在 bioinformatics*中国 当群管的时候,我大体写了一个简单的QQ机器人。那会使用的是已有的 perl 模块。能做的事情也不多,基本就是实现一个QQ聊天界面的数据库操作与字词识别并自动回复。使用已有模块的好处是可以快速达成简单需求。但是这也意味着各个地方会受限,比如开发者不再开发,或者开发者设立相对较高的授权费。
这两日没什么事情,于是我又搜索了一些相关的资料,毕竟对于底层如何实现,我个人还是比较感兴趣。
微信机器人开发的实现方向
基于检索结果,大体我以为是两大方向:
- 逆向协议,或许可以简单地认为,任何一个通讯软件,事实上都是服务器端与用户端的信息交换,搞清楚交换的协议,那么我们就完全可以伪装成一个微信客户端,从而实现微信机器人开发。于是市面上可以看到如 微信ipad协议 等等。
- Hook,很久以前我大概看过这个词。不过可能经过这次检索我才基本了解,这个词可能描述的内容。Hook微信,可以理解为,以windows下的微信为例,微信运行,程序必定是要驻存在内存中,那么就会有对应的内存地址。使用一些内存查看工具,如CE,我们就可以定位到运行中微信对应的不同属性的内存地址,不同内置方法的内存地址。基于这些地址,我们可以获取信息,甚至也可以调用信息。要实现hook,那么在已知微信内存地址的情况下,注入“恶意”DLL,就可以“暴露”运行中微信的方法调用。
逆向协议?我想都不会想。因为确实不容易,市面上似乎只有一批人在售卖 微信ipad协议。而hook,这个是有趣的,但是我并没有太多时间。当然,我仅有的浅薄C/Cpp基础或许还不一定能让我实现注入。不过,运气好在。市面上是存在一些hook微信甚至是hook QQ的软件实现。这些软件的实现基础,本身就包含了这些DLL。本着“拿来主义”,可以借用玩玩。
Java 调用.dll / .so
Emmm... 这是一个我意想不到的收获。早前,我为了加速RNAfold 【注:小RNA数据分析高频使用】的调用,摸索了一段时间的JNI。当然,最后我放弃了。因为我最后发现...实现调用的工作量比较大,需要修改 C/C++ 源码。简单的我搞定了,但是对于RNAfold一个project来说,并不简单。
不小心的检索,【或许是我改变了关键词】,搜索到原来 Java 调用 .dll/.so 有三种不同方法:
- JNI,这是Java原生自带。前述已经提及,实现繁琐,似乎确实一般很少人这么干。
- JNA,在第三方类库的帮助下,无需调整已有源码,可以直接载入并调用 .dll 中的方法。【注:太流弊了....】
- JNaive,Emmm... 这个没搞明白,暂时认为与JNA类似。
于是,我觉得我还是知道了一些新的东西,而这些东西,似乎对我技能的提升存在非常大的帮助,毕竟...原生调用,讲真的,比“命令行调用”的成本,真的低了许多。我甚至有一种感觉,我可以做的应用层开发方位似乎更广,且开发出来的软件运行似乎会更快。
写在最后
两天过去了,暂时还是没连接上实验室的电脑。当然,我其实也确实没有完整的时间片段做事情。或许搞搞一些有的没得,总有一天,还是能用上。