Чтение файлов из банки, не работающей в затмении - PullRequest
1 голос
/ 05 марта 2012

Новичок здесь, я впервые публикую здесь, поэтому постараюсь исправить это, извините за любые ошибки заранее.

Я пытался читать файлы из папок внутри фляги и добавлять их пути в массив строк. Моя папка jar выглядит следующим образом: .class файлы расположены в FileIO.jar \ com \ yumeprojects \ flowdemonstration \ изображения находятся в FileIO.jar \ com \ yumeprojects \ flowdemonstration \ images \

когда я запускаю программу из скомпилированного jar-файла вне затмения, результат будет точным, будет найдено 5 изображений и их пути добавлены в массив. это вывод:

E:\Yumeprojects 2011-2012\File IO tests>java -jar "FileIO0_2.jar"
(file:/E:/Yumeprojects%202011-2012/File%20IO%20tests/FileIO0_2.jar <no signer ce
rtificates>)
com/yumeprojects/flowdemonstration/test/bakgrund01.png
com/yumeprojects/flowdemonstration/test/bakgrund02.png
com/yumeprojects/flowdemonstration/test/bakgrund03.png
com/yumeprojects/flowdemonstration/test/bakgrund04.png
com/yumeprojects/flowdemonstration/test/bakgrund05.png
Number of images: 5

Когда я бегу из затмения, я получаю это:

(file:/E:/Yumeprojects%202011-2012/Project%20Mathematics/flow/bin/ <no signer certificates>)
Number of images: 0

Код выглядит так и не мой, я скопировал его с этого сайта.

package com.yumeprojects.flowdemonstration;

import java.io.File;
import java.io.IOException;
import java.net.URL;
import java.security.CodeSource;
import java.util.ArrayList;
import java.util.List;
import java.util.zip.ZipEntry;
import java.util.zip.ZipInputStream;

public class Main {

   String[] fileNames;
   CodeSource src = Main.class.getProtectionDomain().getCodeSource();
   List<String> list = new ArrayList<String>();

   public static void main(String[] args){
      Main m = new Main();
      m.init();
   }

   public void init(){
      try {
         read();
      } catch (IOException e) {
         // TODO Auto-generated catch block
         e.printStackTrace();
      }
   }



   public void read() throws IOException{
      if(src != null){
         URL jar = src.getLocation();
         System.out.println(jar);

          ZipInputStream zip = new ZipInputStream(jar.openStream());
          System.out.println(zip);

          System.out.println(zip.getNextEntry());

          ZipEntry ze = null;
          ZipEntry ze2 = null;
          while((ze = zip.getNextEntry()) != null){
              String entryName = ze.getName();

              if(entryName.endsWith(".png") || entryName.endsWith(".PNG") ) {
                  list.add(entryName);
                  System.out.println(entryName);
              }
          }
      }
      fileNames = list.toArray(new String[list.size() ] );
      System.out.println("Number of images: " + fileNames.length);
    } 
}

Почему этот код не работает в Eclipse? Нужен ли файл JAR для выполнения внутри? Если да, как мне заставить eclipse выполнить его, чтобы я мог работать с этим кодом в eclipse и получить те же результаты, что и я, если бы я запустил его из jar вне eclipse?

Пожалуйста, помогите

// Kurten

EDIT Поскольку комментарии были не очень хороши для разбора кода, я проанализирую его здесь Syso выглядит так изнутри затмения:

file:/E:/Yumeprojects%202011-2012/Project%20Mathematics/flow/bin/
java.util.zip.ZipInputStream@a62fc3
null
Number of images: 0

и снаружи:

