首先,这个不是写个新手看的,内容比较粗略,把几个关键点自己列一下,以做记录

首先,我对andriod不懂,对java本身也不是非常熟,也从来没写过andriod或java的程序,但本着曾经对编程的理解,想动动手。

一、准备工作,装环境,java jdk, AS(andriod studio),apk反编译工具 jadx

这个步骤有几点提醒一下,一是网上关于AS的版本较旧,安装后要配置很多环境,我用的3.2,安装即可用

apk反编译工具,网上推荐的步骤也较为繁琐,但把apk的打包过程讲了一下,也可以学一下,中间我用了apktool,但最后发现只要jadx即可

二、学习了一下AS,但由于重点在看WX,并没有去动手做什么,但按规矩还是写了一个helloword,这里唯一注意一下如何创建虚拟手机模拟器调试

AS本身直接带有,创建一个就行了。但为了速度,还是选择了夜神模拟器,这个还是挺好用的,如何连接调试论坛上都有

三、在模拟器上如何安装Xposed,网上资料很多,因为用的夜神,已经root过了,于是也在它论坛上下了个,直接装一下即可,

四、写了第一个hook,感觉挺好用的,开始按网上的资料开始折腾,以下为折腾的记录

a、网上说要Android Device Monitor  这玩意AS上没有,但在SDK目录 里有,找一下就可以了,这个东西,我感觉能有一点用处,能监控到执行了哪些方法,不过貌似跟AS不能同时连上模拟器,另外在用这个之前,还得装个插件BuildProp Enhancer,这样才能调试到WX的内容

b、jadx如果想用好,请找个cpu和内存都非常棒的机器,我被卡了一晚上,都没有反编译完,用了一台32G内存的机器,大概15分钟完事

c、模拟器上带的是WX6.7.3,网上资料都是比较老的WX版本,没法跑起来,只能靠静态的去看

d、网上我只看了收消息和回复消息的部分,其它的感觉不想去弄,所以没怎么看,对于收消息有些人用的拦截insertWithOnConflict 来通知收到消息,也可以,但我还是折腾的

com.tencent.mm.booter.notification.b,这个比较即时一些

e、回复消息部分,网上都只做了简单回复,个人和群都可以,但没有处理@的相关代码,在检测是否有人@我时,可以在监控的类上,检测第一个参数,即
com.tencent.mm.booter.notification.b上的czp这个值,
if (czp.contains("notify@all") || czp.contains("<![CDATA[wxid_3e3gejxxxxk22]]>"))
另外,在有人@我时,内容里也包含了@我了WX的ID,还得要拆分消息的内容,这个挺坑的! 消息的内容大概是这样wxid_3e3gejxxxxk22:@隐客 你好啊
这样就知道是谁@我了
x=field_content.indexOf(":");
String id=field_content.substring(0,x);
String co=field_content.substring(x+1);
 
同时回复的时候,发送时的最后一个参数注意,也组成这样的格式即可,
HashMap hm= new HashMap<String, String>();
hm.put("atuserlist","<![CDATA["+id+"]]>"); f、最难的一处是如何获取好友列表,网上有一处资料,是从加载好友列表到ListView着手的,虽然可以实现,但有个不足,就是要人工点一下WX上的通讯录才会执行
setAdapter这里的代码,另外一个方法,就是自己去读WX的数据库,想想不太想弄,于是监控了一下发现在WX启动的时候,本身有读联系人的动作,于是拦截了一下读数据库的动作
rawQueryWithFactory,就OK了,是从FROM rcontact这个表里读的
g、个人信息就不想读了,比较简单,在SharedPreferences里 至次,三个问题解决了,就写这么多吧!

