分享

算法助手使用教程

 黄三岁大爱人生 2023-09-07 发布于广西
前言

自从发布算法助手以来,收到了许多的反馈,其中有很多大佬的宝贵建议,也有很多小白的使用求助,因为平时也没有太多的时间,一一回复肯定是不现实的,所以写下此篇教程,希望能够对大家有所帮助。

这里也给没用过算法助手的兄弟们再介绍一下算法助手,文档尾部也会放下载地址!

算法助手是我们开发的一款运行在Android平台上基于Xposed的安卓调试工具,配合Xposed(需要Root),通过一系列Hook,反射操作,进行应用的安全测试,调试分析,代码定位,是一款不错的调试工具。

基础使用教程

步骤一:激活模块

1、由于该程序是个xposed模块,所以自然是需要先激活模块,本教程默认各位看官已有Xposed环境,将不进行xposed的安装讲解。

2、这边以Lsp框架为例子,启动算法助手模块,并在作用域中勾选你要Hook的App(经典Xposed只需要直接激活模块)

3、模块激活成功后,标题信息将显示“算法助手”,若未激活,则显示红字字体“模块未激活”

Tips:(部分机型和框架,可能会出现激活后显示未激活的情况,如果您确认已经激活,可试着直接使用)






步骤二:算法助手里打开开关

1、在算法助手中,在应用列表里,选择需要Hook的app,点进去以后,将总开关打开(不打开的话,所有的配置都不生效)

2、总开关打开以后,打开需要使用的相关功能的开关,例如'弹窗定位'

3、勾选完毕以后,运行被Hook的App

4、回到算法助手,切换到日志列表,一一点进去,可以看到详细的日志信息。

Tips:(安卓11的用户,被Hook的app需要开启存储权限,且没有开启存储重定向,才能正常写出日志)















步骤三:堆栈分析与代码定位

堆栈的介绍

这个步骤,有开发经验的开发人员可以跳过,调用堆栈对于开发人员来说是再熟悉不过的了,毕竟你们敲了一整天的Bug,一跑起来全是这玩意儿对吧(手动滑稽)

在日志详细的尾部,可以看到调用堆栈,这个调用堆栈是干嘛用的?该怎么去理解他?

实际上,调用堆栈的结构是这样子的:类名.方法名(源文件名:行数)

那怎么看呢?从下往上看!!!

类1.方法1(类1.java:100)类2.方法2(类2.java:55)类3.方法3(类3.java:76)

比如这个例子:

1、首先调用了类3的方法3

2、然后调用了类2的方法2

3、最后调用了类1的方法1

那么,我们已知,在类3的方法3里调用了方法2,可是,方法3的代码可能有非常多,我怎么知道它在哪里调用了方法2呢?

那么这时候行数的重要性就显示出来了,通过行数可以看到,在类3的76行,调用了方法2

堆栈实战分析

还是刚刚的例子,弹窗定位的日志信息,一般情况下,我们只需要看最后几行就可以了

LspHooker_.makeText(Unknown Source:18)com.junge.test.MainActivity.onResume(MainActivity.java:24)android.app.Instrumentation.callActivityOnResume(Instrumentation.java:1454)android.app.Activity.performResume(Activity.java:8050)

最后2行,是android系统类,我们用不到,也不需要去看

从前2行看,我们可以看到,在MainActivity的onResume方法里调用了makeText,通过(MainActivity.java:24),可以看出MainActivity类的24行中调用了makeText

接下来我们反编译app,验证一下,我们在smali代码中找到MainActivity类搜索.line 24

使用Jadx查看java代码,也可以看到24行调用了makeText

Tips:目前MT管理器转为java代码是无法自动识别行号的

Tips:有许多app在编译后,会抹去源文件名,以及行数信息,所以堆栈分析只能当成辅助工具,不必过度依赖,学会怎么通过代码逻辑去分析代码才是重点






进阶使用教程:自定义Hook的使用

Hook,其实可以理解为拦截函数,拦截到函数以后,你想修改返回值,或者不让他执行,都可以 。

在算法助手选择app以后,在功能列表拉到最后,有个'添加自定义'按钮,点进去以后,进入到配置界面,然后进行hook配置

package com.junge.test;import android.os.Bundle;import android.widget.Toast;import androidx.appcompat.app.AppCompatActivity;public class MainActivity extends AppCompatActivity { public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); } public String test(String name) { return '你好:' + name; } public void onResume() { super.onResume(); Toast.makeText(this, test('张三'), 1).show(); }}

还是以这个代码为例子,进入该Activity后,会调用test函数,并传入'张三',并弹出提示,而test函数,返回的是'你好+姓名',我想通过hook,去修改它的返回值,改为'hook返回值成功',怎么做?

配置如下:

java格式:

类名:com.junge.test.MainActivity方法名:test参数类型:java.lang.String返回值:hook返回值成功

smali格式:

类名:Lcom/junge/test/MainActivity方法名:test参数类型:Ljava/lang/String;返回值:hook返回值成功

Tips:使用smali格式的时候,参数类型务填写完整,包括分号。









结语

好了,教程到此结束,如果你也跟我一样,对技术有着浓厚的兴趣,我们可以一起交流学习。

如果在软件过程中,遇到什么问题可以进入官方交流群进行探讨

同时欢迎大家提出宝贵的意见!

算法助手1.7版下载地址:https://wwa./io9Qkrmhndc

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多