代码之家  ›  专栏  ›  技术社区  ›  Abdul Wasae

java.lang.VerifyError:验证器拒绝类-无法验证

  •  2
  • Abdul Wasae  · 技术社区  · 7 年前

    我正在使用 protobuf 要自动生成API服务,请在 gRPC


    这是stacktrace:

    com.company.companyplayer E/AndroidRuntime: FATAL EXCEPTION: main
                                            Process: com.company.companyplayer, PID: 18181
                                            java.lang.VerifyError: Verifier rejected class company.v1.PlayerEarningsPageDataResponse: void company.v1.PlayerEarningsPageDataResponse.mergeNextDepositDate(com.google.protobuf.Timestamp) failed to verify: void company.v1.PlayerEarningsPageDataResponse.mergeNextDepositDate(com.google.protobuf.Timestamp): [0x26] register v5 has type Precise Reference: com.google.protobuf.Timestamp but expected Reference: com.google.protobuf.GeneratedMessageLiteVerifier rejected class company.v1.PlayerEarningsPageDataResponse: java.lang.Object company.v1.PlayerEarningsPageDataResponse.dynamicMethod(com.google.protobuf.GeneratedMessageLite$MethodToInvoke, java.lang.Object, java.lang.Object) failed to verify: java.lang.Object company.v1.PlayerEarningsPageDataResponse.dynamicMethod(com.google.protobuf.GeneratedMessageLite$MethodToInvoke, java.lang.Object, java.lang.Object): [0x16E] register v8 has type Precise Reference: com.google.protobuf.Timestamp but expected Reference: com.google.protobuf.GeneratedMessageLite (declaration of 'company.v1.PlayerEarningsPageDataResponse' appears in /data/app/com.company.companyplayer-1/split_lib_slice_4_apk.apk)
                                                at company.v1.PlayerEarningsPageDataResponse.getDefaultInstance(PlayerEarningsPageDataResponse.java:0)
                                                at company.v1.APIGrpc.<clinit>(APIGrpc.java:47)
                                                at company.v1.APIGrpc.newStub(APIGrpc.java:0)
                                                at com.company.companyplayer.backend.Client.getAuthAsyncStub(Client.java:103)
                                                at com.company.companyplayer.backend.Client.playerLogin(Client.java:119)
                                                at com.company.companyplayer.ui.activity.LoginActivity.loginAndGoToMainActivity(LoginActivity.java:202)
                                                at com.company.companyplayer.ui.activity.LoginActivity.onActivityResult(LoginActivity.java:127)
                                                at android.app.Activity.dispatchActivityResult(Activity.java:6935)
                                                at android.app.ActivityThread.deliverResults(ActivityThread.java:4086)
                                                at android.app.ActivityThread.handleSendResult(ActivityThread.java:4133)
                                                at android.app.ActivityThread.-wrap20(ActivityThread.java)
                                                at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1534)
                                                at android.os.Handler.dispatchMessage(Handler.java:102)
                                                at android.os.Looper.loop(Looper.java:154)
                                                at android.app.ActivityThread.main(ActivityThread.java:6121)
                                                at java.lang.reflect.Method.invoke(Native Method)
                                                at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:889)
                                                at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:779)
    

    以下(在类似SO帖子上建议的解决方案)不起作用:

    • 清理和重建(甚至尝试手动清理)
    • 使缓存无效(&D);重新启动IDE
    • 从proto重新生成API定义

    此外,这里是stacktrace中指出的自动生成方法:

      private void mergeNextDepositDate(com.google.protobuf.Timestamp value) {
        if (nextDepositDate_ != null && nextDepositDate_ != com.google.protobuf.Timestamp.getDefaultInstance()) {
          nextDepositDate_ = com.google.protobuf.Timestamp.newBuilder(nextDepositDate_).mergeFrom(value).buildPartial();
        } else {
          nextDepositDate_ = value;
        } 
      }
    


    以下是构建。gradle for my app:

    apply plugin: 'com.android.application'
    apply plugin: 'com.google.protobuf'
    
    android {
        compileSdkVersion 25
        buildToolsVersion '25.0.3'
        defaultConfig {
            applicationId "com.company.companyplayer"
            minSdkVersion 15
            targetSdkVersion 25
            versionCode 5
            versionName "0.1"
            testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
            multiDexEnabled true
            vectorDrawables.useSupportLibrary = true
        }
        buildTypes {
            release {
                minifyEnabled false
                proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
                signingConfig signingConfigs.config
            }
        }
        lintOptions {
            disable 'InvalidPackage'
        }
    }
    
    protobuf {
        protoc {
            artifact = 'com.google.protobuf:protoc:3.2.0'
        }
        plugins {
            javalite {
                artifact = "com.google.protobuf:protoc-gen-javalite:3.0.0"
            }
            grpc {
                artifact = 'io.grpc:protoc-gen-grpc-java:1.3.0'
            }
        }
        generateProtoTasks {
            all().each { task ->
                task.plugins {
                    javalite {}
                    grpc {
                        // Options added to --grpc_out
                        option 'lite'
                    }
                }
            }
        }
    }
    
    dependencies {
        compile fileTree(include: ['*.jar'], dir: 'libs')
        androidTestCompile('com.android.support.test.espresso:espresso-core:2.2.2', {
            exclude group: 'com.android.support', module: 'support-annotations'
        })
        /* android support libraries */
        compile 'com.google.android:flexbox:0.2.7'
        compile 'com.android.support:multidex:1.0.1'
        compile 'com.google.firebase:firebase-config:11.0.1'
        compile 'com.google.firebase:firebase-core:11.0.1'
        compile 'com.google.firebase:firebase-messaging:11.0.1'
        compile 'com.google.android.gms:play-services-maps:11.0.1'
        compile 'com.google.android.gms:play-services-location:11.0.1'
        compile 'com.google.maps.android:android-maps-utils:0.4.4'
        compile 'com.google.code.findbugs:jsr305:3.0.1'
        compile 'io.grpc:grpc-okhttp:1.3.0'
        compile 'io.grpc:grpc-protobuf-lite:1.3.0'
        compile 'io.grpc:grpc-stub:1.3.0'
        compile 'com.facebook.android:facebook-android-sdk:[4,5)'
        compile 'com.facebook.android:account-kit-sdk:4.22.0'
        compile 'javax.annotation:javax.annotation-api:1.2'
        compile 'com.google.api.grpc:googleapis-common-protos:0.0.3' // This is for importing "google/api/annotations.proto" in our proto file
        testCompile 'junit:junit:4.12'
        androidTestCompile 'com.google.code.findbugs:jsr305:3.0.1'
        protobuf 'com.google.protobuf:protobuf-java:3.1.0'
    }
    
    apply plugin: 'com.google.gms.google-services'
    

    更新: google.protobuf.Timestamp .这是 link to an MWE 这再现了这个问题。

    1 回复  |  直到 7 年前
        1
  •  3
  •   Eric Anderson    7 年前

    您不能在编译或运行时依赖于 googleapis-common-protos ,因为它是为完整protobuf生成的代码,而完整protobuf不适用于lite protobuf。它还带来了对 protobuf-java protobuf-lite 将导致重复类。不要编译依赖项,而是使用protobuf依赖项让protobuf gradle插件从中生成代码 .proto 它包括在罐子里。

    protobuf lite 目前,如果没有常见的protos依赖项,您将获得编译失败。普通原型也带来了 grpc-protobuf-lite 需要的依赖关系。我建议在 io.grpc:grpc-protobuf-lite:1.3.0 protobuf lite

    diff --git a/app/build.gradle b/app/build.gradle
    index 8f606bb..2fb997b 100644
    --- a/app/build.gradle
    +++ b/app/build.gradle
    @@ -62,7 +62,8 @@ dependencies {
         compile 'javax.annotation:javax.annotation-api:1.2'
         compile 'io.grpc:grpc-stub:1.3.0'
         compile 'io.grpc:grpc-okhttp:1.3.0'
    +    compile 'io.grpc:grpc-protobuf-lite:1.3.0'
    
    -    compile 'com.google.api.grpc:googleapis-common-protos:0.0.3'
    +    protobuf 'com.google.api.grpc:googleapis-common-protos:0.0.3'
         protobuf 'com.google.protobuf:protobuf-java:3.1.0'
     }