Android HTTPClient vs HttpUrlConnection vs Socket Verständnisproblem

newbie2009

Bekanntes Mitglied
Hey Leute,

ich habe ein kleines Verständnisproblem, hinsichtlich der Nutzung des DefaultHttpClients, der HttpUrlConnection und von Sockets.

Was ich bisher rausgefunden habe:

Der HttpClient ist depreceated und man sollte auf die HttpUrlConnection ausweichen. In meinem Test war diese auch schneller. Mir stellt sich allerdings die Frage warum das so ist ? Liegt das vllt daran, dass die HttpUrlConnection versucht eine keep-alive connection by default zu erstellen? Ich weiß nicht ob es beim HttpClient auch der Fall ist.


Weiterhin besteht auch die Möglichkeit der Socketnutzung, um TCP basierte Nachrichten auszutauschen. Nun stellt sich mir die Frage warum sollte man dieses Nutzen wenn HttPClient und HttpUrlConnection doch auch auf dem TCP aufsetzen.

Naja ich hoffe jemand kann ein wenig Licht in meine verwirrte Androidwelt reinbringen, thx im voraus :)

mfg newbie
 

schlingel

Gesperrter Benutzer
Der HttpClient ist depreceated und man sollte auf die HttpUrlConnection ausweichen.
Abenteuerliche Behauptung. Kannst du das auch belegen? In der Doku ist's jedenfalls nicht deprecated gekennzeichnet.

In meinem Test war diese auch schneller. Mir stellt sich allerdings die Frage warum das so ist?
Weil du alles selbst handlen musst was so üblichen HTTP-Protokolablauf angeht. Also ein redirect wird nicht von der Klasse abgewickelt, Multiform-Uploads sind ein ziemliches Herumärgern, etc. Du bist einfach näher am Metall.

Liegt das vllt daran, dass die HttpUrlConnection versucht eine keep-alive connection by default zu erstellen? Ich weiß nicht ob es beim HttpClient auch der Fall ist.
Soweit ich weis schon. Allerdings mit Timeout. Du kannst das aber auch manuell steuern. Siehe Doku dazu. Ob das denn tatsächlich so der Grund ist warum das schneller ist wage ich einmal zu bezweifeln.

Weiterhin besteht auch die Möglichkeit der Socketnutzung, um TCP basierte Nachrichten auszutauschen. Nun stellt sich mir die Frage warum sollte man dieses Nutzen wenn HttPClient und HttpUrlConnection doch auch auf dem TCP aufsetzen.
Der Vergleich ist mehr wie der Vergleich warum du denn nicht ein Elektroauto mit einem Elektromotor bauen solltest wenn du doch eh Bahn fahren kannst. HTTP ist selbst ein Protokol das auf TCP aufbaut. Da schleppst du also Komplexität mit die du vielleicht nicht brauchst. Gerade was Performance angeht, kann es sein, dass ein eigenes Protokoll etwas bringt.

Da man heutzutage aber meistens über Webservices arbeitet nimmt man diesen kleinen Performancepenaltie gerne in Kauf, da dass das Debuggen auch einfacher macht. Geht ja dann auch mit dem fiddler oder ähnlichen Sniffern.
 

newbie2009

Bekanntes Mitglied
Hey Danke schon mal für deine Antwort,

Abenteuerliche Behauptung. Kannst du das auch belegen? In der Doku ist's jedenfalls nicht deprecated gekennzeichnet.

mit der Kennzeichnung als deprecated hast du recht, allerdings finden sich folgende Hinweise :


Code:
Since Google has deprecated HttpClient in favor of Java standard HttpURLConnection I created a script to convert a stock release of Apache's HttpClient into an Android library.
(Quelle: java - Apache http client or URLConnection - Stack Overflow ) Und hier allerdings indirekt:

Code:
 New applications should use HttpURLConnection; it is where we will be spending our energy going forward.
(Quelle: Android Developers Blog: Android’s HTTP Clients)


