IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Langage Java Discussion :

Copie de fichier


Sujet :

Langage Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé Avatar de Katachana
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    755
    Détails du profil
    Informations personnelles :
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations forums :
    Inscription : Avril 2007
    Messages : 755
    Par défaut Copie de fichier
    Bonjour,

    Je souhaite lister des fichiers txt contenu dans un jar et puis ensuite les copier en local.


    Pour récupérer la liste des fichier txt pas de souci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    Enumeration<JarEntry> entries = jarfile.entries();
          while(entries.hasMoreElements()) {
              JarEntry entry = (JarEntry)entries.nextElement();
              if(entry.getName().endsWith(".txt")){
                  FileUtil.copyFile(entry.getName(),entry.getName());
              }
          }

    Ensuite j'ai une erreur dans la méthode copyFile, au niveau de l'inputStream (Le fichier spécifié est introuvable).... C'est surement un probleme de path, mais je n'y vois plus grand chose


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
     
        public static void copyFile (String input, String output){
     
            FileChannel in = null; // canal d'entrée
            FileChannel out = null; // canal de sortie
     
            try {
                // Init
                in = new FileInputStream(input).getChannel();
                out = new FileOutputStream(output).getChannel();
     
                // Copie depuis le in vers le out
                in.transferTo(0, in.size(), out);
              } catch (Exception e) {
                e.printStackTrace(); // n'importe quelle exception
              } finally { // finalement on ferme
                if(in != null) {
                  try {
                    in.close();
                  } catch (IOException e) {}
                }
                if(out != null) {
                  try {
                    out.close();
                  } catch (IOException e) {}
                }
              }
     
        }

    Merci d'avance !

  2. #2
    Membre Expert
    Profil pro
    Inscrit en
    Août 2006
    Messages
    3 276
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2006
    Messages : 3 276
    Par défaut
    A mon avis ce que tu essaies de faire ne marchera pas.
    Il faut plutôt lire ton fichier .txt à partir d'un JarInputStream avec la méthode read(byte[] b, int off, int len) et utiliser getNextJarEntry() .

  3. #3
    Expert éminent
    Avatar de adiGuba
    Homme Profil pro
    Développeur Java/Web
    Inscrit en
    Avril 2002
    Messages
    13 938
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Java/Web
    Secteur : Transports

    Informations forums :
    Inscription : Avril 2002
    Messages : 13 938
    Billets dans le blog
    1
    Par défaut
    Salut,



    Pour commencer quelques remarques sur ta méthode copyFile :
    • Le catch(Exception) n'est pas très propre car il pourrait te cacher des erreurs de programmation (nullpointer ou autre). Il est préférable de se limiter aux IOException...
    • Personnellement j'aurais même tendance à laisser remonter l'IOException, car il n'y a rien permettant de détecter une erreur de copie lorsqu'on appelle ta méthode.
    • Plutôt qu'un grand finally avec des if et des try/catch pas très propre, je te conseillerais d'utiliser un finally contenant uniquement le close, mais de le faire pour chaque flux.


    En clair, sans remonter d'exception cela donnerait ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
        public static void copyFile (String input, String output){
     
        	try {
    	        FileChannel in = new FileInputStream(input).getChannel(); // canal d'entrée
    	        try {
    	        	FileChannel out = new FileOutputStream(output).getChannel(); // canal de sortie
    	        	try {
    	        		in.transferTo(0, in.size(), out);
    	        	} finally {
    	        		out.close();
    	        	}
    	        } finally {
    	        	in.close();
    	        }
        	} catch (IOException e) {
        		e.printStackTrace();
        	}
        }

    Quand à ton problème, il vient du fait que tu considères les éléments d'une archive comme un fichier standard. Or ce n'est pas le cas : il ne s'agit pas d'un fichier présent directement sur le système de fichier (il est inconnu de l'OS), donc tu ne peux pas l'ouvrir avec un FileInputStream.

    Du coup tu ne peux même pas utiliser les FileChannel tu dois faire la copie à la main, ce qui n'est pas très compliqué en soit :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    	public static void copy(InputStream in, OutputStream out) throws IOException {
    		byte[] buf = new byte[8192];
    		int len;
    		while ( (len=in.read(buf)) >= 0 ) {
    			out.write(buf, 0, len);
    		}
    	}
    En fait pour accéder au contenu de l'élément d'une archive, tu dois utiliser la méthode getInputStream() du JarFile.

    Tu devrais donc avoir une méthode de la sorte :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    	public static void copy(JarFile jarFile, JarEntry entry, String outputFileName) throws IOException {
    		InputStream in = jarFile.getInputStream(entry);
    		try {
    			OutputStream out = new FileOutputStream(outputFileName);
    			try {
    				copy(in, out);
    			} finally {
    				out.close();
    			}
    		} finally {
    			in.close();
    		}
    	}

    a++

  4. #4
    Membre éclairé Avatar de Katachana
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    755
    Détails du profil
    Informations personnelles :
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations forums :
    Inscription : Avril 2007
    Messages : 755
    Par défaut
    Merci beaucoup !!

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Copie de fichier sur le bureau
    Par LoicH dans le forum C++Builder
    Réponses: 3
    Dernier message: 01/05/2005, 20h57
  2. [C#] Copie de fichier via l'API
    Par slyv dans le forum Windows Forms
    Réponses: 5
    Dernier message: 20/12/2004, 22h39
  3. [C#] Copie de fichier via l'API
    Par slyv dans le forum Windows
    Réponses: 5
    Dernier message: 20/12/2004, 22h35
  4. [Kylix] Copie de fichier...
    Par paty.olivier dans le forum EDI
    Réponses: 1
    Dernier message: 23/06/2004, 12h55
  5. Copie de fichier
    Par Bjorn dans le forum C
    Réponses: 4
    Dernier message: 11/06/2002, 15h23

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo