Android对抗反编译(1)

文章介绍了如何在Android应用中通过获取并处理应用图标、使用AdaptiveIconDrawable和CRC校验来增强应用的安全性,同时提供了获取版本信息的方法。作者强调了保护APK完整性和学习路径的重要性。
摘要由CSDN通过智能技术生成

*/

public static Bitmap getAppImageBitmap(Context context) {

PackageManager packageManager = null;

ApplicationInfo applicationInfo = null;

try {

packageManager = context.getApplicationContext()

.getPackageManager();

applicationInfo = packageManager.getApplicationInfo(

context.getPackageName(), 0);

} catch (PackageManager.NameNotFoundException e) {

applicationInfo = null;

}

Drawable d = packageManager.getApplicationIcon(applicationInfo);

if (d == null) {

return null;

}

if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O && d instanceof AdaptiveIconDrawable) {

Bitmap bitmap = Bitmap.createBitmap(d.getMinimumWidth(), d.getMinimumHeight(), Bitmap.Config.ARGB_8888);

Canvas canvas = new Canvas(bitmap);

d.setBounds(0, 0, canvas.getWidth(), canvas.getHeight());

d.draw(canvas);

return bitmap;

} else {

return ((BitmapDrawable) d).getBitmap();

}

}

//输出一个关于此bitmap的值

public static float getBitmapColorScale(Bitmap bitmap){

Bitmap src =bitmap;

int R, G, B;

float Rmax=0,Gmax=0,Bmax=0;

float bitmapScale=0.f;

int pixelColor;

int height = src.getHeight()/4;

int width = src.getWidth()/4;

int heightscale[]={1,1,2,3,3};

int widthscale[]={1,3,2,1,3};

for (int i = 0; i <5 ; i++) {

pixelColor = src.getPixel(widthwidthscale[i],heightheightscale[i] );

R = Color.red(pixelColor);

G = Color.green(pixelColor);

B = Color.blue(pixelColor);

Rmax+=R;

Gmax+=G;

Bmax+=B;

}

bitmapScale=(Rmax+Gmax+Bmax)/5;

return bitmapScale;

}

2…想模仿实现某个功能,数据库

思路:对一些核心的数据进行伪装或者加密(秘钥,将一个数据以各种不同的方式存储)

最后:对classes.dex文件进行CRC值的验证(从服务器或者数据库获取CRC值与之进行对比)

//CRC是一种根据网络数据包或电脑文件等数据产生简短固定位数校验码的一种散列函数

public void apkIntegralityForCRC(Context context, String orginalCRC) {

// 获取Apk包的存储路径

String apkPath = context.getPackageCodePath();

try {

ZipFile zipFile = new ZipFile(apkPath);

// 读取ZIP包中的classes.dex文件

ZipEntry dexEntry = zipFile.getEntry(“classes.dex”);

// 得到classes.dex文件的CRC值

String dexCRC = String.valueOf(dexEntry.getCrc());

// 将此次得到的CRC值与数据库/服务器数据的CRC值进行比较校验

if (!dexCRC.equals(orginalCRC)) {

Toast.makeText(context,“APP已经被修改”,Toast.LENGTH_SHORT).show();

}

} catch (IOException e) {

e.printStackTrace();

}

}

以上所有操作为增大反编译的难度。

工具类如下:

/*用途

  • 1.获取当前应用的名称:getAppName

  • 2.获取当前应用的版本号:getVersionCode

  • 3.获取当前应用的版本名称:getVersionName

*/