Der Vergleich ist mehr wie der Vergleich warum du denn nicht ein Elektroauto mit einem Elektromotor bauen solltest wenn du doch eh Bahn fahren kannst. HTTP ist selbst ein Protokol das auf TCP aufbaut. Da schleppst du also Komplexität mit die du vielleicht nicht brauchst. Gerade was Performance angeht, kann es sein, dass ein eigenes Protokoll etwas bringt.

Da hast du irgendwo natürlich Recht, stand irgendwie aufm Schlauch, trotzdem hat die Kombination SOAP+TCP bei mir bisher nicht besser abgeschnitten als SOAP und HTTP( Vllt liegt es auch an meinen Messmethoden).
In Android führe ich meine TCP mittels Sockets nach dem folgenden Muster aus :


Java:
		    String path = "/services/soap/";
		    BufferedWriter writer = new BufferedWriter(new OutputStreamWriter(socket.getOutputStream(), "UTF8"));
		    
		   
		    
		    
		    

       	    
		    writer.write("POST " + path + " HTTP/1.1\r\n");
            writer.write("Host: api.flickr.com\r\n");
            writer.write("Content-Length: " + xml.length() + "\r\n");
            writer.write("Content-Type: text/xml; charset=\"utf-8\"\r\n");
            writer.write("\r\n");

            //Send data
            writer.write(xml);
            writer.flush();
		   

// get response....


Wie du siehst, versende ich hier doch auch zahlreiche HttpParameter. Ich weiß, dass die Kombination SOAP+TCP effizienter ist, aber es fällt mir schwer es irgendwie bildlich vorzustellen, weil ich eben diese Http-Infors mit versende.



Und zum letzten Punkt:
Geht ja dann auch mit dem fiddler oder ähnlichen Sniffern.

Ich verwende Fiddler, allerdings zeigt dieser keine TCP-Anfragen an, kannst du vllt noch eine schlanke Variante wie Fiddler empfehlen? Wireshark ist mir zu umfangreich und irgendwie viel zu umständlich.


Vielen Dank im Voraus

mfg newbie
 
Zuletzt bearbeitet:

schlingel

Gesperrter Benutzer
Naja, in SO kann jeder alles reinschreiben. Das macht's nicht richtiger, dass HttpClient deprecated ist. Den Google Blog kann man allerdings schon ernst nehmen. Ich hab den auch vor einiger Zeit gelesen, als ich meinen Code von HttpClient auf UrlConnection umgestellt habe. (Bei mir war das ganze dann mehr als doppelt so schnell!)

Aber Achtung: Da gibt's so einige Tücken, da vor Android 2.2 die UrlConnection buggy ist. Steht ja auch in dem Blog-Beitrag.

Nein, was besseres bzw. einfacheres als Wireshark kenne ich nicht, da ich mit Wireshark sehr zufrieden bist. Wenn du die IP-Filter einstellst und auf follow TCP Stream klickst, bekommst du den ganzen Inhalt angezeigt.

So, warum ist dein Code performanter als der HttpClient oder die UrlConnection-Klasse?

Ganz einfach: Du hast überhaupt nichts extra, du schreibst einfach Strings in einen Stream und machst dann zu. In den anderen Klassen passiert noch anderes. Fehlerbehandlung, Standardwerte für den HTTP-Header, etc. Das passiert ja bei dir gar nicht. Außerdem ist bei den anderen Varianten mehr als eine Klasse im Spiel, da kommen also noch die Kosten für das Auflösen der Referenzen ins Spiel. (Sind aber sehr gering.)
 

newbie2009

Bekanntes Mitglied
Naja, in SO kann jeder alles reinschreiben. Das macht's nicht richtiger, dass HttpClient deprecated ist. Den Google Blog kann man allerdings schon ernst nehmen. Ich hab den auch vor einiger Zeit gelesen, als ich meinen Code von HttpClient auf UrlConnection umgestellt habe. (Bei mir war das ganze dann mehr als doppelt so schnell!)

Da hast du wiederum Recht, deshalb habe ich zur Sicherheit hier nochmal nachgefragt :) Naja bei mir ist die UrlConnection minimal schneller :)





