3

サーバーでコードをコンパイルしてダウンロードし、コンピューターで実行しようとすると、奇妙なエラーが発生します。

基本的に、EC2 インスタンスでいくつかの Java ファイルをコンパイルし、後で使用するためにそれらをストレージにロードします。

ファイルをコンピューターにダウンロードして実行しようとすると、次のエラーが発生します。

Exception in thread "main" java.lang.ClassFormatError: Incompatible magic value  
     4022320623 in class file HelloWorldPackage/HelloWorldClass
    at java.lang.ClassLoader.defineClass1(Native Method)
    at java.lang.ClassLoader.defineClass(ClassLoader.java:787)
    at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:142)
    at java.net.URLClassLoader.defineClass(URLClassLoader.java:447)
at java.net.URLClassLoader.access$100(URLClassLoader.java:71)
at java.net.URLClassLoader$1.run(URLClassLoader.java:361)
at java.net.URLClassLoader$1.run(URLClassLoader.java:355)
at java.security.AccessController.doPrivileged(Native Method)
at java.net.URLClassLoader.findClass(URLClassLoader.java:354)
at java.lang.ClassLoader.loadClass(ClassLoader.java:423)
at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:308)
at java.lang.ClassLoader.loadClass(ClassLoader.java:356)
at sun.launcher.LauncherHelper.checkAndLoadMain(LauncherHelper.java:476)

次の方法を使用してファイルをコンパイルしています。

public void compileProject()
{


    String command = "javac ";
    for(String s: this.getPackages())
    {
        File[] files = new File("/home/benuni/CompileFiles/" + project + "/src/" + s).listFiles(new FilenameFilter() {
            public boolean accept(File dir, String name) {
                return name.endsWith(".java");
            }
        });

        for(File f: files)
        {
            command = command + f.getAbsolutePath() + " ";
        }
    }

    try {
        System.out.println("command: '"+ command +"'");
        Process pro = Runtime.getRuntime().exec(command);
         printLines(" stderr:", pro.getErrorStream());

        pro.waitFor();

        this.moveClassFiles();
    } catch (IOException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    } catch (InterruptedException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    } catch (Exception e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    }


}

この方法でファイルをアップロードしています:

public void uploadBin()
{
    for(String s: this.getPackages())
    {
        File[] filesInPackage = new File("/home/benuni/CompileFiles/"+this.project+"/bin/"+s).listFiles();

        for(File f: filesInPackage)
        {
            String key = this.project+"/"+this.version+"/bin/"+s+"/"+f.getName();
            s3.putObject("devcloud",key,f);

        }

    }

}

誰かが私が間違っていることを知っていますか? クラスファイルは、コンピューターでコンパイルすると実行可能ですが、クラウドにアップロードしてダウンロードするとエラーが発生しますか?

ありがとう、

ベン

4

3 に答える 3

3

Maven te を使用する場合は、プロジェクトをビルドします。POM ファイルのように、 maven-war-pluginでリソース フィルタリングを無効にしてみてください。<filtering>false</filtering>

<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-war-plugin</artifactId>
<version>2.3</version>
<configuration>
    <webResources>
        <resource>
            <filtering>false</filtering>
            <targetPath>WEB-INF/classes</targetPath>
            <directory>${project.basedir}/target/classes</directory>
        </resource>
    </webResources>
    <filtering>false</filtering>
  </configuration>
</plugin>
于 2016-09-08T17:27:36.970 に答える
2

Java は、期待されるバイト シーケンス ( 0xCAFEBABE)で始まっていないため、有効なクラス ファイルではないことを通知しています。ダウンロード時に問題が発生しました。エディターでクラス ファイルを調べて、実際に他のコンテンツが含まれているかどうかを確認してください。

于 2012-08-24T14:16:30.180 に答える
1

さて、@Asaphがダウンロードがうまくいかないことに言及してくれたおかげで、私はそれを理解しました..

基本的に、ダウンロードは問題ありませんでした。それは私がファイルを書いていた方法でした。

プロジェクトをダウンロードするとき、ソースとバイナリをダウンロードしますが、両方のファイルを同じであるかのように書き込んでいました。

そのため、コードを変更して、ファイルの種類を確認し、必要に応じて適切なライターを使用するようにしました。奇跡によって誰かが同じ問題を抱えているか、似たようなことをしている場合、コードは次のとおりです。

(これは問題を修正するために 5 秒前に書かれたものであり、非常に貧弱に書かれていることに注意してください。自分でリファクタリングしようとしていますが、私はあなたのためにすべてを行うことはできません)

public void download(String project, String version, String location)
{
    for(S3ObjectSummary s: getObjectList())
    {
        String[] data = s.getKey().split("/");
        if(data[0].equals(project) && data[1].equals(version))
        {
            S3Object object = s3.getObject(s3BucketName,s.getKey());
            InputStream input = object.getObjectContent();

            BufferedReader reader = new BufferedReader(new InputStreamReader(input));

            File file = new File(location +"/"+ data[0] + "/" + data[2] + "/" + data[3] + "/" + data[4]);
            if(!file.exists())
            {
                  try {
                      file.getParentFile().mkdirs();
                        file.createNewFile();
                } catch (IOException e) {

                    e.printStackTrace();
                }
            }
            try 
            {
                if(data[4].endsWith(".java"))
                {
                Writer writer = new OutputStreamWriter(new FileOutputStream(file));
                while (true) {          
                     String line = reader.readLine();           
                     if (line == null)
                          break;            

                     writer.write(line + "\n");
                }

                writer.close();
                }
                else if(data[4].endsWith(".class"))
                {
                    System.out.println("Writing Classes");
                    byte[] buffer = new byte[8 * 1024];

                    try {
                          OutputStream output = new FileOutputStream(file.getAbsolutePath());
                          try {
                            int bytesRead;
                            while ((bytesRead = input.read(buffer)) != -1) {
                              output.write(buffer, 0, bytesRead);
                            }
                          } finally {
                            output.close();
                          }
                        } finally {
                          input.close();
                        }
                }

            } catch (FileNotFoundException e) {

                e.printStackTrace();
            } catch (IOException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }


        }
    }
}
于 2012-08-24T14:38:49.057 に答える