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

avec Java Discussion :

Erreur "Failed to delete original file [..] after copy to [..]"


Sujet :

avec Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Femme Profil pro
    Développeur Java
    Inscrit en
    Juin 2013
    Messages
    61
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur Java
    Secteur : Finance

    Informations forums :
    Inscription : Juin 2013
    Messages : 61
    Par défaut Erreur "Failed to delete original file [..] after copy to [..]"
    Bonjour,

    Après génération de pdf, de fichiers contenant ces pdf et de documents XML, je souhaite déplacer le tout dans un autre répertoire. Les pdf et fichiers sont bien déplacés dans le répertoire souhaité mais ce qui est des fichier XML j'ai une exception.
    Malgré de mutiples recherches sur le net, et de multiples tests, je ne trouve pas d'où vient mon erreur.
    Voici mon message d'erreur en log:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ... ~ org.apache.commons.lang.UnhandledException: java.io.IOException: Failed to delete original file 'D:\...\LotsPDF\1313520130821165852PDFGENCS1.xml' after copy to 'D:\...\Injection\1313520130821165852PDFGENCS1.xml'

    Voici la partie de code qui lève cette exception:
    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
     
     /**
    ... 
    code qui déplace les pdf et les fichiers les contenants
    ... **/
    Collection<File> outPutXmlFiles = getOutputXmlFiles();
    		LOG.info("nb xml a creer : " + outPutXmlFiles.size() );
     
    		for(File outPutXmlFile : outPutXmlFiles)
     
    		{
    		if(!outPutXmlFile.exists())   
    		        LOG.info(outPutXmlFile.getName() +" INEXISTANT");
    		if(!outPutXmlFile.delete())
        		{
    		        LOG.info(outPutXmlFile.getName() +" NON SUPPRIME");
        		} 
    			File goToFile = new File(moveFolder, outPutXmlFile.getName());
    			FileUtils.deleteQuietly(goToFile);
    			FileUtils.moveFileToDirectory(outPutXmlFile, moveFolder, false);
    			LOG.info("cpt xml move" + outPutXmlFile.getName());
    		}
    	}
    Si une fois de plus je pourrais avoir une piste pour avancer, ce serait bien sympa. Merci par avance.

  2. #2
    Modérateur
    Avatar de joel.drigo
    Homme Profil pro
    Ingénieur R&D - Développeur Java
    Inscrit en
    Septembre 2009
    Messages
    12 430
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur R&D - Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2009
    Messages : 12 430
    Billets dans le blog
    2
    Par défaut
    Salut,

    en général, ce genre de problème arrive lorsqu'on lit les fichiers avec un InputStream (ou écrit avec un OutputStream) qu'on ne ferme pas après la lecture. Un fichier ne peut être effacé tant qu'il reste ouvert.
    L'expression "ça marche pas" ne veut rien dire. Indiquez l'erreur, et/ou les comportements attendus et obtenus, et donnez un Exemple Complet Minimal qui permet de reproduire le problème.
    La plupart des réponses à vos questions sont déjà dans les FAQs ou les Tutoriels, ou peut-être dans une autre discussion : utilisez la recherche interne.
    Des questions sur Java : consultez le Forum Java. Des questions sur l'EDI Eclipse ou la plateforme Eclipse RCP : consultez le Forum Eclipse.
    Une question correctement posée et rédigée et vous aurez plus de chances de réponses adaptées et rapides.
    N'oubliez pas de mettre vos extraits de code entre balises CODE (Voir Mode d'emploi de l'éditeur de messages).
    Nouveau sur le forum ? Consultez Les Règles du Club.

  3. #3
    Membre averti
    Femme Profil pro
    Développeur Java
    Inscrit en
    Juin 2013
    Messages
    61
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur Java
    Secteur : Finance

    Informations forums :
    Inscription : Juin 2013
    Messages : 61
    Par défaut
    Oui c'est ce que à j'avais pensé mais en fait plus, j'ai insancié 2 FileWriter sur lesquels je fais bien un close() dans un finally. (CF le bout de code concerné:

    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
    30
    31
    32
    33
    final String path= ("sourceFolderPath/")+file.getName();
                         final File fichier = new File(path);
     
                         //On crée un fichier de même nom+_KO pour avoir une trace des lignes qui ne permettront pas la génération de pdf
                         final File fichierKO=new File("errorFolderPath/"+ file.getName().substring(0, ext)+"_KO.csv");
                         try {
                             final FileWriter writer = new FileWriter(fichier);
                             final FileWriter writerKO = new FileWriter(fichierKO);
                             try {
                                 //Réécriture des lignes OK dans le fichier csv initial
                                 for(Iterator<String> iter = ListLigneOK.iterator();iter.hasNext();)
                                     writer.write(iter.next()+ LINE_SEPARATOR);
                                 writer.flush();
     
                                 //Ecriture des lignes KO dans un fichiers créé: nomFic_KO.csv
                                 for(Iterator<String> iter = ListLigneKO.iterator();iter.hasNext();)
                                     writerKO.write(iter.next()+ LINE_SEPARATOR);
                                 writerKO.flush();
                                 } 
                             finally {
                                 writer.close();//on ferme le fichier
                                 writerKO.close();
     
                                 }
                         } catch (Exception e){
                                 LOG.info("Problème lors de l'écriture des lignes valides dans le fichier " + file.getName());
                             }
                         }//fin du try
     
                    finally
                        {   
                            lnr.close();//libération des ressourses
                          }
    Mais je ne pense pas que le problème vienne d'ici car ce fichier est un .csv qui est bien déplacé dans un nouveau répertoire alors que mon pb vient des .xml générés plus bas dans le code et pour lesquels il est impossible de les déplacer.

  4. #4
    Modérateur
    Avatar de joel.drigo
    Homme Profil pro
    Ingénieur R&D - Développeur Java
    Inscrit en
    Septembre 2009
    Messages
    12 430
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur R&D - Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2009
    Messages : 12 430
    Billets dans le blog
    2
    Par défaut
    L'erreur d'effacement est sur des fichiers xml, et tu mets un extrait de code qui concerne des csv ; en plus les dossiers utilisés ne correspondent pas à ce qu'on voit dans le message d'erreur. Le problème n'est donc probablement pas là.

    C'est le code qui traite le fichier xml indiqué dans le message d'erreur qu'il serait intéressant de voir. Il sert à quoi ce fichier ? De source pour créer un pdf ? Il est généré en complément du pdf ?

    Peux tu supprimer ce fichier en dehors de ton appli (en laissant ton appli "ouverte", premièrement, puis ensuite, après que ton appli soit arrêtée) ?
    L'expression "ça marche pas" ne veut rien dire. Indiquez l'erreur, et/ou les comportements attendus et obtenus, et donnez un Exemple Complet Minimal qui permet de reproduire le problème.
    La plupart des réponses à vos questions sont déjà dans les FAQs ou les Tutoriels, ou peut-être dans une autre discussion : utilisez la recherche interne.
    Des questions sur Java : consultez le Forum Java. Des questions sur l'EDI Eclipse ou la plateforme Eclipse RCP : consultez le Forum Eclipse.
    Une question correctement posée et rédigée et vous aurez plus de chances de réponses adaptées et rapides.
    N'oubliez pas de mettre vos extraits de code entre balises CODE (Voir Mode d'emploi de l'éditeur de messages).
    Nouveau sur le forum ? Consultez Les Règles du Club.

  5. #5
    Modérateur
    Avatar de joel.drigo
    Homme Profil pro
    Ingénieur R&D - Développeur Java
    Inscrit en
    Septembre 2009
    Messages
    12 430
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur R&D - Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2009
    Messages : 12 430
    Billets dans le blog
    2
    Par défaut
    Question annexe : sous quel os et environnement ton programme s'exécute-t-il ?


    J'ai rencontré un problème similaire (mais tous les fichiers étaient concernés, pas seulement certains) sous Windows 8 avec disque ssd : le programme générait des fichiers temporaires, faisait un traitement, puis les effaçait. L'indexeur Windows cherchait à les indexer, et l'effacement échouait parce que le fichier était encore "pris" par l'indexeur : j'ai retiré le dossier de fichiers temporaires de l'indexation pour résoudre le problème.

    Pour détecter le problème, j'ai utilisé ProcessMonitor de sysinternals. Ca peut peut être également t'aider à voir si ton fichier est encore ouvert lors de l'effacement, si tu es sous Windows, bien sûr.
    L'expression "ça marche pas" ne veut rien dire. Indiquez l'erreur, et/ou les comportements attendus et obtenus, et donnez un Exemple Complet Minimal qui permet de reproduire le problème.
    La plupart des réponses à vos questions sont déjà dans les FAQs ou les Tutoriels, ou peut-être dans une autre discussion : utilisez la recherche interne.
    Des questions sur Java : consultez le Forum Java. Des questions sur l'EDI Eclipse ou la plateforme Eclipse RCP : consultez le Forum Eclipse.
    Une question correctement posée et rédigée et vous aurez plus de chances de réponses adaptées et rapides.
    N'oubliez pas de mettre vos extraits de code entre balises CODE (Voir Mode d'emploi de l'éditeur de messages).
    Nouveau sur le forum ? Consultez Les Règles du Club.

  6. #6
    Membre averti
    Femme Profil pro
    Développeur Java
    Inscrit en
    Juin 2013
    Messages
    61
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur Java
    Secteur : Finance

    Informations forums :
    Inscription : Juin 2013
    Messages : 61
    Par défaut
    Oui c'est ce que j'indiquai, la partie du code qui pose problème est dans mon 1er post.

    Pour répondre à tes questions, je suis effectivement sous windows 7 (même si mon dev sera ammené à tourner sous unix par la suite.
    Je ne connais pas du tout ProcessMonitor, je vais essayer de voir ça...

  7. #7
    Expert éminent
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 482
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : Belgique

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 482
    Par défaut
    Ton premier code, c'est la partie delete. On voulais voir la partie où tu écrit dans ces fichiers xml pour être sûr qu'ils sont bien fermés.

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

Discussions similaires

  1. Erreur "Failed to load properties file for project"
    Par el_kamal dans le forum Android
    Réponses: 4
    Dernier message: 31/08/2011, 00h26
  2. [PEAR][DB] Erreur : CONNECT FAILED
    Par prog2003 dans le forum Bibliothèques et frameworks
    Réponses: 2
    Dernier message: 20/04/2007, 10h06
  3. Erreur après compilation : cannot execute binary file
    Par Djo00 dans le forum Administration système
    Réponses: 8
    Dernier message: 21/07/2006, 16h26

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