代码插桩是实现覆盖测试的关键技术之一,而高效的插桩技术对于嵌入式软件的测试 来说又是至关重要的。在对CodeTeST 中插桩技术研究的基础上,以GCC 作为开发平台,应用并实现了新的插装器,采用增加一个词法语法分析器的方法,提高了插桩的效率。经过实验证明新的插装器具有代码膨胀率小,插桩速度块的优 点,在一定程度上做到了高效插桩。
在实现覆盖测试的过程中,往往需要知道某些信息,如
转载
2023-12-14 00:18:08
82阅读
白盒测试白盒测试概述: .白盒测试是指基于一个应用代码的内部逻辑知识,即基于覆盖全部代码、分支、路径、条件,使用程序设计的控制结构导出测试用例,是软件测试的主要方法之一。一般是以单元或者模块为技基础的。 优点是帮助软件测试人员增大代码的覆盖率,提高代码的质量,发现代码中隐藏的问题。主要是检查程序的内部结构,逻辑,程序,循环和路径。白盒测试分为静态测试和动态测试: 白盒测试的原则:保证一个模块中所有
## Android 代码插桩实现流程
为了帮助你理解和实现 Android 代码插桩,我将会提供一个简单的流程图来展示整个过程。在下面的表格中,我将逐步演示每个步骤,并提供相应的代码和注释来帮助你理解。
```mermaid
pie
title Android 代码插桩实现流程
"1.准备工作" : 15%
"2.配置 Plugin" : 15%
"3.编写插
原创
2023-11-27 06:15:17
141阅读
文章目录小说插桩(代码注入法)栈跟踪和方法抛析栈跟踪方法抛析 小说插桩(代码注入法)小tips:当打开一个APK时,入口点比入口界面执行加载的早用AK打开案例软件,
按照箭头指示找到“onCreate”方法,此处是入口界面。203行,表示此方法调用了10个局部变量寄存器。
204行,参数
206行,代码开始执行的地方。右击,插入代码—Log信息输出。点击之后是这样的,随便输入点字,
20
转载
2023-08-28 10:12:55
130阅读
当启动插桩测试时,系统会重启其目标软件包,并且会注入和启动插桩代码以执行测试。一种例外情况是,这里的目标软件包不能是 Android 应用框架本身,即软件包 android,因为这样做会导致出现一种矛盾情况:需要重启 Android 框架,而正是该框架支持系统功能,包括插桩本身。这意味着,插桩测试无法将本身注入到 Android 框架(也称为系统服务器)以执行测试。为了测试 Android 框架,
转载
2023-11-22 21:51:06
152阅读
简介ASM插桩在网上其实已经有很多资料了,我之所以再写这篇文章呢,一是因为好久前学习的ASM,现在已经忘的差不多了,需要再回顾一下,二来是记录一下学习过程,以后如果再有细节记不清楚可以很方便的就能查到,三来再学习的过程中也踩了一些坑,收获了一些心得,这些也需要一个地方记录一下。好了,废话就说到这里,接下来开始正文。插桩技术指在保证原有程序逻辑完整性的基础上,在程序中插入探针,通过探针采集代码中的信
转载
2023-10-04 11:46:17
160阅读
原文由zlulu发表于TesterHome社区,缘起前段时间,我负责测试的系统在生产环境运行出现问题。该系统对于响应时间要求较高,问题发生的时候并发很高,出现大量请求超时,超时请求比例随时间推迟越来越高,最后几乎全部请求都失败。滚动重启了所有进程后,很快又出现超时情况。 后经过排查,发现是新版本实现某个功能时修改了一个数据库查询语句,修改后该查询语句的查询条件未使用到索引字段,而所查询的表生产环境
转载
2024-08-04 19:41:33
63阅读
文章目录插桩方式实现插件化 插桩方式实现插件化项目机构如下:app为宿主application ,pluginstand为中间连接作用,负责定义主app和插件之间组件传递规则。shop用来打包插件apk。主app和shop同时依赖 pluginstand为了模拟实现网络下载插件这里采用文件拷贝的方式将apk存储到内存卡,拷贝到/data/data/目录下。app 中,首先定义 PluginMan
转载
2023-07-01 19:20:48
188阅读
在上篇文章 Android编译期插桩,让程序自己写代码(一) 的前言部分我放了一张图,用来说明编译期插桩的位置和相应的技术。这里,我还打算这张图来开篇。 AspectJ在上图中,我们可以清楚的看到AspectJ的插桩位置是.java与.class之间。这很容易使人联想到编译器。事实上,AspectJ就是一种编译器,它在 Java 编译器的基础上增加了关键字识别和编译方法。因此,AspectJ可以编
转载
2024-06-16 06:56:10
88阅读
插桩是进行二进制代码分析时常用的方法之一。通过插桩,我们能够得知代码在运行时的一些状况,包括堆栈、寄存器等。了解了这些情况,不仅能够分析软件的输入输出是否存在漏洞,也能对程序代码执行的整个流程进行监控。 Dyninst是从1994年就已经开始开发的一个项目,目的是在运行时动态地向程序中插入代码。 动态插桩省却了代码的重写、重新链接编译、重新执行的过程。如果在执行过程中代码出现了难以理解的性
转载
2023-11-27 13:17:18
15阅读
一、为什么要插桩 我们都知道JAVA是面向对象(继承、封装、多态),而插桩的意义在于面向切面(AOP),可想而知单方面的面向对象开发有许多的局限性,而结合面向切面编程可以说补足了我们的这种局限性。举个例子:在onClick中一般都要做防抖动操作,这样是为了避免多次打开页面的问题。一般实现的话是在每个onClick实现第二次点击的时候加个时间判断
转载
2023-10-23 06:43:26
124阅读
目录1.插桩是什么 2.插桩的作用 3.插桩的原理 4.插桩方案对比 5.AspectJ 耗时统计实践 6.ASM 耗时统计实践 7.插桩编译 Gradle Transform 8.ASM的更多用法 9.MethodTraceMan插桩是什么插桩就是在代码编译期间修改已有的代码或者生成新代码插桩的作用插桩可以做什么?减少代码的重复编写无痕埋点对全局所有class插桩,做UI,内存,网络等等方面的性
转载
2024-07-25 16:10:35
104阅读
一、什么是插桩QQ空间曾经发布的《热修复解决方案》中利用 Javaassist库实现向类的构造函数中插入一段代码解决CLASS_ISPREVERIFIED 问题。包括了Instant Run的实现以及参照Instant Run实现的热修复美团Robus等都利用到了插桩技术。插桩就是将一段代码插入或者替换原本的代码。字节码插桩顾名思义就是在我们编写的源码编译成字节码(Class)后,在Android
转载
2023-11-07 00:29:41
132阅读
8种机械键盘轴体对比本人程序员,要买一个写代码的键盘,请问红轴和茶轴怎么选?何为代码插桩 最早是由J.C. Huang 教授提出的,它是在保证被测程序原有逻辑完整性的基础上在程序中插入一些探针(又称为“探测仪”,本质上就是进行信息采集的代码段,可以是赋值语或采集覆盖信息的函数调用,通过探针的执行并抛出程序运行的特征数据,通过对这些数据的分析,可以获得程序的控制流和数据流信息,进而得到逻辑覆盖等动态
转载
2023-07-06 16:00:29
166阅读
前言动态二进制插桩(dynamic binary instrumentation ,DBI)技术是一种通过注入插桩代码,来分析二进制应用程序在运行时的行为的方法。动态二进制插桩技术,可以在不影响程序动态执行结果的前提下,按照用户的分析需求,在程序执行过程中插入特定分析代码,实现对程序动态执行过程的监控与分析。目前,应用广泛的动态二进制分析平台有Pin,DynamoRIO和Frida等。最常用动态二
转载
2023-08-02 12:25:12
45阅读
经验总是不停刨坑刨出来的,最近结合工作需要并熟悉学习android ASM 字节码插桩的环境下,开发了一个方法 hook 的插件,虽然在各方其他开源项目的参考下,还是刨了不少坑,下面就来记录下。gradle 知识点记录–dry-run 查看gradle task执行顺序,验证插件是否被执行时有用。 –stacktrace 查看详细堆栈,报错时可以看到插件代码错误的位置。ASM开发相关注意基本类型中
转载
2023-11-09 17:05:08
149阅读
目录为了更加精确的追踪方法调用,优化性能,可以通过 Debug 类生成插桩日志,在 Profiler 面板中导入后进行分析。一、生成插桩日志1. 工具类封装2. 示例中调用3. 模拟耗时二. 导出日志,分析数据1. 在 Device File Explorer 面板中找到自己的应用目录下的 xxx.trace 文件,右键 Save as 保存到自己指定的目录中,比如桌面2. 然后打开 Profi
转载
2023-10-10 17:23:34
121阅读
背景在做应用启动速度优化时,需先了解启动阶段做了哪些耗时任务,分析 Application 的 attachBaseContext、onCreate 等关键方法,统计它们内部调用到的其他方法耗时。分析要结合 systrace 工具,因为不仅要知道方法的 wall time,还要知道 cpu time,这样才能知道是否属于 cpu 密集型任务,然后针对任务类型进行调整或线程调度。需求很清晰,在要统计
转载
2023-10-15 10:54:44
171阅读
程序插桩技术最早是由J.C. Huang 教授提出的, 它是在保证被测程序原有逻辑完整性的基础上在程序中插入一些探针(又称为“探测仪”),通过探针的执行并抛出程序运行的特征数据,通过对这些数据的分析,可以获得程序的控制流和数据流信息,进而得到逻辑覆盖等动态信息,从而实现测试目的的方法。 由于程序插桩技术是在被测程序中插入探针,然后通过探针的执行来获得程序的控制流和数据流信息,以此来实现测试的目
转载
2023-07-17 22:57:32
197阅读
一、AOP概念Android AOP就是通过预编译方式和运行期动态代理实现程序功能的统一维护的一种技术。利用AOP可以对业务逻辑的各个部分进行隔离,从而使得业务逻辑各部分之间的耦合度降低,提高程序的可重用性,提高开发效率。二、Android代码的编译过程以及插桩位置三、AOP方案对比3.1 AspectJAspectJ 的作为一个老牌的插桩框架优点是 1 成熟稳定 2 使用简单。但是 Aspect
转载
2023-08-29 17:43:45
175阅读