E:\Yumeprojects 2011-2012\File IO tests>java -jar "FileIO0_3.jar"
file:/E:/Yumeprojects%202011-2012/File%20IO%20tests/FileIO0_3.jar
java.util.zip.ZipInputStream@649e4dc0
META-INF/MANIFEST.MF
com/yumeprojects/flowdemonstration/test/bakgrund01.png
com/yumeprojects/flowdemonstration/test/bakgrund02.png
com/yumeprojects/flowdemonstration/test/bakgrund03.png
com/yumeprojects/flowdemonstration/test/bakgrund04.png
com/yumeprojects/flowdemonstration/test/bakgrund05.png
Number of images: 5

E:\Yumeprojects 2011-2012\File IO tests>

ВТОРОЕ РЕДАКТИРОВАНИЕ: Это рабочий код! Это не красиво, и структура кода все к черту, но она делает то, что должна делать. Спасибо Гийому Полю за помощь в этом!

package com.yumeprojects.flowdemonstration;

import java.io.File;
import java.io.IOException;
import java.net.URI;
import java.net.URISyntaxException;
import java.net.URL;
import java.security.CodeSource;
import java.util.ArrayList;
import java.util.List;
import java.util.zip.ZipEntry;
import java.util.zip.ZipInputStream;

public class Main {

   String[] fileNames;
   CodeSource src = Main.class.getProtectionDomain().getCodeSource();
   List<String> list = new ArrayList<String>();
   URL jar;
   URI jar2;
   File source;
   String[] images;
   static boolean inIDE;

   public static void main(String[] args){
      if(args.length > 0){
          for(int i = 0; i < args.length; i++){
              if(args[i].equalsIgnoreCase("inIDE")){
                  inIDE = true;
              }
          }
      }
      Main m = new Main();
      m.init();
   }

   public void init(){
      try {
         read();
      } catch (IOException e) {
         // TODO Auto-generated catch block
         e.printStackTrace();
      }
   }



   public void read() throws IOException{

       if(src != null){
         jar = src.getLocation();

         if(inIDE){
             try {
                jar2 = new URI(jar.toURI().toString() + "/com/yumeprojects/flowdemonstration/test");
            } catch (URISyntaxException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
            System.out.println(jar2);
            source = new File(jar2);
            images = source.list();
            for(int i = 0; i < images.length; i++){
                 System.out.println(images[i]); 
            }
         }else{
             System.out.println(jar); 
             ZipInputStream zip = new ZipInputStream(jar.openStream());
             System.out.println(zip);
             System.out.println(zip.getNextEntry());

              ZipEntry ze = null;

              while((ze = zip.getNextEntry()) != null){
                  String entryName = ze.getName();

                  if(entryName.endsWith(".png") || entryName.endsWith(".PNG") ) {
                      list.add(entryName);
                      System.out.println(entryName);
                  }
              }
              fileNames = list.toArray(new String[list.size() ] );
              System.out.println("Number of images: " + fileNames.length);
         }




      }

    } 
}

1 Ответ

0 голосов
/ 05 марта 2012

Что ж, ошибка, как я уже говорил в моем предыдущем комментарии: в Eclipse URL-адрес указывает на папку с файлом, а при выполнении из упакованного jar-файла URL-адрес указывает на ваш jar-файл.Создание ZipInputStream для папки, конечно, не имеет смысла.

Один из способов исправить ваш код - поиск конца URL:

Если он заканчивается на .jar, то вы можете сохранитьваш реальный код.

Если это не так, вам нужен рекурсивный метод для поиска ваших файлов.Преобразуйте ваш URL в URI (toURI()), а затем создайте объект File.Затем рекурсивно сканируйте эту папку и ищите ваши файлы, как и раньше.

Это может работать для вас в этой ситуации, но я не думаю, что оно охватывает все возможности, поэтому это определенно лучшее решение.

Кроме того, мне не нравится эта идея, чтобы очень разные коды выполняли одну и ту же задачу в зависимости от того, находится ли она на стадии разработки или на стадии разработки.Возможно, вам следует попытаться найти другой подход к вашей проблеме.У некоторых людей могут быть лучшие решения для вас.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...