Flutter编译的APK包体积过大的解决方法 APK大小优化策略

最近在编译SocialCall的手机APP代码,发现默认生成的APK大小竟然高达400多兆,这明显是不正常了,赶紧百度找到以下解决方法。

android和iOS通用方案

  1. 删:移除无用代码和无用资源
  2. 缩:压缩资源图片(熊猫压缩)或者多使用svg格式的图片
  3. 挪:服务端下发插件或资源

android方案

  1. so优化:Flutter打包Apk会包含三种CPU架构信息以适配不同架构的设备(x86_64,arm64-v8a,armeabi-v7a),目前大部分手机都是armeabi-v7a这个架构,所以我们可以分架构分别打包,包体减小较明显,但是需要舍弃小部分机型

打包命令:

flutter build apk --target-platform android-arm,android-arm64,android-x64 --split-per-abi
  • 首先 flutter build apk 表示当前构建 release 包;
  • 后面 android-arm,android-arm64,android-x64则是指定生成对应架构的release包;
  • 最后的 –split-per-abi则表示告知需要按照我们指定的类型分别打包,如果移除则直接构建包含所有 CPU 架构的 Apk 包。
  • 所以这个命令的含义就是告诉编译器,我需要你为我针对我指定的三种不同架构分别生成对应的Apk 包。
  1. 混淆:可以增加逆向难度还有减少Apk大小

混淆打包命令(): flutter build apk –obfuscate –split-debug-info=xx

  • –obfuscate:开启混淆操作;
  • –split-debug-info=:将因混淆生成的 map 符号表缓存到此位置

so优化和混淆同时使用打包命令:

flutter build apk --obfuscate --split-debug-info=debugInfo --target-platform android-arm,android-arm64,android-x64 --split-per-abi

 

PS:经过测试android原debug包 104.9MB ,release包 73.5MB ,如果仅仅使用v7a架构包大小为 29.1MB

PS2:经过测试分架构打包不使用混淆打包命令好像也会自动开启混淆。若不设置相关混淆规则,部分三方插件会不能使用。

原文链接:https://vuesite.cn/40167.html,转载请注明出处。
0
显示验证码
没有账号?注册  忘记密码?