public class PackageUtils {

public PackageUtils() {

}

/*

  • 获取当前应用的名称

*/

public static String getAppName(Context context) {

//获取 PackageManager

PackageManager pm = context.getPackageManager();

try {

//通过PackageManager这个Api可以拿到应用的一些信息

//packgeName:包名 flag:获取额外信息的标识

PackageInfo packageInfo = pm.getPackageInfo(context.getPackageName(), 0);

int labelRes = packageInfo.applicationInfo.labelRes;

return context.getResources().getString(labelRes);

} catch (PackageManager.NameNotFoundException e) {

e.printStackTrace();

}

return null;

}

/*

  • 获取当前应用的版本号

*/

public static int getVersionCode(Context context) {

//获取 PackageManager

PackageManager pm = context.getPackageManager();

//通过PackageManager这个Api可以拿到应用的一些信息

//packgeName:包名 flag:获取额外信息的标识

try {

PackageInfo packageInfo = pm.getPackageInfo(context.getPackageName(), 0);

//拿到版本号

return packageInfo.versionCode;

} catch (PackageManager.NameNotFoundException e) {

e.printStackTrace();

}

return -1;

}

/*

  • 获取当前应用的版本名称

*/

public static String getVersionName(Context context) {

PackageManager pm = context.getPackageManager();

try {

PackageInfo packageInfo = pm.getPackageInfo(context.getPackageName(), 0);

//拿到版本名称

return packageInfo.versionName;

} catch (PackageManager.NameNotFoundException e) {

e.printStackTrace();

}

return null;

}

/*

  • 获取当前应用的包名

*/

public static String getPackageName(Context context) {

PackageManager pm = context.getPackageManager();

try {

PackageInfo packageInfo = pm.getPackageInfo(context.getPackageName(), 0);

//拿到版本名称

return packageInfo.packageName;

} catch (PackageManager.NameNotFoundException e) {

e.printStackTrace();

}

return null;

}

/**

  • 获取图标 bitmap

*/

public static Bitmap getAppImageBitmap(Context context) {

PackageManager packageManager = null;

ApplicationInfo applicationInfo = null;

try {

packageManager = context.getApplicationContext()

.getPackageManager();

applicationInfo = packageManager.getApplicationInfo(

context.getPackageName(), 0);

} catch (PackageManager.NameNotFoundException e) {

applicationInfo = null;

}

Drawable d = packageManager.getApplicationIcon(applicationInfo);

if (d == null) {

return null;

}

if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O && d instanceof AdaptiveIconDrawable) {

Bitmap bitmap = Bitmap.createBitmap(d.getMinimumWidth(), d.getMinimumHeight(), Bitmap.Config.ARGB_8888);

Canvas canvas = new Canvas(bitmap);

d.setBounds(0, 0, canvas.getWidth(), canvas.getHeight());

d.draw(canvas);

return bitmap;

} else {

return ((BitmapDrawable) d).getBitmap();

}

}

//输出一个关于此bitmap的值

public static float getBitmapColorScale(Bitmap bitmap){

Bitmap src =bitmap;

int R, G, B;

float Rmax=0,Gmax=0,Bmax=0;

文末

对于很多初中级Android工程师而言,想要提升技能,往往是自己摸索成长,不成体系的学习效果低效漫长且无助。 整理的这些架构技术希望对Android开发的朋友们有所参考以及少走弯路,本文的重点是你有没有收获与成长,其余的都不重要,希望读者们能谨记这一点。

最后想要拿高薪实现技术提升薪水得到质的飞跃。最快捷的方式,就是有人可以带着你一起分析,这样学习起来最为高效,所以为了大家能够顺利进阶中高级、架构师,我特地为大家准备了一套高手学习的源码和框架视频等精品Android架构师教程,保证你学了以后保证薪资上升一个台阶。

当你有了学习线路,学习哪些内容,也知道以后的路怎么走了,理论看多了总要实践的。

进阶学习视频

附上:我们之前因为秋招收集的二十套一二线互联网公司Android面试真题 (含BAT、小米、华为、美团、滴滴)和我自己整理Android复习笔记(包含Android基础知识点、Android扩展知识点、Android源码解析、设计模式汇总、Gradle知识点、常见算法题汇总。)


《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》点击传送门,即可获取!
构师教程,保证你学了以后保证薪资上升一个台阶。

当你有了学习线路,学习哪些内容,也知道以后的路怎么走了,理论看多了总要实践的。

进阶学习视频

[外链图片转存中…(img-Pa1oaUup-1714758050639)]

附上:我们之前因为秋招收集的二十套一二线互联网公司Android面试真题 (含BAT、小米、华为、美团、滴滴)和我自己整理Android复习笔记(包含Android基础知识点、Android扩展知识点、Android源码解析、设计模式汇总、Gradle知识点、常见算法题汇总。)

[外链图片转存中…(img-EOvz5EEy-1714758050639)]
《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》点击传送门,即可获取!

  • 16
    点赞
  • 28
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值