So, warum ist dein Code performanter als der HttpClient oder die UrlConnection-Klasse?

Ganz einfach: Du hast überhaupt nichts extra, du schreibst einfach Strings in einen Stream und machst dann zu. In den anderen Klassen passiert noch anderes. Fehlerbehandlung, Standardwerte für den HTTP-Header, etc. Das passiert ja bei dir gar nicht. Außerdem ist bei den anderen Varianten mehr als eine Klasse im Spiel, da kommen also noch die Kosten für das Auflösen der Referenzen ins Spiel. (Sind aber sehr gering.)

Macht Sinn :)

Nein, was besseres bzw. einfacheres als Wireshark kenne ich nicht, da ich mit Wireshark sehr zufrieden bist. Wenn du die IP-Filter einstellst und auf follow TCP Stream klickst, bekommst du den ganzen Inhalt angezeigt.

Ja habe wieder bisschen rumgespielt und mit den Filtereinstellungen lässt es sich auch damit arbeiten, benutze noch zusätzliche den Microsoft Network Monitor, ist etwas schlanker und einfacher zu bedienen :)

Noch eine letzte Frage zum Abschluss: Also ich versuche eine HttpUrlConnection wiederzuverwenden, da ja standardmäßig die Verbindung offen gehalten wird. Wie kann ich mittels Wireshark denn feststellen ob eine Verbindung auch tatsächlich gehalten wird. Meinem Verständnis nach müsste doch dann einfach alle nachfolgenden Anfragen im bestehenden TCP Stream( wenn ich mittels follow tcp-stream" den stream verfolge) auftauchen oder nicht? Oder bin ich da auf der falschen Spur?

mfg newbie
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
J Benachrichtigung Freigabe ab Android 14 Android & Cross-Platform Mobile Apps 1
J Android Benachrichtigung zum Zeitpunkt ers Android & Cross-Platform Mobile Apps 15
J Das Beispiel von Android erzeugt Fehler Android & Cross-Platform Mobile Apps 8
J Zeitdifferenzen unter Android 7 (API < 26) berechnen Android & Cross-Platform Mobile Apps 4
W Netzwerk Verbindungen Java Android Android & Cross-Platform Mobile Apps 107
Z Android IntelliJ Android & Cross-Platform Mobile Apps 2
M Repository bei Room-Database in Android Studio (Java) Android & Cross-Platform Mobile Apps 2
Android App auf das eigene Handy bekommen Android & Cross-Platform Mobile Apps 3
Alex IV Android App erstellen Android & Cross-Platform Mobile Apps 3
OnDemand CrossPlatform Kotlin iOs/Android Datenverbrauch Android & Cross-Platform Mobile Apps 2
W In Android Studio Integer an andere activities übergeben Android & Cross-Platform Mobile Apps 2
wladp Android Studio Room Database Android & Cross-Platform Mobile Apps 1
N "Schöne" Datatable in Android und setzen von Parametern von Textview im Code Android & Cross-Platform Mobile Apps 5
N Android game programmieren Android & Cross-Platform Mobile Apps 5
T Android Studio: Einen Button in einer For Schleife verwenden Android & Cross-Platform Mobile Apps 2
K BLE Komunikation mit Android studio und esp32 Android & Cross-Platform Mobile Apps 5
G Android UDP Kommunikation Android & Cross-Platform Mobile Apps 1
M Paper DB wird in Android Studio nicht erkannt Android & Cross-Platform Mobile Apps 7
J Android zugrif auf Thread nach Handy drehen. Android & Cross-Platform Mobile Apps 10
T Android Android Augmented Faces in Java. Neue Landmarks erstellen Android & Cross-Platform Mobile Apps 1
K Android Android In-App-Purchase lädt nicht Android & Cross-Platform Mobile Apps 0
Besset Android http request an interne ip adresse funktioniert nicht Android & Cross-Platform Mobile Apps 8
J Is Android Development Head First Outdated? Android & Cross-Platform Mobile Apps 3
J Android Android Datenbankverbindung zum Raspberry Pi Android & Cross-Platform Mobile Apps 1
lolcore Android Studio -Download Documentation for Android SDK Android & Cross-Platform Mobile Apps 0
S Sinnvollste weg eine SQLite DB mit Android auslesen Android & Cross-Platform Mobile Apps 7
W Problem mit Android Studio Android & Cross-Platform Mobile Apps 0
W App Abo Android Android & Cross-Platform Mobile Apps 10
OSchriever Android Android MediaPlayer bei Anruf stoppen/pausieren Android & Cross-Platform Mobile Apps 2
OSchriever Auf onClick-Listener reagieren und Parameter übergeben (Android Studio) Android & Cross-Platform Mobile Apps 4
W removeNetwork Android App mit Spendenaktion fürs Tierheim! Android & Cross-Platform Mobile Apps 1
T Android R.string.test+i Problem Android & Cross-Platform Mobile Apps 2
P undefinierbarer Fehler Android Android & Cross-Platform Mobile Apps 8
T Android ArrayList sortieren mit 2 Werten ohne thencomparing , Wie? Android & Cross-Platform Mobile Apps 10
W Variable überschreiben (Android Studio) Android & Cross-Platform Mobile Apps 2
ruutaiokwu Android Selbst entwickelter SMTP-Client läuft auf PC, nicht aber auf Android Android & Cross-Platform Mobile Apps 9
ruutaiokwu Android Warum muss man bei Android Studio immer 2x auf "Run" klicken damit die App auf dem Gerät startet Android & Cross-Platform Mobile Apps 8
ruutaiokwu Android Wo das 'android.useAndroidX' property hinzufügen? Android & Cross-Platform Mobile Apps 8
ruutaiokwu Android In einem Android-“Spinner”-Element GLEICHZEITIG Bild (links) UND Text (rechts) anzeigen Android & Cross-Platform Mobile Apps 0
P Login und Registrierung Android Anzeige Android & Cross-Platform Mobile Apps 7
S Von JavaFx zu Android Android & Cross-Platform Mobile Apps 12
K Android to Pi | Websocket Problem Android & Cross-Platform Mobile Apps 3
ruutaiokwu Wie fügt man bei Android Studio .jar-Libraries zu einem Android-Java-Projekt hinzu? Android & Cross-Platform Mobile Apps 33
M Komponenten positionieren in Android Studio 3.6.3 Android & Cross-Platform Mobile Apps 1
M Android Studio - Property-Fenster einblenden Android & Cross-Platform Mobile Apps 1
M Android Studio - App auf dem Smartphone testen Android & Cross-Platform Mobile Apps 7
M Barrierefreie Appentwicklung für Android - Suche Codebeispiele Android & Cross-Platform Mobile Apps 8
M Android Studio - Configuration fehlt Android & Cross-Platform Mobile Apps 20
M Wo kann ich das Android SDK herunterladen / wie kann ich es installieren Android & Cross-Platform Mobile Apps 3
M Unsupported class file major version 57 - Fehlermeldung bei Android Studio Android & Cross-Platform Mobile Apps 27
ruutaiokwu Android Studio (SDK) ANDROID_SDK_ROOT-Variable? Android & Cross-Platform Mobile Apps 5
O Web API in Android (JAVA) einbinden Android & Cross-Platform Mobile Apps 3
J Android Studio macht seltsame Sachen Android & Cross-Platform Mobile Apps 2
J Android 9.1 aber android Studio findet API22 Android & Cross-Platform Mobile Apps 0
Dimax Web-Seite in native app convertieren mit Android Studio Android & Cross-Platform Mobile Apps 8
A Android Studio: while-Schleife beginnt nicht Android & Cross-Platform Mobile Apps 5
lolcore android studio: fehler bei laden des emulators Android & Cross-Platform Mobile Apps 10
J Android App - Browser öffnen und Text eingeben/Button click auslösen Android & Cross-Platform Mobile Apps 10
A Android-Studio: 2. Layout nach kurzer Zeit aufzeigen Android & Cross-Platform Mobile Apps 2
A jpg wird im Android Studio nicht akzeptiert Android & Cross-Platform Mobile Apps 3
J Android Studio - ArrayList - Selected Item ermitteln Android & Cross-Platform Mobile Apps 13
T Android SDK-Manager startet nicht in Eclipse Android & Cross-Platform Mobile Apps 5
T Bringen mir die Java-Basics irgendetwas für die Android-Programmierung Android & Cross-Platform Mobile Apps 4
J Was soll das bedeuten ? does not require android.permission.BIND_JOB_SERVICE permission Android & Cross-Platform Mobile Apps 7
A Android Studio: ImageView verpixelt Android & Cross-Platform Mobile Apps 2
J intend Service im Android Studio Android & Cross-Platform Mobile Apps 4
L Android Android Development eventuell mit Flutter Android & Cross-Platform Mobile Apps 1
S Android Layout - welchen Typ? Android & Cross-Platform Mobile Apps 3
T Fehler Android Studio: java.net.MalformedURLException: no protocol: http%3A%2F%2Fwww.mal ..... Android & Cross-Platform Mobile Apps 2
Arif Android Android Studio: Fehler beim Einbinden fremder Bibliothek? Android & Cross-Platform Mobile Apps 2
L Android Android Contacts DB auslesen Android & Cross-Platform Mobile Apps 1
A Android Studio - App mit Nearby Android & Cross-Platform Mobile Apps 1
L Android content URI Datei einlesen Android & Cross-Platform Mobile Apps 9
N Android Game Background Service Android & Cross-Platform Mobile Apps 11
Jackii Android Android Studio Error im Testlauf ohne zu programmieren Android & Cross-Platform Mobile Apps 9
B Android Probleme mit Android Studio Android & Cross-Platform Mobile Apps 6
Excess Android Service läuft nicht in Sandby weiter Android & Cross-Platform Mobile Apps 2
B Android Projekt für Android und IOS erstellen? Android & Cross-Platform Mobile Apps 5
J App funktioniert auf Android 5, auf 6 nicht Android & Cross-Platform Mobile Apps 2
J Android Snake Android & Cross-Platform Mobile Apps 15
J Android TaschenRechner Android & Cross-Platform Mobile Apps 22
I Das Problem mit der Tastatur... android:windowSoftInputMode="adjustPan" Android & Cross-Platform Mobile Apps 1
E Wie erhalte ich Zugriff auf das Microfon? (Android Studio) Android & Cross-Platform Mobile Apps 9
C Android Programmierung speziell oder einfach Java Buch kaufen? Android & Cross-Platform Mobile Apps 3
B Android Kein Zugriff auf Telefonspeicher (Android 6) Android & Cross-Platform Mobile Apps 1
T Android Equalizer für Android Android & Cross-Platform Mobile Apps 3
L Android Android Studio - Exportierte APK funktioniert nicht Android & Cross-Platform Mobile Apps 6
L Android Methode funktioniert nicht unter Android Android & Cross-Platform Mobile Apps 3
A Beginnen mit Serverkommunikatsion in Android Studio Android & Cross-Platform Mobile Apps 6
E Android Studio Android & Cross-Platform Mobile Apps 15
L Android Android Studio Setup killt Explorer Android & Cross-Platform Mobile Apps 3
K Android Videos rendern Android & Cross-Platform Mobile Apps 1
J Variable in strings.xml (Android Studio) Android & Cross-Platform Mobile Apps 0
B Android Android Studio lässt PC abstürzen Android & Cross-Platform Mobile Apps 3
B Android App Fehler Android & Cross-Platform Mobile Apps 21
J android Spinner funktioniert nicht Android & Cross-Platform Mobile Apps 14
G Android Push Notification Android & Cross-Platform Mobile Apps 2
Light Lux Fehlermeldung unter Android Studio Android & Cross-Platform Mobile Apps 1
D Android Android Apps direkt vom Handy aus programmieren? Android & Cross-Platform Mobile Apps 2
L Android Android Kalendar Tag Ansicht Android & Cross-Platform Mobile Apps 1

Ähnliche Java Themen

Neue Themen


Oben