加固与脱壳03 - 加固技术讨论

在 02 中,贴了一张图,里面涵盖了加固的绝大部分知识。现在我们稍微展开说一下其中几个,也是后续会深入学习的,其中一些还需要单独成系列才行。

代码混淆

分为 Java 层与 Native 层混淆。

Java 层的混淆主要分为两种:

  • 字符串

  • Proguard 混淆类名,方法名,字段名

字符串的混淆

比如:

  • https://github.com/MegatronKing/StringFog?tab=readme-ov-file

原理也很简单:

  • 加密前:

String a = "This is a string!";
  • 加密后:

String a = StringFog.decrypt(new byte[]{-113, 71...}, new byte[]{-23, 53});

就是将常量字符串替换为一个运行时解密的函数调用。

字符串混淆都是看着恶心,实际意义不大,如果你会 frida 或者 xposed,直接 hook 这个 decrypt 函数就可以得到所有解密后的字符串了。

Native 层的混淆与 Java 层类似。

它也有字符串混淆,一般也是写一个方法进行运行时解密,同样 hook 解密方法即可。或者是在 init 与 init_array 阶段解密。

  • https://bbs.kanxue.com/thread-252257.htm

有个开源项目提供了字符串混淆,名字很有意思——孤挺花:

  • https://github.com/GoSSIP-SJTU/Armariris

还有控制流混淆OLLVM,需要单独开一个系列。

OLLVM

简单理解一下,就是程序运行逻辑都是由控制流决定的。一个正常的程序分支不会太多,逆向起来也很简单。OLLVM 的作用就是生成很多的虚假分支,将真实的逻辑切片,混到这些虚假分支里面,反编译后的逻辑,看起来非常头大。如下图:

这是一个混淆程度不算深的代码,就算这样,看起来也很头疼了,所以需要将汇编指令进行处理,我们在系列里面进行讨论。

反反编译器

花指令:就是在代码中加入一些无意义的指令,这样 ida 分析的时候会出错。不过这种绕过也比较简单,就是 dump 内存中的 so,或者针对性的处理一下就行。

jdax 对抗:修改 dex 内容,比如我之前做过的一种,将 method 的 flag 改成 native 标识,这样 jadx 会将它当成一个真正的 native 方法,就不会反编译方法内容。

加固

Dex 加固:

  • 函数性抽取壳:就是将 Dex 里面的 CodeItem 指令提取出来,储存到别的地方,加密,然后运行的时候再设置回方法里面。

  • Dex2C:将 dex 反编译成 smali 后,分析 smali 语法树,生成的对应的 C 代码,利用 JNI 来完成逻辑调用,最后的到 so 文件。

  • DEXVMP:对原来的smail代码做替换,然后用自己的解释器“执行”替换后的代码,实现的功能和原smail代码一样!

    • https://geneblue.github.io/2019/09/13/android/sec--android-dex-vmp/

  • ARMVMP:将 so 指令换成自己定义的指令,使用自己的虚拟机来执行自定义指令,实现同样的逻辑。

    • https://cloud.tencent.com/developer/article/1847027

VMP 也是得单独开一个系列的。

二手的程序员

主要研究Android逆向相关的知识。文章均会同步到博客,且持续修订:lyldalek.top

公众号

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.xdnf.cn/news/1550224.html

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

基于微信小程序的交友平台

作者:计算机学姐 开发技术:SpringBoot、SSM、Vue、MySQL、JSP、ElementUI、Python、小程序等,“文末源码”。 专栏推荐:前后端分离项目源码、SpringBoot项目源码、Vue项目源码、SSM项目源码、微信小程序源码 精品专栏:…

[ComfyUI]Flux:超美3D微观山水禅意,经典中文元素AI重现,佛陀楼阁山水画卷

在数字艺术和创意领域,[ComfyUI]Flux以其独特的虚实结合技术,已经成为艺术家和设计师们手中的利器。今天,我们激动地宣布,[ComfyUI]Flux带来了一款超美的3D微观山水禅意作品,经典中文元素通过AI技术重现,包…

结婚证识别-离婚证识别接口-结婚证识别API应用场景

在信息化与智能化高速发展的今天,证件的自动识别技术逐渐成为了各行各业数字化转型的关键工具,而结婚证识别接口、离婚证识别接口正在悄然改变着传统的民政工作方式。 结婚证识别与离婚证识别接口是基于光学字符识别(OCR)技术的智…

热门财务软件大盘点,哪款最适合你?

本文介绍了ZohoBooks、金蝶云、速达会计等10款财务记账软件,各具优点,适合不同需求企业。各软件特点包括实时财务跟踪、多币种管理、无缝银行账户同步等,助企业高效管理财务。建议企业根据自身需求试用后选择。 一、Zoho Books Zoho Books是…

FreeRTOS列表与列表项

1.什么是列表与列表项 列表与列表项实际上是FreeRTOS中一个大量使用的一种数据结构 1.列表 列表的概念有点像链表,在 FreeRTOS 中,列表主要用于以下几个方面: 任务的管理:FreeRTOS 使用列表来管理不同的任务,包括就…

计算机网络面试题——第二篇