学习Xposed --记WX功能分析的过程的更多相关文章

  1. (转)Maven学习总结(二)——Maven项目构建过程练习

    孤傲苍狼 只为成功找方法,不为失败找借口! Maven学习总结(二)——Maven项目构建过程练习 上一篇只是简单介绍了一下maven入门的一些相关知识,这一篇主要是体验一下Maven高度自动化构建项 ...

  2. ARM Linux驱动篇 学习温度传感器ds18b20的驱动编写过程

    ARM Linux驱动篇 学习温度传感器ds18b20的驱动编写过程 原文地址:http://www.cnblogs.com/NickQ/p/9026545.html 一.开发板与ds18b20的入门 ...

  3. 记录学习antd design pro dva的过程,主要记错, 多图预警,如有理解偏差,忘指出,多谢!

    首要问题: 如何增加菜单项 答案: 在router.config中添加路由,在locales语言国际化增加选项 问题1: 答案1: 问题2: 这个要修改state,正确写法 存在的疑惑:为什么不能直接 ...

  4. 一个Python爬虫工程师学习养成记

    大数据的时代,网络爬虫已经成为了获取数据的一个重要手段. 但要学习好爬虫并没有那么简单.首先知识点和方向实在是太多了,它关系到了计算机网络.编程基础.前端开发.后端开发.App 开发与逆向.网络安全. ...

  5. Deep Learning学习随记(二)Vectorized、PCA和Whitening

    接着上次的记,前面看了稀疏自编码.按照讲义,接下来是Vectorized, 翻译成向量化?暂且这么认为吧. Vectorized: 这节是老师教我们编程技巧了,这个向量化的意思说白了就是利用已经被优化 ...

  6. 转:增强学习(二)----- 马尔可夫决策过程MDP

    1. 马尔可夫模型的几类子模型 大家应该还记得马尔科夫链(Markov Chain),了解机器学习的也都知道隐马尔可夫模型(Hidden Markov Model,HMM).它们具有的一个共同性质就是 ...

  7. Spring Boot学习随记

    由于早年在管理领域耕耘了一段时间,完美错过了Spring的活跃期, 多少对这个经典的技术带有一种遗憾的心态在里面的, 从下面的我的生涯手绘图中大概可以看出来我的经历. 最近由于新介入到了工业数字化领域 ...

  8. Maven学习总结(二)——Maven项目构建过程练习

    上一篇只是简单介绍了一下maven入门的一些相关知识,这一篇主要是体验一下Maven高度自动化构建项目的过程 一.创建Maven项目 1.1.建立Hello项目 1.首先建立Hello项目,同时建立M ...

  9. Maven学习总结(二)——Maven项目构建过程练习_转载

    上一篇只是简单介绍了一下maven入门的一些相关知识,这一篇主要是体验一下Maven高度自动化构建项目的过程 一.创建Maven项目 1.1.建立Hello项目 1.首先建立Hello项目,同时建立M ...

随机推荐

  1. Rabbit 集群部署

    1.RabbitMQ是用erlang语言编写的,所以我们先安装erlang语言环境 配置erlang语言环境 # vim /etc/yum.repos.d/rabbitmq-erlang.repo [ ...

  2. better-scroll

    better-scroll会将默认事件阻止掉,如果自己写的部分需要有点击事件,需要在参数里加上click:true. 同时,在PC上或某些手机端,由于未成功将touchend事件move掉,点击事件会 ...

  3. 从.net parallel角度解读spark

    对于我这样一个一直工作在.net平台上的developer来讲,Hadoop,Spark,HBase等这些大数据名词比较陌生,对于分布式计算,.net上也有类似的Parallel(我说的不是HDIns ...

  4. BUAAOO P1-P3 Expression Dirivation

    目录 1.问题描述 1.1.概念定义 7.程序度量 8.知识点笔记 1.运行 2.1.方法 2.2.检测相等性 2.3.空串与null串 2.4.使用StringBuilder构建字符串 2.5.使用 ...

  5. Django REST framewor

      4.1 RESTfull 4.1.1.前后端不分离 前端看到什么效果,由后端决定,前端页面看到的效果是有后端控制的 前后端耦合度很高 比较适合纯网页设计,如果有APP,还需要开发APP后端借口 4 ...

  6. java 基础代码

    /** * Created by y0n on 2017/4/17. * 1.输出控制台传递的默认参数 */public class JavaDay001_1 { public static void ...

  7. C# Ini、Json、Xml 封装类

    1.Ini是什么?(我对它的理解,用于存储用户配置信息的文件,该文件放在用户电脑...) INI文件是一个无固定标准格式的配置文件.它以简单的文字与简单的结构组成,常常使用在Windows操作系统,或 ...

  8. MYSQL HA 部署手册

    1 MySQL启用主主双写复制 1.1 卸载系统默认的数据库mariadb 安装mysql出现安装包不兼容问题,首先卸载掉系统自带mariadb 查看已经安装的mariadb rpm -qa|grep ...

  9. 【leetcode】461. Hamming Distance

    problem 461. Hamming Distance solution1: 根据题意,所求汉明距离指的是两个数字的二进制对应位不同的个数.对应位异或操作为1的累积和. class Solutio ...

  10. 04bootstrap_表单

    03bootstrap_表单 表单的基本实例 1.默认表单:form 表单域 fieldset legend label 提示span class="help-block" 2.基 ...