Google难架马甲多

今年谷歌上架的难度可谓是地狱级别。

可是国内马甲这么多,总要摸索出一些套路来。

这里总结几条开源aab混淆策略。

1、as自带混淆是必要的,否则就是源码提包,相当于到谷歌门口举个牌子说我是马甲包。

不仅要驳回,还要被封号。

所以这个得加上。

2、做了第一步,也还只是个小孩。只是对包名、字符串做了简单的替换,对安卓的4大组件类开绿灯了,这块相似度高也是个麻烦事。

我们问问开源世界对这个问题的看法。

有一些变态混淆我们可以用起来:

比如说这个:

2.1  变态字典

用上这个,我们看下反编译出来的aab:

这个马甲,人看了只会一脸黑。

当然还有一些超级变态的混淆字典,比如这个兄弟提供的:

2.2  超级变态混淆字典

这已经到了乱码级了。

但个人觉得,做到2.1就行了,2.2没必要。我们的目的是通过审核,在审核层面的帮助这一步意义不大。

好,dex代码混淆其实做的差不多了,再往下做就得像加固那样把代码怼到so里面去了,那样可能适得其反,谷歌直接帮你驳回。

3、aab包里还有一块也是谷歌重点审核对象:资源

资源其实大致分两类,一类是xml文件,一类是非xml文件。

xml文件除了文件名、md5校验,还可以比较文件内容。一些id,属性,字串等都可能要经过审查。

非xml的比如图片,这类一般是文件名和md5比对(瞎猜的)。

图片的md5简单的就是通过UI设计发力,程序员对资源做混淆就好。

开源社区上也有较多的这类混淆工具

针对aab的有bytedance的这个:

这个工具比较老了,AGP版本1.8以上就会无法使用。但是可以用fork他的改良版:

3.1  ResChiper

目测是印度小伙优化的,点赞。

根据他的魔法,打出来的aab反编译是这样的:

构建完成后会在aab目录输出resource-mapping.txt:

可以看到只是对文件夹、文件名做了字典替换。

文件内容不会去变。

但为了深度混淆,最好在做个xml文件内容混淆。

可以用这个:

3.2  XmlClassGuard

这个是本地gradle task直接修改源码,建议在单独分支处理,避免污染源码。

另外需要注意的是,这个工具会把所有类和资源做字典替换,且会有部分类会替换不完全,还需要手动补全。需要花点精力。

执行顺序应该是XmlClassGuard的task先执行,再执行ResCeipher打包任务。

这套combo下来,基本上谷歌也会低下高傲的头颅。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【Trino权威指南(第二版)】Trino介绍:trino解决大数带来的问题

文章目录 一. 大数据带来的问题二. Trino来救场1. 为性能和规模而生2. SQL-on-Anything3. 数据存储与查询计算资源分离 三. Trino使用场景 一. 大数据带来的问题 数据现状 数据存储机制日益多样:关系型数据库、NoSQL数据库、文档数据库、键值存储和对象存储系统等。…

Python中的并发编程(1)并发相关概念

并发和并行 并发和并行 并发指逻辑上同时处理多件事情,并行指实际上同时做多件事情。 并发不一定通过并行实现,也可以通过多任务实现。例如:现代操作系统都可以同时执行多个任务,比如同时听歌和玩游戏,但歌曲播放和游…

每日一练【查找总价格为目标值的两个商品】

一、题目描述 题目链接 购物车内的商品价格按照升序记录于数组 price。请在购物车中找到两个商品的价格总和刚好是 target。若存在多种情况,返回任一结果即可。 示例 1: 输入:price [3, 9, 12, 15], target 18 输出:[3,15] …

【MVP矩阵】投影矩阵推导与实现

相机空间和NDC空间示意图(来自奇乐编程学院) 相机坐标系一般都是右手坐标系, 相机朝向是 z 的负半轴 裁剪空间和NDC空间示意图 投影矩阵推导 【本文仅用于自身备忘】 正交投影推导结果如下 透视投影推导结果如下 备注 一般情况下,透…

Java数据结构之《希尔排序》(难度系数85)

一、前言: 这是怀化学院的:Java数据结构中的一道难度中等的一道编程题(此方法为博主自己研究,问题基本解决,若有bug欢迎下方评论提出意见,我会第一时间改进代码,谢谢!) 后面其他编程题只要我写完…

【国金属学会指导】第十一届先进制造技术与材料工程国际学术会议 (AMTME 2024)

JPCS独立出版/高录用快检索/院士杰青云集 第十一届先进制造技术与材料工程国际学术会议 (AMTME 2024) 2024 11th International Conference on Advanced Manufacturing Technology and Materials Engineering 第十一届先进制造技术与材料工程国际学术会议 (AMTME 2024) 定…

高质量科技期刊分级目录汇总(附下载)

