[求助]为什么 flutter 调试模式可以。发布模式打包出来的则无法运行。 - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
Dnlyao
V2EX    Flutter

[求助]为什么 flutter 调试模式可以。发布模式打包出来的则无法运行。

  •  
  •   Dnlyao 2024-11-12 14:44:55 +08:00 1648 次点击
    这是一个创建于 395 天前的主题,其中的信息可能已经有所发展或是发生改变。
    环境使用 gradle-7.5-all.zip ,
    buildscript {
    ext.kotlin_version = '1.9.10'
    repositories {
    maven {
    url 'https://maven.aliyun.com/repository/public/'
    }
    google()
    mavenCentral()
    maven { url "https://jitpack.io" }//maven 仓库
    }

    dependencies {
    classpath 'com.android.tools.build:gradle:7.2.0'
    classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version"
    }
    }
    使用 flutter_blue: ^0.8.0 依赖。发布模式查看不到什么报错。然后再调试模式,正常调起蓝牙服务。
    Dnlyao
        1
    Dnlyao  
    OP
       2024-11-12 16:11:50 +08:00
    在真机编译运行。
    lutter ( 7085): [ERROR:flutter/runtime/dart_vm_initializer.cc(41)] Unhandled Exception: PlatformException(error, Field state_ for t2.i not found. Known fields are [private int t2.i.e, private static final t2.i t2.i.f, private static volatile r1.a1 t2.i.g], null, java.lang.RuntimeException: Field state_ for t2.i not found. Known fields are [private int t2.i.e, private static final t2.i t2.i.f, private static volatile r1.a1 t2.i.g]
    E/flutter ( 7085): at r1.v0.n0(Unknown Source:72)
    E/flutter ( 7085): at r1.v0.T(Unknown Source:698)
    E/flutter ( 7085): at r1.v0.R(Unknown Source:12)
    E/flutter ( 7085): at r1.k0.e(Unknown Source:60)
    E/flutter ( 7085): at r1.k0.a(Unknown Source:49)
    E/flutter ( 7085): at r1.d1.d(Unknown Source:17)
    E/flutter ( 7085): at r1.d1.e(Unknown Source:4)
    E/flutter ( 7085): at r1.z.A(Unknown Source:4)
    E/flutter ( 7085): at r1.z$a.C(Unknown Source:9)
    E/flutter ( 7085): at r1.z$a.B(Unknown Source:0)
    E/flutter ( 7085): at t2.a.a(Unknown Source:775)
    E/flutter ( 7085): at j3.k$a.a(Unknown Source:17)
    E/flutter ( 7085): at w2.c.l(Unknown Source:18)
    E/flutter ( 7085): at w2.c.m(Unknown Source:40)
    E/flutter ( 7085): at w2.c.i(Unknown Source:0)
    E/flutter ( 7085): at w2.b.run(Unknown Source:12)
    E/flutter ( 7085): at android.os.Handler.handleCallback(Handler.java:958)
    E/flutter ( 7085): at android.os.Handler.dispatchMessage(Handler.java:99)
    E/flutter ( 7085): at android.os.Looper.loopOnce(Looper.java:257)
    E/flutter ( 7085): at android.os.Looper.loop(Looper.java:368)
    E/flutter ( 7085): at android.app.ActivityThread.main(ActivityThread.java:8839)
    E/flutter ( 7085): at java.lang.reflect.Method.invoke(Native Method)
    E/flutter ( 7085): at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:572)
    E/flutter ( 7085): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1049)
    E/flutter ( 7085): )
    E/flutter ( 7085): #0 StandardMethodCodec.decodeEnvelope (package:flutter/src/services/message_codecs.dart:652)
    E/flutter ( 7085): #1 MethodChannel._invokeMethod (package:flutter/src/services/platform_channel.dart:310)
    E/flutter ( 7085): <asynchronous suspension>
    E/flutter ( 7085): #2 FlutterBlue.state (package:flutter_blue/src/flutter_blue.dart:56)
    E/flutter ( 7085): <asynchronous suspension>
    E/flutter ( 7085): #3 AppBleService.init.<anonymous closure> (package:weight_app/services/app_ble.dart:40)
    E/flutter ( 7085): <asynchronous suspension>
    E/flutter ( 7085):
    Dnlyao
        2
    Dnlyao  
    OP
       2024-11-12 16:41:49 +08:00
    貌似找到问题了,可能是 flutter 混淆把依赖的 class 搞丢了。现在配置了保护,就能正常了。
    proguard-rules.pro 位置 android\app\proguard-rules.pro
    -ignorewarnings
    -keep class io.flutter.app.** { *; }
    -keep class io.flutter.plugin.** { *; }
    -keep class io.flutter.util.** { *; }
    -keep class io.flutter.view.** { *; }

    -keep class * {
    public private *;
    }

    android\app\build.gradle 也需要修改,设置规制文件
    buildTypes {

    release {
    signingConfig signingConfigs.release
    proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' // 自定义混淆规则文件
    }

    }
    _____
    不知道是不是真的这个原因。要等有空才能确定......
    whevether
        3
    whevether  
       2024-11-15 13:47:50 +08:00
    ext.kotlin_version 这种写法在新版 flutter 中过时了吧。 新版本是写在 settings.gradle 中了. 这种可能导致其他的依赖无统一使用指定的 kotlin 编译。
    whevether
        4
    whevether  
       2024-11-15 13:49:37 +08:00
    flutter_blue 而且你这个包也过时了啊。三年前更新的。 还是更新到新版 flutter_blue_plus 吧。要不然后期升级更加工作量巨大。
    Dnlyao
        5
    Dnlyao  
    OP
       2024-11-15 16:07:40 +08:00
    @whevether 以前同事搭的模板,flutter 一升级上去,好多不兼容。可能后面会换 plus 吧。太多东西要改了。
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     921 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 24ms UTC 19:12 PVG 03:12 LAX 11:12 JFK 14:12
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86