1. TCP拆包和粘包 现象 粘包:指在TCP传输中,发送方的多个数据包在接收方被合并在一个包接收,导致多条消息数据粘在一起,接收方无法正确区分这些消息的边界。拆包:指的是发送方的一个数据包在接收方被分成了多个包接收…

springboot集成mybatis插入数据时返回刚插入数据的自增id,插入数据没有使用实体

直接上代码吧 需要改两个地方一个dao一个xml 实现类里的逻辑 dao中新增注解 Options(useGeneratedKeys true, keyProperty "id")xml中新增 useGeneratedKeys"true" keyProperty"id"

2024年【电工(高级)】考试题及电工(高级)考试内容

题库来源:安全生产模拟考试一点通公众号小程序 电工(高级)考试题根据新电工(高级)考试大纲要求,安全生产模拟考试一点通将电工(高级)模拟考试试题进行汇编,组成一套电工…

Android问题笔记五十:构建错误-AAPT2 aapt2-7.0.2-7396180-windows Daemon

Unity3D特效百例案例项目实战源码Android-Unity实战问题汇总游戏脚本-辅助自动化Android控件全解手册再战Android系列Scratch编程案例软考全系列Unity3D学习专栏蓝桥系列ChatGPT和AIGC 👉关于作者 专注于Android/Unity和各种游戏开发技巧,以及各种资源分…

xxl-job--03--分片广播 动态分片

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 xxl-job通过分片广播模式前言1.定义什么是分片广播:即xxl-job调度中心发出一次调度,所有相关节点全部执行一次 采用分片广播调度优点 2.API介…

基于 ESP-AT 固件从外部服务器获取文件,使用分段续传的方式

**可使用 ATHTTPCGET 指令获取 HTTP\HTTPS 的资源,将返回资源的 Size 和 Data ** AT 指令序列如下: ATRESTOREATCWMODE1 //设置 WiFi Station 模式ATCWJAP"cc2.4","12345678" //连接 WiFi ATHTTPCHEAD…

JAVA全球美业新风尚国际版同城美容美发到店上门一体化服务系统小程序源码

全球美业新风尚,美丽触手可及!✨ 🌍 开篇:引领国际美业新潮流 在这个追求个性与美丽的时代,美容美发已不再是简单的日常护理,它成为了我们展现自我、追求品质生活的一种方式。而“全球美业新风尚国际版同…

qt 图形视图框架 事件处理

Qt 的图形视图框架(Graphics View Framework)提供了一套丰富的类来管理大量的自定义 2D 图形项(QGraphicsItem),以及这些图形项之间的交互和事件处理。在这个框架中,事件处理是一个关键部分,它允…

如意控物联网项目-ML307R模组软件及硬件调试环境搭建

软件及硬件调试环境搭建 1、 软件环境搭建及编译 a) 打开官方SDK,内涵APP-DEMO,通过vscode打开程序, 软件程序编写及编译参考下边说明文档链接 OneMO线上服务平台 编译需预安装python3.7以上版本,安装完python后,打开…

微信小程序使用scroll-view 加上enable-flex之后高度变得特别长

横向滚动给scroll-view标签加上了display:flex的样式后高度变得很长。 可以在设置align-items: flex-start;可解决这个问题。 或者给scroll-view下的标签加上height: fit-content;

普密斯在线图像测量仪:为质量把关助力

质量是企业的生命线,普密斯在线图像测量仪是质量把关的得力助手。 在产品生产过程中,它持续不断地对产品进行测量监控。一旦发现尺寸偏差超出允许范围,就会及时发出警报。 在塑料制品生产中,它可以确保每个塑料制品的厚度、长度等…

Altium Designer板框提取工具

这个工具用于提取Altium Designer的PCB文档的边框,支持输出为PCBDOC、SVG、AI、VSDX、PDF、DWG、DXF、HTML这几种矢量格式的图形文件,JPG、PNG、BMP、GIF、EMF这几种非矢量格式的图像文件,CSV和TXT格式的点阵文件。可以将PCB的廓落提取出来复…

【最新发布】Win10 22H2 19045.4957 正式版免费下载!

今日系统之家小编给大家分享2024年9月第二次更新的Windows10 22H2正式版系统,该版本系统基于最新Windows10 22H2 19045.4957 64位专业版进行离线制作,安全无毒,修复了使用某些环绕声技术时某些媒体的播放可能会停止等多项问题,系统…

pyQt 退出报:进程已结束,退出代码为 -1073740791 (0xC0000409)

摘要 我在调试pyQT的时候发现结束线程后会出现,进程已结束,退出代码为 -1073740791 (0xC0000409),这个错误,排查了一星期才发现问题在哪里,特此记录 解决方案 进程已结束,退出代码为 -1073740791 (0xC00…

探索 DaPy:Python 中的 AI 数据处理新贵

文章目录 探索 DaPy:Python 中的 AI 数据处理新贵背景介绍DaPy 是什么?如何安装 DaPy?DaPy 的简单函数使用方法加载数据数据筛选数据聚合数据可视化自定义函数 DaPy 在实际场景中的应用数据预处理数据分析数据处理与集成 常见 Bug 及解决方案…