Hi, ich habe hier mal einen kleinen Code Ausschnitt
aus einem Programm von mir. Ich kann dateien wie bilder oder txt dateien leicht downloaden.
Aber wenn ich einen zip downloade, klappts nicht, wenn ich ihn zu öffnen versuche ist er erstens nicht vollständig und zweitens nicht öffbar weil die datei nach meinem Windows Explorer nicht korrekt.
Kann mir einer sagen wie man zips downloaden kann mit java, oder was ich bei mir, bei meinem programm ändern soll?
Ich habe auch mal einen DownloadManager geschrieben. Der Besteht aber aus mehreren Dateien mit:
DownloadEntry.java
DownloadEvent.java
DownloadListener.java
DownloadManager.java
DownloadStatusEvent.java
Seine Funktionalitäten:
Erkennt Namen der Datei, man kann sie aber auch umbennen (hängt von der Pfadangabe ab)
einen abgebrochenen Download fortsetzten (kann man auch deaktivieren)
erkennt mimeTypen und Größe der Datei
er kann mehrere Downloads nacheinander abfertigen
Downloads werden als DownloadEntry angelegt und speichern u.a. Quelle und Speicherort
Kennt folgende Events: status(aktueller status, refreshzeit vom User einstellbar), started(Wenn ein DownloadEntry gestartet wird), nextEntry(nächster Download wird gestartet), complete(wenn alle downloads fertig sind)
Ist zwar nicht komplett durchgetestet, aber wenn du willst, stelle ich ihn dir zur verfügung.
MFG
Tomate_Salat
Anmerkung zu deinem Problem: denke es liegt am [c](n = is.read(tmp_buffer)) > 0[/c], da glaube manchmal n 0 sein kann und er mitten drin abbricht. In meinem DownloadManager benutze ich soetwas ähnliches:
[java=259]
while( ( read = in.read()) != -1 )
{
baos.write( read );
if( safeFile ) saos.write( read );
}
[/code]
Das Problem muss nicht am Code liegen. Die Tatsache, dass der gewünschte Inhalt auf Deiner Platte landet, wenn Du im Browser auf einen Link klickst, muss nicht bedeuten, dass auch unmittelbar eine Response 200 mit "Content-type: application/zip" ankommt. Es könnte z. B. auch ein Redirect sein mit <META refresh> oder ein obskures JavaScript, dass dem Browser eine neue "window.location" unterjubelt, ohne dass Du das merkst.
Ich würde mit wireshark erst mal den HTTP-Traffic mitschneiden.
Mein Manager bekommt das aber auch nicht geladen und als MimeType erhält er:
[c]text/html; charset=ISO-8859-1[/c]
und eine Größe von -1 :-/
und öffne ich die Datei(zip) im Editor bekomme ich ne HTML :lol: => Kopierschutz?!
Bennen ich die datei um in eine html sehe ich das Forum mit der Mitteilugn: Sie müssen angemeldet sein xD, also doch anmeldeschutz
oh ja, sry das mit tmp_buffer hatte ich garnicht beachtet :-/. Bin davon ausgegangen du hättest die Doku richtig gelesen und das ganze ByteWeise ausgelesen
oh ja, sry das mit tmp_buffer hatte ich garnicht beachtet :-/. Bin davon ausgegangen du hättest die Doku richtig gelesen und das ganze ByteWeise ausgelesen
und genau um die ginge es mir ja letztendlich, das mit dem byteweisen auslesen habe ich in meinem Manager mitlerweile auch abgeändert (und schau mir das bei der gelegenheit auch mal ein bisschen näher gerade an).
Deswegen habe ich auch nur auf die Schleife geachtet und hätte er die Doku richtig gelesen, ginge es auch mit dem Byteweisen auslesen