Avatar billede zitzo Nybegynder
09. august 2005 - 12:46 Der er 4 kommentarer og
1 løsning

Apache Commons FTPClient laver korrupte filer

Hej

Jeg har levet et lille program som tjekker en mappe på en FTP og henter de rar filer der måtte være i den her mappe. Hvis rar er simpel, fx. med en txt fil i en mappe, kan rar filen sagtens pakkes ud. Men hvis rar filen holder på mapper i mapper med forskellige slags filer, doc, bmp, txt, rar, zip osv. så siger den at den har hentet det hele korrekt men når den skal pakkes ud fejler den. Fejlene er lidt forskellige men jeg ser mest "the file header is corrupt" og "unexpected end of archive".

når en "kompliceret" rar fil bliver hentet går det succesfuldt ifølge retrieveFile og FTPReply.isPositiveCompletion(FTPClient.getReplyCode()) hvilket forekommer mig rimlig underligt.

Jeg har ikke kunne finde nogen former for svar på mit problem... google vil i hvert fald ikke kendes ved det :| ikke andet end at den måde jeg har skrevet det på er korrekt. Men bare for at være 100 smider jeg det lige ind her :)

OutputStream os;
FTPClient client = new FTPClient();

...

client.connect(server);
err = false;
if(client.login(user,pass)){
    PLZIP.sysLog.addTxt("Forbundet til ftp:\\\\"+server,PLZIP.sysLog.bluTxt);
   
    if(client.changeWorkingDirectory(downDir)&&downDir!=null){
        PLZIP.sysLog.addTxt("Skiftet til "+downDir+" mappen",PLZIP.sysLog.bluTxt);
       
        FTPFile[] getFiles = client.listFiles("*."+fileType);
        for(int i = 0;i<getFiles.length; i++){
            PLZIP.sysLog.addTxt("Henter "+getFiles[i].getName(),PLZIP.sysLog.bluTxt);
            String destDir = "c:\\";
            try{
                os = new BufferedOutputStream(new FileOutputStream(new File(destDir+getFiles[i].getName())));
            }catch(FileNotFoundException ev){
                File tmpDirs = new File(destDir);
                PLZIP.sysLog.addTxt("Opretter mappe til "+getFiles[i].getName(),PLZIP.sysLog.greTxt);
                tmpDirs.mkdirs();
                os = new BufferedOutputStream(new FileOutputStream(new File(destDir+getFiles[i].getName())));
            }
            if(client.retrieveFile(getFiles[i].getName(),os)){
               
                if (!FTPReply.isPositiveCompletion(client.getReplyCode())) {
                    System.out.println("could not get file: " + client.getReplyString());
                } else {
                    System.out.println("File " + getFiles[i].getName() + " copied from " + server+" ("+client.getReplyCode()+")");
                }
                PLZIP.sysLog.addTxt(getFiles[i].getName()+" hentet",PLZIP.sysLog.greTxt);
                if(delFiles){
                    PLZIP.sysLog.addTxt("Sletter "+getFiles[i].getName()+" fra FTP",PLZIP.sysLog.bluTxt);
                    client.deleteFile(getFiles[i].getName());
                }
            }else{
                PLZIP.sysLog.addTxt("Kunne ikke hente "+getFiles[i].getName(),PLZIP.sysLog.redTxt);
            }
           
            os.close();
            os = null;
        }
    }else{
        err = true;
        PLZIP.sysLog.addTxt("Kunne ikke skifte til "+downDir+" mappen",PLZIP.sysLog.redTxt);
    }
}else{
    err = true;
    PLZIP.sysLog.addTxt("Kan ikke få adgang, tjek navn og kode",PLZIP.sysLog.redTxt);
}
if(!err){
    PLZIP.sysLog.addTxt("Alle filer hentet",PLZIP.sysLog.greTxt);
}
client.disconnect();
PLZIP.sysLog.addTxt("Forbindelse lukket til "+server,PLZIP.sysLog.bluTxt);

-----------------------------------------------

Så det korte af det lange er.... er der nogen der ved om det er en bug i retreiveFile eller om der er et eller andet man lige skla have på plads inden man kan være 100 på den henter filerne korrekt... eller om der er nogen der kender til en anden ftp package...

hvis der er nogen der har lyst til at teste mit udsagn kan i hente denne rar fil www.zitzo.dk/to_client/28010.rar
den her fil skal virke men det går den ikke hvis jeg bruger mit eget program.
Avatar billede arne_v Ekspert
09. august 2005 - 12:50 #1
jeg kan ikke se en:

client.setFileType(FTPClient.BINARY_FILE_TYPE);

!?!?
Avatar billede arne_v Ekspert
09. august 2005 - 12:50 #2
ja - rar filer er binary !
Avatar billede zitzo Nybegynder
09. august 2005 - 12:52 #3
true that jeg tester lige...
Avatar billede zitzo Nybegynder
09. august 2005 - 12:54 #4
det er fantastisk jeg kan være så utjekket, jeg ahr rodet med det næsten hele dagem... tak igen igen arne :)
Avatar billede arne_v Ekspert
09. august 2005 - 12:54 #5
så ligger jeg et svar
Avatar billede Ny bruger Nybegynder

Din løsning...

Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] Web- og emailadresser omdannes automatisk til links. Der sættes "nofollow" på alle links.

Loading billede Opret Preview
Kategori
Kurser inden for grundlæggende programmering

Log ind eller opret profil

Hov!

For at kunne deltage på Computerworld Eksperten skal du være logget ind.

Det er heldigvis nemt at oprette en bruger: Det tager to minutter og du kan vælge at bruge enten e-mail, Facebook eller Google som login.

Du kan også logge ind via nedenstående tjenester