<<让问题交流,简单明了。>>
AIDL回调接口报错: Parcel : **** enforceInterface() expected 'com.unistrong..ReadIDCardAIDL'
but read 'com.xxx..CallBackIdCard'01-02 14:25:14.540 27923 27923 D AndroidRuntime: Shutting down VM
--------- beginning of crash
FATAL EXCEPTION: main
Process: com.xxx.:remote, PID: 27923
java.lang.SecurityException: Binder invocation to an incorrect interface
at android.os.Parcel.nativeEnforceInterface(Native Method)
at android.os.Parcel.enforceInterface(Parcel.java:483)
at com.unistrong..ReadIDCardAIDL$Stub.onTransact(ReadIDCardAIDL.java:47)
at android.os.Binder.transact(Binder.java:499)
at com.unistrong..CallBackIdCard$Stub$Proxy.setInfo(CallBackIdCard.java:80)
at com.unistrong.XXX..callback(XXX.java:245)
at com.XXX.XXX..updateInfo(XXX.java:225)
at com.XXX.XXX..access$0(XXX.java:200)
at com.XXX.XXX.$1.handleMessage(XXX.java:52)
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)
uid=1000(system) android.ui expire 13 lines
纠结了好久,在网上搜了搜大部分都说是Server和Client的包名不一致,在接口回调里其实不是这样的,在这里把这个总结出来,希望能帮助遇到的朋友。其实这个问题,主要还是自己马虎造成的,后来才突然发现。
原因是 : 在onServiceConnected() 中 回调时, CallBackIdCard的实例创建是
CallBackIdCard callback=new CallBackIdCard(){
void setInfo(Map map){
//处理数据
}
}
,导致报错: Parcel : **** enforceInterface() expected 'com.unistrong..ReadIDCardAIDL'
but read 'com.xxx..CallBackIdCard' ,意思是Server端不能识别callback。
解决办法:
CallBackIdCard的实例创建是:
CallBackIdCard callback=new CallBackIdCard.Stub(){
void setInfo(Map map){
//处理数据
}
}
这样传递给Server的callback是Stub 代理基于Binder, Server能识别到callback接口,然后就能正常调用了。