中国科协自 2019 年以来,分批支持全国学会面向学科领域国内外科技期刊,编制发布高质量期刊分级目录,为科技工作者发表论文和科研机构开展学术评价提供参考。截至 2023 年 11 月底,已有 43 家全国学会完成了所在领域首版分级目录编…

用java比较两个二叉搜索树是否等价

一. 定义树的的节点 ​ 不同二叉树的叶节点上可以保存相同的值序列。例如,以下两个二叉树都保存了序列 1,1,2,3,5,8,13。 package com.wedoo.coderyeah.module.iot.algorithm;import lombok.…

车联网架构设计(二)_消息缓存

在上一篇博客车联网架构设计(一)_消息平台的搭建-CSDN博客中,我介绍了车联网平台需要实现的一些功能,并介绍了如何用EMQXHAPROXY来搭建一个MQTT消息平台。车联网平台的应用需要消费车辆发布的消息,同时也会下发消息给车辆,以实现车…

ModStartCMS v7.7.0 集成内容区块,文件选择顺序

ModStart 是一个基于 Laravel 模块化极速开发框架。模块市场拥有丰富的功能应用,支持后台一键快速安装,让开发者能快的实现业务功能开发。 系统完全开源,基于 Apache 2.0 开源协议,免费且不限制商业使用。 功能特性 丰富的模块市…

羊大师发现,广州可能真的要下雪了!

羊大师发现,广州可能真的要下雪了! 关于这次广州可能要下雪的消息,来源于气象部门的初步预测。据气象部门表示,近期广州将受到较强的冷空气影响,降温幅度可达5-7摄氏度,且湿度较大,这都是下雪的…

动静态IP代理是怎么实现的?如何搭建稳定独享住宅IP?

首先,让我们来了解一下什么是动静态IP代理。动静态IP代理是一种网络代理服务,它可以通过设置IP代理服务器来隐藏用户的真实IP地址,从而保护用户的隐私和安全。 根据是否需要手动切换IP地址,可以将动静态IP代理分为动态代理和静态代…

C-11练习题

一、单项选择题(本大题共20小题,每小题2分,共40分。在每小题给出的四个备选项中选出一个正确的答案,并将所选项前的字母填写在答题纸的相应位置上。) 1,在C语言中,合法的长整型常数是() A. OxOL B. 4962710M C. 324562& D. 216D 2,设有定义: int a[10],*pa6,*q…

Git配置

个人主页:Lei宝啊 愿所有美好如期而遇 前言 前面我们新建了远程仓库并且在Linux上克隆了远程仓库,但是在新建仓库时我们提到会配置gitignore文件,这次我们将会配置他,并给命令起别名。 目录 前言 忽略特殊文件 给命令起别名…

matplotlib 默认属性和绘图风格

matplotlib 默认属性 一、绘图风格1. 绘制叠加折线图2. Solarize_Light23. _classic_test_patch4. _mpl-gallery5. _mpl-gallery-nogrid6. bmh7. classic8. fivethirtyeight9. ggplot10. grayscale11. seaborn12. seaborn-bright13. seaborn-colorblind14. seaborn-dark15. sea…

东芝CT高压电源维修VP-33452 ULTIMAX80 DREX-ULT80

东芝高压电源多用于东芝CT机XVISION/EX、AUKLET系列、ASTEION系列、以及多排系列。 电源内部电路不得随意更改。电源维修的几点注意事项,希望大家能够在以后遇到类似的问题能帮帮助到大家。spellmαnl电源维修一首先在维修开关电源时,维修人员在修理时注…

Linux环境下安装Nginx

Nginx(发音:engine-x)是一个高性能的HTTP和反向代理服务器,也可以作为邮件代理服务器使用。它是由俄罗斯程序员Igor Sysoev开发的,并在2004年公开发布。Nginx是一个开源项目,可以在Linux、Unix、BSD和Windo…

UVM验证平台中加入sequencer

sequence机制用于产生激励,它是UVM中最重要的机制之一。在 一个规范化的UVM验证平台中,driver只负责驱动transaction,而不负责产生transaction。sequence机制有两大组成部分,一是 sequence,二是sequencer。如何在验证平…

集合01 - Java

集合 1、数组的不足2、集合3、集合的框架体系(背)CollectionMap 1、数组的不足 前面我们保存多个数据使用的是数组,那么数组有不足的地方,我们分析一下。 数组: 长度开始时必须指定,而且一旦指定,不能更改…

【从删库到跑路 | MySQL数据库总结篇】JDBC编程

个人主页:兜里有颗棉花糖 欢迎 点赞👍 收藏✨ 留言✉ 加关注💓本文由 兜里有颗棉花糖 原创 收录于专栏【MySQL学习专栏】🎈 本专栏旨在分享学习MySQL的一点学习心得,欢迎大家在评论区讨论💌 目录 一、前言…