首页 > 解决方案 > 如何检查 *.war 文件的导入?

问题描述

我有一个旧的战争文件,当我的旧机器去世时,源代码丢失了。

它确实与tomcat 8一起运行,没有任何问题。

在我的新机器上,当tomcat(8和9)尝试部署war文件时,它给了我

... 10 更多原因:java.lang.ClassNotFoundException: javafx.scene.image.Image at org.apache.catalina.loader.WebappClassLoaderBase.loadClass(WebappClassLoaderBase.java:1358) at org.apache.catalina.loader.WebappClassLoaderBase .loadClass(WebappClassLoaderBase.java:1180) ... 23 更多

我不记得在我的代码中直接使用过 javafx。

那么,如何检查 *.war 文件的导入以查看导致问题的类或库?

我在示例类上尝试过 javap,但从未看到任何导入。

我知道 javafx 不再是运行时环境的一部分,这显然是问题的直接原因,但是对于这个应用程序,根本不需要 javafx。

标签: javawarjavap

解决方案


在您的 .class 文件上运行javap -v -constants以查看类引用。

您可能希望通过grep "= Class"(Linux) 或findstr "=\ Class"(Windows) 或仅通过管道输出输出grep javafx/ findstr javafx

例如,即使是一个超级简单的“Hello World”程序也使用多个类。

public class Test {
    public static void main(String[] args) {
        System.out.println("Hello World");
    }
}

输出

C:\path\to\classes\classes>javap -v -constants Test.class | grep "= Class"
   #1 = Class              #2             // Test
   #3 = Class              #4             // java/lang/Object
  #17 = Class              #18            // java/lang/System
  #25 = Class              #26            // java/io/PrintStream

它没有显示String. 要了解原因,请查看完整的常量池,对于那个小程序,它是:

Constant pool:
   #1 = Class              #2             // Test
   #2 = Utf8               Test
   #3 = Class              #4             // java/lang/Object
   #4 = Utf8               java/lang/Object
   #5 = Utf8               <init>
   #6 = Utf8               ()V
   #7 = Utf8               Code
   #8 = Methodref          #3.#9          // java/lang/Object."<init>":()V
   #9 = NameAndType        #5:#6          // "<init>":()V
  #10 = Utf8               LineNumberTable
  #11 = Utf8               LocalVariableTable
  #12 = Utf8               this
  #13 = Utf8               LTest;
  #14 = Utf8               main
  #15 = Utf8               ([Ljava/lang/String;)V
  #16 = Fieldref           #17.#19        // java/lang/System.out:Ljava/io/PrintStream;
  #17 = Class              #18            // java/lang/System
  #18 = Utf8               java/lang/System
  #19 = NameAndType        #20:#21        // out:Ljava/io/PrintStream;
  #20 = Utf8               out
  #21 = Utf8               Ljava/io/PrintStream;
  #22 = String             #23            // Hello World
  #23 = Utf8               Hello World
  #24 = Methodref          #25.#27        // java/io/PrintStream.println:(Ljava/lang/String;)V
  #25 = Class              #26            // java/io/PrintStream
  #26 = Utf8               java/io/PrintStream
  #27 = NameAndType        #28:#29        // println:(Ljava/lang/String;)V
  #28 = Utf8               println
  #29 = Utf8               (Ljava/lang/String;)V
  #30 = Utf8               args
  #31 = Utf8               [Ljava/lang/String;
  #32 = Utf8               SourceFile
  #33 = Utf8               Test.java

由于您不需要所有字符串常量,您可以使用grep -v Utf8

   #1 = Class              #2             // Test
   #3 = Class              #4             // java/lang/Object
   #8 = Methodref          #3.#9          // java/lang/Object."<init>":()V
   #9 = NameAndType        #5:#6          // "<init>":()V
  #16 = Fieldref           #17.#19        // java/lang/System.out:Ljava/io/PrintStream;
  #17 = Class              #18            // java/lang/System
  #19 = NameAndType        #20:#21        // out:Ljava/io/PrintStream;
  #22 = String             #23            // Hello World
  #24 = Methodref          #25.#27        // java/io/PrintStream.println:(Ljava/lang/String;)V
  #25 = Class              #26            // java/io/PrintStream
  #27 = NameAndType        #28:#29        // println:(Ljava/lang/String;)V

推荐阅读