代码混淆导致 [java.lang.VerifyError Bad type on operand stack]
场景
在项目开发中为了源代码的安全问题,有时候会把代码混淆,让人无法通过反编译Java的class文件得到源码,但是在代码混淆之后可能会出现一些问题。
问题描述
我新建了一个类
public class TKScheduledTaskServiceDataOperationUpload {
public Object exeAction(HashMap<String, Object> result) {
try{
//code
} catch (ParseException | IOException e) {
e.printStackTrace();
return null;
}
return null;
}
}
编译完成之后得到jar
包,通过 allatori
混淆代码,上传到服务器,在启动项目的时候出现了如下的异常日志:
Caused by: java.lang.VerifyError Bad type on operand stack
Exception Details:
Location:
com/css/tk/tka/core/common/log/TKScheduledTaskServiceDataOperationUpload.exeAction(Ljava/util/HashMap;)Ljava/lang/Object; @831: invokevirtual
Reason:
Type 'java/lang/Object' (current frame, stack[2]) is not assignable to 'java/lang/Throwable'
Current Frame:
bci: @831
flags: {
}
locals: {
'java/lang/Object', 'java/util/List', 'com/css/tk/tka/core/common/log/TKScheduledTaskServiceDataOperationUpload', 'java/lang/Object', 'java/lang/String', 'java/lang/Object', 'java/util/HashMap' }
stack: {
'com/css/sword/kernel/utils/SwordLogUtils', 'java/lang/String', 'java/lang/Object' }
Bytecode:
0x0000000: 2a4d b200 3812 b0b8 003f b600 452b b800
0x0000010: b699 0011 b200 3812 b8b8 003f b600 4501
0x0000020: b0bf 12ba b800 3fb6 0095 04bd 00bc 0459
0x0000030: 5859 0312 be53 b800 c4c0 00c6 594b b800
0x0000040: b69a 0032