当前位置: 首页 > 知识库问答 >
问题:

线程“main”java.lang.ClassFormatError中的异常:缺少代码属性

颛孙英勋
2023-03-14

我正在尝试使用下面的代码扫描实体类的JPA@column注释;

for (Method m : User.class.getMethods())
{
    if (m.isAnnotationPresent(javax.persistence.Column.class))
    {
        javax.persistence.Column column = m.getAnnotation(javax.persistence.Column.class);
        System.out.println(column.name());
    }
}

但我越来越不例外了。我可以确认已将javax-api jar作为依赖项的一部分加载。有人知道我做错了什么吗?

线程“main”java.lang.ClassFormaterror中出现异常:在java.lang.ClassLoader.DefineClass1(native method),在java.security.secureClassLoader.DefineClass(classLoader.java:791),在java.net.urlClassLoader.defineClass(secureClassLoader.java:142),在java.net.urlClassLoader.defineClass(urlClassLoader.java:449),在.urlClassLoader$1.run(urlClassLoader.java:355)在java.security.html" target="_blank">html" target="_blank">accessController.doprivileged(原生方法)在java.net.urlClassLoader.findclass(urlClassLoader.java:354)在java.lang.ClassLoader.loadClass(classLoader.java:423)在sun.misc.launcher$appClassLoader.loadClass(launcher.java:308)在java.lang.class.getDeclaredMethods(Ava:2442)在java.lang.class.getDeclaredMethods(class.java:1808)在sun.reflect.annotation.annotationType$1.run(annotationType.java:104)在sun.reflect.annotation.annotation.annotationType$1.run(annotationType.java:104)在java.security.accessController.doprivileged(原生方法)在sun.reflect.annotation.annotationType.(annotationType.java:100)在java:221)在sun.reflect.annotation.annotation.annotationParser.parseAnnotations2(annotationParser.java:88)在sun.reflect.annotation.annotation.annotationParser.parseAnnotations(annotationParser.java:70)在java.lang.reflect.Method.DeclaredAnnotations(Method.java:699)在java.lang.reflect.Method.getAnnotation(Method.java:685)在

共有1个答案

管景天
2023-03-14

您的jar不包含任何方法体,只包含API规范。这不适合与应用程序一起运行或部署。解压缩jar,在反编译程序中打开该类,您将知道为什么它没有运行。我不确定您是从哪里得到javax-api jar,但您肯定需要这个jar的原始完整版本。

 类似资料:
  • 问题内容: 每当我运行此命令时,该函数就可以正常使用。当我选择洞穴时,消息会每隔2秒弹出一次,然后当它越过该部分时,就会出现错误: 我已经尝试过和,并且在该方法中使用时,出现了很多错误。当我在方法中使用时,它不接受我的输入。 当我在该方法中使用时,它不接受我的字符串输入,而直接进入另一个游戏,但是布尔值返回并且它无限地发送垃圾邮件“ Which Cave …”。 我已经阅读了错误报告,以及类似问题

  • 问题内容: 我正在开发一个访问数据库的项目,但是我遇到了一些问题。我尝试使用hibernate3.2和4.52,但是它不起作用。 例外是在这行代码中 问题答案: 您需要在类路径中检查类org.apache.log4j.Level的冲突版本并进行解决。版本1.2.12或更高版本的log4j jar中提供了TRACE级别。

  • 我最近安装了intellij IDEA 14.0,为了确保一切正常,我创建了一个简单的Hello World程序。我不明白为什么输出不正确,为什么会出现这个错误。如果有人能帮忙,那就太好了。 以下是程序: 这是错误:

  • 问题内容: 当我运行程序进行智能卡读取时,会出现此异常。我的设备未连接。请帮我。 问题答案: 这意味着它无法加载您需要的共享库。这可能是因为。 该库不在您的库路径中。 该库名称不正确,例如,Unix上LIBRARY必须为libLIBRARY.so。 您无法执行该库。 该库不适用于操作系统或JVM的位大小。例如64位JVM将不会加载32位库。 您的JRE未正确安装,并且无法加载其自己的库之一。 您正

  • 我不断收到错误消息: 线程“main”java.lang.NumberFormatException.forInputString(NumberFormatException.java:65)在java.lang.Integer.ParseInt(Integer.java:580)在java.lang.Integer.ParseInt(Integer.java:615)在TestClass.Mai

  • 运行代码后,我收到以下错误 线程 “main” java.time.format.DateTimeParseException 中的异常:文本 '03-09-1999' 无法在 java.base/java.time.format.DateTimeFormatter.parseResolved0(DateTimeFormatter.java:2051) at java.base/java.time