2 Netzwerkprogrammierung in Java
|
|
|
- Hildegard Ursler
- vor 7 Jahren
- Abrufe
Transkript
1 2 Netzwerkprogrammierung in Java In package java.net Vorläufige Version 31 c 2006 Peter Thiemann
2 2.1 Internet-Adressen (IP-Adressen) Internet-Adresse = vier Oktette (je 8 Bit) jedes direkt mit dem Internet verbundene Endgerät besitzt eindeutige Internet-Adresse maximal 2 32 = Endgeräte (überhöht, da Adressraum strukturiert und teilweise reserviert) 0nnnnnnn. H. H. H class A Netzwerk 10nnnnnn. N. H. H class B Netzwerk 110nnnnn. N. N. H class C Netzwerk 1110nnnn... class D Netzwerk (Multicast) 1111nnnn... class E Netzwerk (Experimentell) Beispiele WWW-Server der Uni Freiburg WWW-Server der Informatik localhost (eigener Rechner, für Experimente) Vorläufige Version 32 c 2006 Peter Thiemann
3 Zukünftige IP-Adressen: IPv6 [RFC 2060] Befürchtung: IPv4 Adressraum bald erschöpft daher: 128bit IP-Adressen [RFC 2373] viele Konzepte eingebaut bzw vorgesehen selbständige Adresskonfiguration (mobiler Zugang) quality of service Garantieen möglich Authentisierung, Datenintegrität, Vertraulichkeit Schreibweise: 4er Gruppen von Hexziffern 1080:0:0:0:8:800:200C:417A 1080::8:800:200C:417A a unicast address... compressed Vorläufige Version 33 c 2006 Peter Thiemann
4 2.2 Die Klasse java.net.inetaddress Objekte repräsentieren IP-Adressen Subklassen für IPv4 und IPv6 kein öffentlicher Konstruktor, stattdessen public static InetAddress[] getallbyname(string host) throws UnknownHostException sämtliche IP-Adressen von host public String gethostaddress() liefert die IP-Adresse als Text public static InetAddress getlocalhost() throws UnknownHostException IP-Adresse des lokalen Rechners Vorläufige Version 34 c 2006 Peter Thiemann
5 Beispiel: DomainName2IPNumbers import java.net.*; public class DomainName2IPNumbers { public static void main(string[] args) { try { InetAddress[] a = InetAddress.getAllByName(args[0]); for (int i = 0; i<a.length; i++) System.out.println(a[i].getHostAddress()); catch (UnknownHostException e) { System.out.println("Unknown host!"); /* > java DomainName2IPNumbers */ Vorläufige Version 35 c 2006 Peter Thiemann
6 import java.net.*; Beispiel: Eigene Adresse public class MyAddress { public static void main(string[] args) { try { InetAddress a = InetAddress.getLocalHost(); System.out.println("domain name: "+a.gethostname()); System.out.println("IP address: "+a.gethostaddress()); catch (UnknownHostException e) { System.out.println("Help! I don t know who I am!"); /* > java MyAddress domain name: abacus.informatik.uni-freiburg.de IP address: */ Vorläufige Version 36 c 2006 Peter Thiemann
7 2.3 Sockets Ein Socket (Steckdose) ist eine Datenstruktur zur Administration von (Netzwerk-) Verbindungen. An jedem Ende einer Verbindung ist ein Socket erforderlich. Es gibt sie in mehreren Dimensionen: Aktivität Client Socket: Verbindung mit existierendem Dienst Server Socket: Stellt Dienst zur Verfügung Verbindungsart UDP (Datagram, unidirektional) TCP (Stream, bidirektional) Vorläufige Version 37 c 2006 Peter Thiemann
8 Sockets und Ports Ports Prozess Sockets Bindung Vorläufige Version 38 c 2006 Peter Thiemann
9 2.3.1 Klasse java.net.socket für Clients Socket Konstruktoren Socket (InetAddress address, int port) Verbindung zum Server auf address und port Socket (String host, int port) { Socket (InetAddress.getByName (host), port); Verbindung zum Server host und port auch ein Client Socket ist auf dem lokalen Rechner an einen (meist beliebigen) Port gebunden Vorläufige Version 39 c 2006 Peter Thiemann
10 Socket Methoden OutputStream getoutputstream() throws IOException Ausgabe auf diesem Strom wird zum Server gesendet (Anfragen an den Server) InputStream getinputstream() throws IOException Eingaben von diesem Stream stammen vom Server (Antworten des Servers) void close() throws IOException Schließen des Sockets Vorläufige Version 40 c 2006 Peter Thiemann
11 2.3.2 Beispiel class HTTPGet { public static void main (String[] args) throws Exception { if (args.length!= 2) { System.out.println ("Usage: java HTTPGet host path"); else { String hostname = args[0]; String path = args[1]; Socket s = new Socket (hostname, 80); PrintWriter out = new PrintWriter (s.getoutputstream (), true); // send request out.print ("GET "+path+" HTTP/1.1\r\n"); out.print ("Host: "+hostname+"\r\n"); out.print ("\r\n"); // read & echo response System.out.println (" "); in = new BufferedReader (new InputStreamReader (s.getinputstream ())); String line = in.readline (); while (line!= null) { System.out.println (line); line = in.readline (); // may hang for a while System.out.println (" "); Vorläufige Version 41 c 2006 Peter Thiemann
12 2.3.3 Klasse java.net.serversocket Konstruktoren ServerSocket (int port) throws IOException Erzeugt einen Socket für Verbindungen über port. Dient nur zum Verbindungsaufbau. Wichtige Methoden Socket accept() throws IOException Wartet am port des ServerSocket auf eine (externe) Verbindung. Liefert einen gewöhnlichen Socket für die Abwicklung der Kommunikation. void close() throws IOException Schließt den ServerSocket Vorläufige Version 42 c 2006 Peter Thiemann
13 2.3.4 Beispielserver Das Interface DialogHandler trennt die Handhabung der Verbindung von der Abwicklung der Kommunikation. import java.io.*; public interface DialogHandler { false to exit the server loop boolean talk (BufferedReader br, PrintWriter pw); Vorläufige Version 43 c 2006 Peter Thiemann
14 Beispiel Implementierung import java.net.*; import java.io.*; public class TCPServer { ServerSocket ss; public TCPServer (int port) throws IOException { ss = new ServerSocket (port); public void run (DialogHandler dh) throws IOException { boolean acceptingconnections = true; while (acceptingconnections) { Socket s = ss.accept (); BufferedReader br = new BufferedReader (new InputStreamReader (s.getinputstream ())); PrintWriter pw = new PrintWriter (s.getoutputstream (), true); acceptingconnections = dh.talk (br, pw); s.close (); Vorläufige Version 44 c 2006 Peter Thiemann
15 DialogHandler für BackTalk public class BackTalkDialog implements DialogHandler { public boolean talk (BufferedReader br, PrintWriter pw) { String line = null; BufferedReader terminal = new BufferedReader (new InputStreamReader (System.in)); while (true) { try { if (br.ready ()) { line = br.readline (); System.out.println (line); else if (terminal.ready ()) { line = terminal.readline (); if (line.equals ("STOP!")) { break; pw.println (line); catch (IOException ioe) { return false; return false; // stop the server Vorläufige Version 45 c 2006 Peter Thiemann
16 Beispiel ein handbetriebener Server import java.net.*; import java.io.*; public class BackTalk { public static void main (String[] arg) throws Exception { if (arg.length!= 1) { System.out.println ("Usage: BackTalk port"); else { try { int port = new Integer (arg[0]).intvalue (); TCPServer server = new TCPServer (port); server.run (new BackTalkDialog ()); catch (RuntimeException e) { System.out.println ("Argument not an integer"); Vorläufige Version 46 c 2006 Peter Thiemann
17 2.4 Verbindungen über URLs URL (Uniform Resource Locator) RFC 1738, RFC 1808, RFC 2368 Symbolische Adresse für ein Dokument Format: Schema : schemaspezifische Information Mögliche Schemata und schemaspezifische Informationen mailto: Internet-Mailadresse Beispiel: mailto:[email protected] http: // User : Host : Port / URL-Path Dabei sind optional User : : Port Beispiel: ftp: // User : Host : Port / Path Auch hier sind User, Password und Port Informationen optional. Beispiel: ftp://ftp.informatik.uni-freiburg.de/iif news: Newsgruppe Nicht alle Zeichen sind im schemaspezifischen Anteil einer URL erlaubt (vgl. RFC), sie werden URL-kodiert durch % hexdigit hexdigit, die Hexadezimaldarstellung der Nummer des Zeichens. (Siehe Klasse java.net.urlencoder.) Vorläufige Version 47 c 2006 Peter Thiemann
18 2.4.1 Klasse URL Wichtige Konstruktoren URL(String spec) throws MalformedURLException parst den String spec und falls erfolgreich erstellt ein URL Objekt. Wichtige Methoden URLConnection openconnection() throws IOException liefert ein Objekt, über das 1. die Parameter der Verbindung gesetzt werden 2. die Verbindung hergestellt wird 3. die Verbindung abgewickelt wird Vorläufige Version 48 c 2006 Peter Thiemann
19 2.4.2 Klasse URLConnection abstrakte Klasse, daher keine Konstruktoren Wichtige Methoden Methoden zum Setzen von Anfrageparametern (Request-Header für HTTP): setusecaches, setifmodifiedsince, setrequestproperty,... void connect() Herstellen der Verbindung Methoden zum Abfragen von Antwortparametern (Response-Header für HTTP): getcontentencoding, getcontentlength, getheaderfield,... InputStream getinputstream() zum Lesen von der Verbindung Object getcontent () zum Parsen von der Verbindung in ein passendes Objekt kann selbst bestimmt werden: setcontenthandlerfactory Vorläufige Version 49 c 2006 Peter Thiemann
20 2.4.3 Klasse HttpURLConnection extends URLConnection abstrakte Klasse, daher keine Konstruktoren Wichtige Methoden Setzen von HTTP-spezifischen Anfrageparametern static void setfollowredirects(boolean set) Standardwert: true void setrequestmethod(string method) (method ist GET, HEAD, POST,...) Abfagen von HTTP-spezifischen Antwortparametern int getresponsecode() String getresponsemessage() InputStream geterrorstream () Vorläufige Version 50 c 2006 Peter Thiemann
21 Beispiel: Inhalt eines Dokuments als byte[] public class RawURLContent { private URLConnection uc; public RawURLContent (URL u) throws IOException { uc = u.openconnection (); public byte[] getcontent () throws IOException { int len = uc.getcontentlength (); if (len <= 0) { System.err.println ("Length cannot be determined"); return new byte[0]; else { byte[] rawcontent = new byte [len]; uc.getinputstream ().read (rawcontent); return rawcontent; Vorläufige Version 51 c 2006 Peter Thiemann
22 Beispiel: I m Feeling Lucky import java.net.*; import java.io.*; public class ImFeelingLucky2 { public static void main(string[] args) { try { String req = " "q="+urlencoder.encode(args[0], "UTF8")+"&"+ "btni="+urlencoder.encode("i m Feeling Lucky", "UTF8"); HttpURLConnection con = (HttpURLConnection) (new URL(req)).openConnection(); con.setrequestproperty("user-agent", "IXWT"); con.setinstancefollowredirects(false); String loc = con.getheaderfield("location"); if (loc!=null) System.out.println("Direct your browser to "+loc); else System.out.println("I am sorry - my crystal ball is blank."); catch (IOException e) { System.err.println(e); Vorläufige Version 52 c 2006 Peter Thiemann
23 2.5 SSL Verbindungen JSSE (Java Secure Socket Extension) import javax.net.ssl.* Wesentliche Pattern) Änderung im Client Programm: (Factory Ersetze Socket s = new Socket (hostname, portnumber) durch SSLSocketFactory sf = (SSLSocketFactory)SSLSocketFactory.getDefault(); SSLSocket s = (SSLSocket)sf.createSocket(hostname, portnumber); Dafür muss SSL konfiguriert sein (siehe unten). Vorläufige Version 53 c 2006 Peter Thiemann
24 SSLSocketFactory SocketFactory Socket static SocketFactory getdefault() abstract Socket createsocket(...) InputStream getinputstream() OutputStream getoutputstream() SSLSocketFactory SSLSocket abstract void starthandshake() Vorläufige Version 54 c 2006 Peter Thiemann
25 SSL Server Sockets Wesentliche Ersetze Änderung im Server Programm: durch ServerSocket ss = new ServerSocket (portnumber) //... Socket con = ss.accept () SSLServerSocketFactory sf = (SSLServerSocketFactory)SSLServerSocketFactory.getDefault(); SSLServerSocket ss = (SSLServerSocket)sf.createServerSocket(portnumber); //... SSLSocket con = (SSLSocket)ss.accept(); Vorläufige Version 55 c 2006 Peter Thiemann
26 Konfiguration von SSL: Zertifikate Keystore erzeugen self signed Zertifikat erz. certificate signing request Trust Center $$$$$ Exportieren des self signed Zertifikats trust assertion Truststore erzeugen unterschriebenes Zertifikat aktivieren Vorläufige Version 56 c 2006 Peter Thiemann
27 Erzeugen des Key Store > keytool -genkey -alias widgetorg -keyalg RSA -validity 7 -keystore serverkey.jks Enter keystore password: ToPsEcReT What is your first and last name? [Unknown]: What is the name of your organizational unit? [Unknown]: Web Division What is the name of your organization? [Unknown]: Widget Inc. What is the name of your City or Locality? [Unknown]: Punxsutawney What is the name of your State or Province? [Unknown]: Pennsylvania What is the two-letter country code for this unit? [Unknown]: US Is CN= OU=Web Division, O=Widget Inc., L=Punxsutawney, ST=Pennsylvania, C=US correct? [no]: yes Enter key password for <widgetorg> (RETURN if same as keystore password): Schlüsselpaar, Self-Signed Zertifikat in serverkey.jks Vorläufige Version 57 c 2006 Peter Thiemann
28 Certificate Signing Request > keytool -certreq -alias widgetorg -keystore serverkey.jks -keyalg RSA -file widgetorg.csr Enter keystore password: ToPsEcReT Einsenden von widgetorg.csr an certificate authority Zurück: unterschriebenes Zertifikat widgetorg.cer, Zertifikat der certificate authority ca.cer Trust Assertion > keytool -import -alias root -keystore serverkey.jks -trustcacerts -file ca.cer Enter keystore password: ToPsEcReT Certificate was added to keystore Dieser Schritt kann übersprungen werden, falls certificate authority bereits bekannt Vorläufige Version 58 c 2006 Peter Thiemann
29 Zertifikat aktivieren > keytool -import -alias widgetorg -keystore serverkey.jks -file widgetorg.cer Enter keystore password: ToPsEcReT Certificate was added to keystore Zertifikat verwenden > java -Djavax.net.ssl.keyStore=serverkey.jks -Djavax.net.ssl.keyStorePassword=ToPsEcReT MySecureServer 8443 Falls certificate authority allgemein bekannt, kann jeder Client eine Verbindung herstellen Vorläufige Version 59 c 2006 Peter Thiemann
30 Alternative: self-signed Zertifikat akzeptieren Exportiere das self-signed Zertifikat nach Konstruktion des key stores: > keytool -export -keystore serverkey.jks -alias widgetorg -file widgetorgself.cer Enter keystore password: ToPsEcReT Certificate stored in file <widgetorgself.cer> Erzeuge dann einen trust store, der alle vertrauenswürdigen Schlüssel enthält. > keytool -import -alias widgetorg -file widgetorgself.cer -keystore truststore.jks Enter keystore password: HuShHuSh Owner: CN= OU=Web Division, O=Widget Inc., L=Punxsutawney, ST=Pennsylvania, C=US Issuer: CN= OU=Web Division, O=Widget Inc., L=Punxsutawney, ST=Pennsylvania, C=US Serial number: Valid from: Wed Apr 20 14:59:33 CEST 2005 until: Wed Apr 27 14:59:33 CEST 2005 Certificate fingerprints: MD5: 4D:A7:09:CB:1A:8E:5F:91:5E:7A:2F:F1:CD:16:B6:4F SHA1: C6:90:05:6D:1D:B8:B1:5D:C9:83:BF:9F:79:2C:FD:28:54:58:B9:D6 Trust this certificate? [no]: yes Certificate was added to keystore Verwendung in einem Client mit > java -Djavax.net.ssl.trustStore=truststore.jks -Djavax.net.ssl.trustStorePassword=HuShHuSh MySecureClient 8443 Vorläufige Version 60 c 2006 Peter Thiemann
31 import java.net.*; import java.io.*; import javax.net.ssl.*; import java.security.cert.*; Wenn was schief geht... class CertificationPath { public static void main (String[] args) { try { // Create the client socket int port = 443; String hostname = args[0]; SSLSocketFactory factory = HttpsURLConnection.getDefaultSSLSocketFactory(); SSLSocket socket = (SSLSocket)factory.createSocket(hostname, port); // Connect to the server socket.starthandshake(); Vorläufige Version 61 c 2006 Peter Thiemann
32 // Retrieve the server s certificate chain java.security.cert.certificate[] servercerts = socket.getsession().getpeercertificates(); for (int i=0; i<servercerts.length; i++) { System.out.println("Server certificate type: "+servercerts[i].gettype()); if (servercerts[i] instanceof X509Certificate) { X509Certificate c = (X509Certificate)serverCerts[i]; System.out.println(" Subject: "+c.getsubjectdn()); System.out.println(" Issuer: "+c.getissuerdn()); // Close the socket socket.close(); catch (SSLPeerUnverifiedException e) { catch (IOException e) { Vorläufige Version 62 c 2006 Peter Thiemann
33 2.6 UDP Sockets Wichtig: UDP Ports TCP Ports Java API: Zwei Klassen DatagramPacket repräsentiert ein Datenpaket (zum Versenden oder nach dem Empfang) DatagramSocket repräsentiert die eigentliche Verbindung Klasse java.net.datagrampacket nur Aufbau von Datenstruktur, keine Verbindung! Wichtige Konstruktoren DatagramPacket(byte[] buf, int length) zum Empfang von length Bytes in buf DatagramPacket(byte[] buf, int length, InetAddress address, int port) vorbereitet zum Versenden von length Bytes aus buf an address und port Beachte: die Adresse des Ziels befindet sich im Paket! Vorläufige Version 63 c 2006 Peter Thiemann
34 Wichtige Methoden java.nat.datagrampacket Empfangen Senden byte[] getdata() int getlength() InetAddress getaddress() int getport() void setdata(byte[] buf) void setlength(int length) void setaddress(inetaddress iaddr) void setport(int iport) Vorläufige Version 64 c 2006 Peter Thiemann
35 Klasse java.net.datagramsocket Wichtige Konstruktoren DatagramSocket() DatagramSocket(int port) Wichtige Methoden void send(datagrampacket p) throws IOException void receive(datagrampacket p) throws IOException void close() Vorläufige Version 65 c 2006 Peter Thiemann
36 Ablauf Senden s = new DatagramSocket (); p = new DatagramPacket (b,l); p.setaddress (...); p.setport (...); p.setdata (...); s.send (p); Empfangen s = new DatagramSocket (myport); p = new DatagramPacket (b,l); s.receive (p); result = p.getdata (); sender = p.getaddress (); seport = p.getport (); Vorläufige Version 66 c 2006 Peter Thiemann
37 Beispiel ein Client für daytime RFC 867 public class Daytime { static final int BUFSIZE = 128; static final int DAYTIME = 13; // portnumber of daytime service //... public static String gettime (String hostname) throws Exception { byte[] buffer = new byte[bufsize]; InetAddress server = InetAddress.getByName (hostname); DatagramPacket answer = new DatagramPacket (buffer, BUFSIZE); DatagramSocket s = new DatagramSocket (); answer.setaddress (server); answer.setport (DAYTIME); s.send (answer); // contents do not matter s.receive (answer); s.close (); int len = answer.getlength (); buffer = answer.getdata (); while (buffer[len-1] == 10 buffer[len-1] == 13) { len--; return new String (buffer, 0, len); Vorläufige Version 67 c 2006 Peter Thiemann
38 Beispiel ein Server für daytime RFC 867 public class DaytimeServer { static final int BUFSIZE = 128; static final int DAYTIME = 13; // portnumber for daytime service //... public static void servetime (int port) throws Exception { byte[] buffer = new byte[bufsize]; DatagramPacket p = new DatagramPacket (buffer, BUFSIZE); DatagramSocket s = new DatagramSocket (port); // while (true) { s.receive (p); // contents do not matter Date d = new GregorianCalendar ().gettime (); System.out.println ("Sending: " + d); String answer = d.tostring (); p.setdata ((answer + "\r\n").getbytes ()); p.setlength (answer.length () + 2); s.send (p); // s.close (); Vorläufige Version 68 c 2006 Peter Thiemann
39 2.7 UDP vs. TCP Application Application-layer protocol Underlying Transport Protocol electronic mail SMTP TCP remote terminal access Telnet TCP Web HTTP TCP file transfer FTP TCP remote file server NFS typically UDP streaming multimedia proprietary typically UDP Internet telephony proprietary typically UDP Network Management SNMP typically UDP Routing Protocol RIP typically UDP Name Translation DNS typically UDP Vorläufige Version 69 c 2006 Peter Thiemann
40 2.8 DNS, ein Paket-Protokoll Hintergrund: RFC Technische Beschreibung: RFC 1035 DNS: Abbildung von Domainnamen auf Resource Records (RR) Ein Domainname ist Folge von Strings (Labels), getrennt durch und beendet mit. Maximale Länge eines Labels: 63 Maximale Länge eines Domainnamen: 255 (inkl. der Punkte) Menge der Domainnamen ist Hierarchie mit Wurzel.. de. uni-freiburg.de. informatik.uni-freiburg.de. Typen von Resource Records (Ausschnitt): A NS CNAME SOA PTR MX host address authoritative name server canonical name for an alias zone of authority domain name pointer mail exchanger Vorläufige Version 70 c 2006 Peter Thiemann
41 Grundidee DNS ist verteilte Datenbank, in der jeder Server zuständig (authoritativ) für eine bestimmte Domain ist. Abfrage der Datenbank: UDP Nachricht an beliebigen Server. Abgleich zwischen den Servern: TCP Verbindungen Beispielsitzung nslookup ist ein textuelles Werkzeug für DNS-Anfragen, kontaktiert Port domain (53) mit UDP shell> /usr/sbin/nslookup - Default Server: atlas.informatik.uni-freiburg.de Address: Alle folgenden Fragen beziehen sich auf Address RRs: > set q=a > Server: atlas.informatik.uni-freiburg.de Address: Name: falcon.informatik.uni-freiburg.de Address: Aliases: Vorläufige Version 71 c 2006 Peter Thiemann
42 Frage nach Nameserver RRs: unix> nslookup - > set q=ns > informatik.uni-freiburg.de. Server: atlas.informatik.uni-freiburg.de Address: informatik.uni-freiburg.de nameserver = dns1.fun.uni-freiburg.de informatik.uni-freiburg.de nameserver = tolkien.imtek.uni-freiburg.de informatik.uni-freiburg.de nameserver = atlas.informatik.uni-freiburg.de informatik.uni-freiburg.de nameserver = dns0.fun.uni-freiburg.de dns1.fun.uni-freiburg.de internet address = tolkien.imtek.uni-freiburg.de internet address = atlas.informatik.uni-freiburg.de internet address = dns0.fun.uni-freiburg.de internet address = Vorläufige Version 72 c 2006 Peter Thiemann
43 Für Deutschland: > de. Server: atlas.informatik.uni-freiburg.de Address: Non-authoritative answer: de nameserver = s.de.net. de nameserver = z.nic.de. de nameserver = a.nic.de. de nameserver = c.de.net. de nameserver = f.nic.de. de nameserver = l.de.net. Authoritative answers can be found from: s.de.net internet address = z.nic.de has AAAA address 2001:628:453:4905::53 z.nic.de internet address = a.nic.de internet address = c.de.net internet address = f.nic.de internet address = f.nic.de has AAAA address 2001:608:6::5 l.de.net internet address = Vorläufige Version 73 c 2006 Peter Thiemann
44 Reverse Query (IP-Adresse Domainname): > set q=ptr > Server: atlas.informatik.uni-freiburg.de Address: in-addr.arpa name = willi.informatik.uni-tuebingen.de in-addr.arpa nameserver = dns1.belwue.de in-addr.arpa nameserver = dns1.uni-tuebingen.de in-addr.arpa nameserver = dns3.belwue.de in-addr.arpa nameserver = mx01.uni-tuebingen.de in-addr.arpa nameserver = macon.informatik.uni-tuebingen.de in-addr.arpa nameserver = snoopy.informatik.uni-tuebingen.de dns1.belwue.de internet address = dns1.uni-tuebingen.de internet address = dns3.belwue.de internet address = mx01.uni-tuebingen.de internet address = macon.informatik.uni-tuebingen.de internet address = snoopy.informatik.uni-tuebingen.de internet address = Vorläufige Version 74 c 2006 Peter Thiemann
45 2.8.2 Ablauf eines DNS-lookup user_query() resolver local NS root NS.edu NS.mit.edu NS rec_query() query() edu. NS for edu. query() mit.edu. NS for mit.edu. query() A for A for A for Vorläufige Version 75 c 2006 Peter Thiemann
46 2.8.3 Benutzerperspektive User Program user queries Resolver queries Foreign Name Server user responses cache additions queries responses cache references Cache Vorläufige Version 76 c 2006 Peter Thiemann
47 2.8.4 Primary und Secondary Server Master Files user queries Primary Server queries Foreign Name Server user responses zone transfer responses transfer requests Secondary Name Server Vorläufige Version 77 c 2006 Peter Thiemann
48 2.8.5 Recursive Queries Simple Resolver rec. queries Recursive Server queries Foreign Name Server responses cache additions queries responses cache references Cache Foreign Name Server Vorläufige Version 78 c 2006 Peter Thiemann
49 2.8.6 Format eines Domainnamens Folge von Strings (Labels), getrennt durch und beendet mit. Maximale Länge eines Labels: 63 Maximale Länge eines Domainnamen: 255 (inkl. der Punkte) Interne Darstellung: Ein Oktet Länge des Labels, gefolgt von den Zeichen des Labels, wiederholt bis Nulloktet (Label der Länge Null) Beispiel: informatik.uni-freiburg.de 10 informatik 12 uni freiburg 2 de 0 Vorläufige Version 79 c 2006 Peter Thiemann
50 2.8.7 Internes Format eines Resource Record Feldname Größe/Oktetts Beschreibung NAME 2n Domainname für den das Record gilt TYPE 2 Kode für TYPE CLASS 2 Kode für CLASS TTL 4 Time to Live, Gültigkeitsdauer/Sek. RDLENGTH 2 Anzahl der Oktetts im RDATA Feld RDATA 2d Inhalt je nach TYPE und CLASS Kodes für TYPE (Ausschnitt) A 1 Host Address NS 2 authoritative name server CNAME 5 canonical name for an alias SOA 6 zone of authority PTR 12 domain name pointer MX 15 mail exchanger Kodes für CLASS (Ausschnitt) IN 1 Internet Vorläufige Version 80 c 2006 Peter Thiemann
51 2.8.8 Format einer Nachricht Header Question Answer Authority Additional Anfrage an den Name-Server Antworten des Servers Zeiger auf autorisierten Name-Server weitere Information Header immer vorhanden Answer, Authority und Additional enthalten je eine Liste von Resource Records (RR) maximale Länge 512 Oktetts Vorläufige Version 81 c 2006 Peter Thiemann
52 Header 12 Oktette mit folgendem Inhalt ID QR Opcode AA TC RD RA Z RCODE QDCOUNT ANCOUNT NSCOUNT ARCOUNT wobei ID QR identifier erzeugt vom Client 0= Frage, 1= Antwort Opcode Art der Anfrage 0= Standard-Anfrage (QUERY) 1= Inverse Anfrage (IQUERY) 2= Status-Anfrage (STATUS) 3 15 reserviert AA TC RD 1= Authoritative Answer 1= Truncated (abgeschnitten) 1= Recursion Desired (Wunsch vom Client) Vorläufige Version 82 c 2006 Peter Thiemann
53 RA 1= Recursion Available (Anzeige vom Server) Z immer 0 RCODE Response Code 0 kein Fehler 1 Formatfehler 2 Serverfehler 3 Gesuchter Name existiert nicht (nur falls AA) 4 nicht implementiert 5 Anfrage abgelehnt 6 15 reserviert QDCOUNT ANCOUNT NSCOUNT ARCOUNT Anzahl der Einträge in Question Anzahl der Resource Records in Answer Anzahl der Name-Server Resource Records in Authority Anzahl der Resources Records in Additional Vorläufige Version 83 c 2006 Peter Thiemann
3.5 SSL Verbindungen. JSSE (Java Secure Socket Extension) import javax.net.ssl.* Wesentliche Pattern) Änderung im Client Programm: (Factory.
3.5 SSL Verbindungen JSSE (Java Secure Socket Extension) import javax.net.ssl.* Wesentliche Pattern) Änderung im Client Programm: (Factory Ersetze Socket s = new Socket (hostname, portnumber) durch SSLSocketFactory
3 Netzwerkprogrammierung in Java
3 Netzwerkprogrammierung in Java In package java.net Vorläufige Version 64 c 2005 Peter Thiemann 3.1 Internet-Adressen (IP-Adressen) Internet-Adresse = vier Oktette (je 8 Bit) jedes direkt mit dem Internet
Programmierzertifikat Objekt-Orientierte Programmierung mit Java
Programmierzertifikat Objekt-Orientierte Programmierung mit Java Vorlesung 10: Netzwerk Peter Thiemann Universität Freiburg, Germany SS 2008 Peter Thiemann (Univ. Freiburg) Programmierzertifikat Objekt-Orientierte
Netzwerkprogrammierung & Threads
& Threads Praktikum aus Softwareentwicklung 2 Netzwerp. - 1 & Threads URL, URLConnection, UDP, TCP Threads Parallele Programme, Synchronisation, Netzwerp. - 2 Grundlagen (1/2) Kommunikation zwischen verteilten
Advanced Network Programming
1 Advanced Network Programming Inhalt Netzwerkkommunikation Protokolle Verbindungsaufbau, -kontrolle, Datentransfer Socketprogrammierung TPC und UDP Client- und Serversockets verbindungsorientierte Server
TCP und UDP Sockets in Java
TCP und UDP Sockets in Java Grundlegende Mechanismen Server reserviert Port: Klient: - Server: bind Server nimmt Verbindungswünsche an Klient: - Server: listen Klient möchte sich verbinden Klient: connect;
Verbindungen zu mehreren Clients. Informatik B - Objektorientierte Programmierung in Java. Vorlesung 23: Netzwerkprogrammierung/ Kommunikation 2
Universität Osnabrück 1 Verbindungen zu mehreren Clients 3 - Objektorientierte Programmierung in Java Vorlesung 23: Netzwerkprogrammierung/ Kommunikation 2 Wie könnte das bereits vorgestellte Programm
Java und Netzwerkkommunikation
Java und Netzwerkkommunikation Ziel: Kommunikation über Rechnergrenzen hinweg Grundlagen Sockets in Java Java-Netzwerk-Einführung Seite 1 Grundbegriffe Senden und Empfangen von Daten! Frau B Herr A Sender
Intern: DNSSec Secure DNS
Intern: DNSSec Secure DNS Simon Fromme 25.04.2017 Tralios IT GmbH www.tralios.de URls Definition foo://example.com:8042/over/there?name=ferret#nose \_/ \ /\ / \ / \ / scheme authority path query fragment
Socket-Programmierung unter Java
Socket-Programmierung unter Java 1 - Grundlagen: Datenströme Datenströme JAVA unterscheidet Streams und Reader/Writer Zur Dateneingabe: InputStream oder Reader Zur Datenausgabe: OutputStream oder Writer
Socket-Programmierung unter Java
Datenströme -Programmierung unter Java 1 - Grundlagen: Datenströme JAVA unterscheidet Streams und Reader/Writer Zur Dateneingabe: InputStream oder Reader Zur Datenausgabe: OutputStream oder Writer Verwende
Referat: Netzwerkprogrammierung in Java
1.)ISO/OSI und Internet Referenzmodell Referat: Netzwerkprogrammierung in Java ISO/OSI 7 Schichtenmodell (1-Bitübertragung, 2-Sicherung, 3-Netzwerk, 4-Transport, 5-Sitzung, 6- Darstellung, 7-Anwendung)
Jan Distel. Im Rahmen der Veranstaltung Fortgeschrittene Programmierung in Java
Jan Distel Im Rahmen der Veranstaltung Fortgeschrittene Programmierung in Java Jan Distel - Diplomarbeitskolloquium 02.07.2010 1. Allgemeines 2. Datagram-Sockets 3. Sockets 4. Server-Sockets 5. Socket-Channels
Verteilte Systeme - Java Networking (Sockets) -
Verteilte Systeme - Java Networking (Sockets) - Prof. Dr. Michael Cebulla 30. Oktober 2014 Fachhochschule Schmalkalden Wintersemester 2014/15 1 / 36 M. Cebulla Verteilte Systeme Gliederung Grundlagen TCP/IP
Netzwerkprogrammierung & Threads
& Praktikum aus 1 & URL, URLConnection, UDP, TCP Parallele Abläufe, Synchronisation, 2 Grundlagen (1/4) Kommunikation zwischen verteilten Programmen Host Computer Java Virtuelle Maschine Host Computer
Transmission Control Protocol (TCP)
Transmission Control Protocol (TCP) Verbindungsorientiertes Protokoll, zuverlässig, paketvermittelt stream-orientiert bidirektional gehört zur Transportschicht, OSI-Layer 4 spezifiziert in RFC 793 Mobile
Netzwerkprogrammierung
Netzwerkprogrammierung 1 Netzwerkverbindungen Das Entwurfsziel von Java war: Einfache Verbindung zwischen Rechnern und SetBox-Systemen. Das Standardpaket java.net hilft bei allen Netzwerkverbindungen.
2 Verbindungslose Kommunikation mit UDP
2 Verbindungslose Kommunikation mit UDP Das User Datagram Protocol (UDP) stellt grundlegende Funktionen zur Verfügung, um mit geringem Aufwand Daten zwischen kommunizierenden Prozessen austauschen zu können.
Einleitung Details. Domain Name System. Standards
Standards Das Domain Name System bildet ein verteiltes Verzeichnis zur Umwandlung von Namen und Adressen. Der Internet Standard 13 (DOMAIN) umfaßt RFC1034 Domain Names - Concepts and Facilities RFC1035
1. Netzwerkprogrammierung für mobile Geräte
1. Netzwerkprogrammierung für mobile Geräte Lernziele 1. Netzwerkprogrammierung für mobile Geräte Themen/Lernziele: Konzepte der verbindungslosen Kommunikation beherrschen Client/Server-Anwendungen auf
Network Communication. Dr. Jürgen Eckerle WS 06/07
Network Communication Dr. Jürgen Eckerle WS 06/07 1 Thread-Programmierung ist wichtig um Nebenläufigkeit bei der Netzwerkprogrammierung zu realisieren Typisches Muster beim Server: Server-Handler. Der
Android VPN. Am Beispiel eines Netzwerktunnels für das Domain Name System (DNS) 1 Andiodine - Android DNS-VPN
Android VPN Am Beispiel eines Netzwerktunnels für das Domain Name System () 1 Inhalt VPN Framework in Android Übersicht zu Iodine Funktionsweise Demonstration 2 VPN und Android Verfügbar seit Android 4.0
Softwarepraktikum Sommersemester 2006
Softwarepraktikum Sommersemester 2006 Netzwerkprogrammierung in Java Ralf Wienzek [email protected] Ulrich Loup [email protected] Grundlagen Netzwerkprogrammierung TCP/IP
Programmieren II. Sockets. Vorlesung 16. Handout S. 1. Dr. Klaus Höppner. Hochschule Darmstadt Sommersemester 2010. Sockets.
Programmieren II Dr. Klaus Höppner Hochschule Darmstadt Sommersemester 2010 1 / 19 2 / 19 Über einen Socket kann eine Anwendung die Implementierung des Netzwerkprotokolls des darunter liegenden Betriebssystems
Client-Server TCP/IP - Kodierung
Client-Server TCP/IP - Kodierung Die klassen Ein (engl. Sockel) ist eine bidirektionale Netzwerk-Kommunikationsschnittstelle, deren Verwaltung das Betriebssystem übernimmt. Die Kombination aus IP-Adresse
Objektorientierung II & die Java Klassenbibliothek. Kristian Bergmann und Arthur Lochstampfer
Java Kurs Objektorientierung II & die Java Klassenbibliothek Kristian Bergmann und Arthur Lochstampfer Vergleich class Apfel { String farbe; int gewicht; String geerntetin; class Erdbeere { String farbe;
Networking. JOHANNES KEPLER UNIVERSITY LINZ Research and teaching network. Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H.
Networking Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer 1 Networking Grundlagen Klasse Socket Klasse ServerSocket Klasse URL Pratikum SWE 2 M. Löberbauer, T. Kotzmann, H. Prähofer 2 Netzwerkprogrammierung
Netzwerkprogrammierung & Threads
Netzwerkprogrammierung & Threads Praktikum aus 1 Netzwerkprogrammierung & Threads Netzwerkprogrammierung URL, URLConnection, UDP, TCP Threads Praktikum aus Parallele Programme, Synchronisation, 2 Netzwerkprogrammierung
Beispiel Time Client/Server
Beispiel Time Client/Server /** * * Programmbeschreibung: * --------------------- * Dieses Programm ermittelt über eine TCP/IP-Verbindung die Uhrzeit eines * entfernten Rechners, wobei es sowohl die Rolle
Unified-E Standard WebHttp Adapter
Unified-E Standard WebHttp Adapter Version: 1.5.0.2 und höher Juli 2017 Inhalt 1 Allgemeines... 2 2 Adapter-Parameter in Unified-E... 2 3 Symbolische Adressierung... 3 3.1 ReadValues-Methode... 4 3.2 WriteValues
Kommunikationsnetze. 2. Direkte TCP/IP-Verbindungen 2.1 Höhere Programmiersprachen
Kommunikationsnetze Gliederung 1. Socket-Programmierung unter C 2. Socket-Programmierung unter Java Gliederung Berkeley Sockets (Erste freie TCP/IP-Implementierung in Berkeley UNIX): SOCKET: Erzeugen eines
Kommentare, Client-Server, Protokolle
Kommentare, Client-Server, Protokolle Grundlagen für die erste Praktikumswoche 19. Oktober 2006 Dokumentationsziel Zweck und Funktionsweise sollten so dokumentiert werden, dass ein Programmierer eine Klasse
DNS Grundlagen. ORR - November 2015. [email protected]. DNS Grundlagen 1
DNS Grundlagen ORR - November 2015 [email protected] DNS Grundlagen 1 /me Freelancer Linux seit es das auf 35 Disketten gab IPv6 DNS und DNSSEC Monitoring mit Icinga, LibreNMS,... Netzwerke (Brocade, Cisco,
Tipps und Hinweise zum Bezug der Beitragssatzdatei V5.0
Tipps und Hinweise zum Bezug der Beitragssatzdatei V5.0 Die Beitragssatzdatei in der Version 5.0 wird nur über https Download auf einer frei zugänglichen Webseite auf den folgenden Seiten bereitgestellt.
Handbuch konsultieren!
Zeichenketten Klasse String Enthält zahlreiche Methoden z.b.: int length(): Anzahl der Zeichen in Zeichenkette String substring(int start): Unterzeichenkette ab Position start boolean equalsignorecase(string
Client-Server TCP/IP - Kodierung
Client-Server TCP/IP - Kodierung Die Socketklassen Ein Socket (engl. Sockel) ist eine bidirektionale Netzwerk-Kommunikationsschnittstelle, deren Verwaltung das Betriebssystem übernimmt. Die Kombination
Java I/O, Serialisierung und Netzwerkprogrammierung
Java I/O, Serialisierung und Netzwerkprogrammierung Philipp Güttler 16. Dezember 2009 Universität Ulm, Abt. SGI Progwerkstatt 2 19 Gliederung Java I/O, Serialisierung und Netzwerkprogrammierung 16. Dezember
Programmieren II. Timer. Vorlesung 11. Handout S. 1. Martin Schultheiß. Hochschule Darmstadt Sommersemester 2011. Timer. Sockets.
Programmieren II Martin Schultheiß Hochschule Darmstadt Sommersemester 2011 1 / 26 Timer Sockets SMTP-Client 2 / 26 Timer Mit einem Timer können bestimmte Aktionen periodisch wiederkehrend durchgeführt
boolean ispalindrome = word.equalsignorecase(reverse.tostring());
Bereich: Input/Output (2) Palindrome speichern Package: de.dhbwka.java.exercise.io Musterlösung Klasse: PalindromeFile package de.dhbwka.java.exercise.io; import java.io.bufferedreader; import java.io.file;
Informatik B. Vorlesung 16 Netzwerkprogrammierung. Dr. Ralf Kunze
Vorlesung 16 Netzwerkprogrammierung 1 Netzwerkprogrammierung Mit Java-Programmen ist es möglich, Verbindungen über Netze aufzubauen Die Basisfunktionalität zur Netzwerkprogrammierung stellt das Paket java.net
Teil 5 - Java. Programmstruktur Operatoren Schlüsselwörter Datentypen
Teil 5 - Java Programmstruktur Operatoren Schlüsselwörter Datentypen 1 Kommentare in Java In Java gibt es drei Möglichkeiten zur Kommentierung: // Kommentar Alle Zeichen nach dem // werden ignoriert. für
Peer-to-Peer- Netzwerke
Peer-to-Peer- Netzwerke Christian Schindelhauer Sommersemester 2006 2. Vorlesung 27.04.2006 [email protected] 1 Organisation Web-Seite http://cone.informatik.uni-freiburg.de/ teaching/vorlesung/peer-to-peer-s96/
DynDNS für Strato Domains im Eigenbau
home.meinedomain.de DynDNS für Strato Domains im Eigenbau Hubert Feyrer Hubert Feyrer 1 Intro homerouter$ ifconfig pppoe0 pppoe0: flags=8851...
1. Netzwerkprogrammierung für mobile Geräte
1. Netzwerkprogrammierung für mobile Geräte Lernziele 1. Netzwerkprogrammierung für mobile Geräte Themen/Lernziele: Konzepte der verbindungslosen Kommunikation beherrschen Client/Server-Anwendungen auf
Einstieg in die Informatik mit Java
1 / 22 Einstieg in die Informatik mit Java Grundlagen Gerd Bohlender Institut für Angewandte und Numerische Mathematik Gliederung 2 / 22 1 Kommentare 2 Bezeichner für Klassen, Methoden, Variablen 3 White
Einstieg in die Informatik mit Java
Vorlesung vom 18.4.07, Grundlagen Übersicht 1 Kommentare 2 Bezeichner für Klassen, Methoden, Variablen 3 White Space Zeichen 4 Wortsymbole 5 Interpunktionszeichen 6 Operatoren 7 import Anweisungen 8 Form
Dateien. DVG Dateien 1
Dateien DVG2-05 - Dateien 1 Die Klasse File Die Klasse File stellt die Verbindung zwischen dem Filesystem des Rechners und dem JAVA-Programm her. Das Filesystem enthält als Objekte Devices, Verzeichnisse
Java Remote Method Invocation (RMI)
Java Remote Method Invocation (RMI) Alexander Petry 13. Mai 2003 engl.: Entfernter Methodenaufruf 1 Übersicht 1. Einleitung 2. RMI Interfaces und Klassen 3. Parameterübergabe 4. Dynamisches Nachladen von
Informatik B. Vorlesung 17 Netzwerkprogrammierung. Dr. Ralf Kunze
Vorlesung 17 Netzwerkprogrammierung 1 Rückblick URL-Objekt Socket Verbindung zu einem Server aufbauen Webserver aus Clientsicht 2 Serverimplementation Server bauen keine eigene Verbindung auf, sondern
Programmieren in Java
Programmieren in Java Dateien lesen und schreiben 2 Übersicht der heutigen Inhalte File Streams try-with-resources Properties csv-dateien 3 Klasse File Die Klasse java.io.file bietet Unterstützung im Umgang
Netzwerk-Programmierung. Netzwerke. Alexander Sczyrba Michael Beckstette.
Netzwerk-Programmierung Netzwerke Alexander Sczyrba Michael Beckstette {asczyrba,mbeckste}@techfak.uni-bielefeld.de 1 Übersicht Netzwerk-Protokolle Protkollfamilie TCP/IP Transmission Control Protocol
Client-Server TCP/IP - Kodierung
Client-Server TCP/IP - Kodierung (1.) (a.) Testen Sie das erste Beispiel aus dem Ordner 01: Starten Sie Client und Server auf dem gleichen PC, aber den Server zuerst! (b.) In welchem Bereich müssen die
Klausur Rechnernetze
Klausur Rechnernetze Studiengang MI Sommersemester 2007, 30. Mai FH Giessen-Friedberg Prof. Dr. Euler Name Vorname Matrikelnummer Studiengang MI / TI / WK Aufgabe 1 2 3 4 5 Punkte Gesamtpunkte Ich bin
Kommunikationsnetze 6. Domain Name System (DNS) University of Applied Sciences. Kommunikationsnetze. 6. Domain Name System (DNS)
Kommunikationsnetze Gliederung 1. Geschichte von DNS bis RFC 1035 2. Die Namenshierarchie 3. DNS-Server-Hierarchie 4. Rekursive und iterative Abfragen 5. Struktur der Datenbank 6. Struktur der Abfragen
Java-Programmierung. Remote Method Invocation - RMI
Java-Programmierung Remote Method Invocation - RMI Entwicklungsmethoden Sockets Entwurf verteilter Anwendungen ist relativ aufwändig, da zunächst ein Kommunikationsprotokoll entwickelt werden muss aufwändig
Java-Schulung Grundlagen
Java-Schulung Grundlagen Java 2 Standard Edition JDK 5 / 6 31.05.2008 Marcel Wieczorek 1 Themenübersicht Basiswissen Objektorientierung Datentypen Fehlerbehandlung Sonstiges Einführung Klassen, Strings
Übung 4 DNS & E- Mail 21. November Laborübungen NWTK. Informationstechnologie für Berufstätige
Laborübungen NWTK Informationstechnologie für Berufstätige Höhere technische Bundeslehranstalt, 1160 Wien, Thaliastraße 125 Klasse 5ABKIF Projekttitel Gruppenleiter - Projektteilnehmer Trojkó Katalognummer:
UDP Datagramme und Sockets
In diesem Kapitel: Was ist ein UDP Datagramm Die DatagrammPacket Klasse Die DatagrammSocket Klasse Höhere Abstraktionslevel Anwendungsbeispiele 9 UDP Datagramme und Sockets 9.1. Einführung In den beiden
Programmiermethodik. Übung 10
Programmiermethodik Übung 10 Sommersemester 2011 Fachgebiet Software Engineering [email protected] Agenda Vorstellung Musterlösung HA 6 Client/Server Kommunikation in Java Vorstellung HA 7
Lösungsvorschläge zur Nachklausur zum Kurs 1618 Sommersemester 2001 am
Aufgabe 1 Lösungsvorschläge zur Nachklausur zum Kurs 1618 Sommersemester 2001 am 16.3.2002 Folgende Implementierung löst die gestellte Aufgabe : public interface Figur { public void anzeigen (); public
Programmieren in Java
Programmieren in Java Vorlesung 02: Methoden Prof. Dr. Peter Thiemann Albert-Ludwigs-Universität Freiburg, Germany SS 2017 Peter Thiemann (Univ. Freiburg) Programmieren in Java JAVA 1 / 17 Inhalt Scanner
PROG 2: Einführung in die Programmierung für Wirtschaftsinformatiker
Netzwerkprogrammierung PROG 2: Einführung in die Programmierung für Wirtschaftsinformatiker Steffen Helke, Marcus Mews Technische Universität Berlin Fachgebiet Softwaretechnik 17. Juni 2013 Übersicht Grundlagen
1 Klassen anlegen und Objekte erzeugen
Werkzeugkiste Java 1 1 Klassen anlegen und Objekte erzeugen Klassengrundgerüst 1 /** 2 * Write a description of class Testklasse here. 3 * 4 * @author ( your name ) 5 * @version (a version number or a
TECHNISCHE UNIVERSITÄT MÜNCHEN FAKULTÄT FÜR INFORMATIK
TECHNISCHE UNIVERSITÄT MÜNCHEN FAKULTÄT FÜR INFORMATIK Lehrstuhl für Sprachen und Beschreibungsstrukturen WS 2006/2007 Praktikum Grundlagen der Programmierung Lösungsvorschläge zu Blatt 3 F. Forster, M.
1 Klassen anlegen und Objekte erzeugen
Werkzeugkiste Java 1 1 Klassen anlegen und Objekte erzeugen Klassengrundgerüst 1 /** 2 * Write a description of class Testklasse here. 3 * 4 * @author ( your name ) 5 * @version (a version number or a
4. Thread- und Netzwerk- Programmierung
4. Thread- und Netzwerk- Programmierung 4.1 Ziel dieses Kapitels 4.2 Prozeß versus Thread 4.3 Thread-Programmierung 4.4 TCP/IP Grundlagen 4.5 TCP Programmierung 3. TCP/IP und Threads 3-1 4.1 Ziel dieses
! 1. Unterklassen und Vererbung! 2. Abstrakte Klassen und Interfaces! 3. Modularität und Pakete! 4. Ausnahmen (Exceptions) II.4.
! 1. Unterklassen und Vererbung! 2. Abstrakte Klassen und Interfaces! 3. Modularität und Pakete! 4. Ausnahmen (Exceptions) II.4.4 Exceptions - 1 - Ausnahmen (Exceptions( Exceptions) Treten auf, wenn zur
Das Internet-Protocol. Aufteilung von Octets. IP-Adressformat. Class-A Netzwerke. Konventionen für Hostadressen
Das Internet-Protocol Das Internet Protocol (IP) geht auf das Jahr 1974 zurück und ist die Basis zur Vernetzung von Millionen Computern und Geräten weltweit. Bekannte Protokolle auf dem Internet Protokoll
Device Management Schnittstellen. Referat von Peter Voser Embedded Development GmbH
Device Management Schnittstellen Referat von Peter Voser Embedded Development GmbH Device Management ist Gerätesteuerung Parametrisierung Zugang zu internen Messgrössen und Zuständen Software Upgrade www.embedded-development.ch
Remote Method Invocation
Remote Method Invocation Spezielle Technik aus dem Java-Umfeld Ausführung von Methoden auf einem entfernten Rechner Analogon zum RPC (Remote Procedure Call) Zweck: Objekte in verschiedenen Java-VMs Aufruf
Projektierung und Betrieb von Rechnernetzen
Projektierung und Betrieb von Rechnernetzen Versuch : Router-Konfiguration Vorbetrachtungen Im Rahmen des Praktikums sind einige Begriffe bzw. Fragen zum Thema Router zu klären: Was ist ein Router? Router
Domain Name System (DNS) Seminar: Internet Protokolle Theodor Heinze Jaroslaw Michalak
Domain Name System (DNS) Seminar: Internet Protokolle Theodor Heinze Jaroslaw Michalak Gliederung Geschichte Struktur des DNS Domain / Zone Root-Server Nameserver Namensauflösung DNS-Nachrichten Protokolle
Netzprogrammierung: URL-Schemata
Netzprogrammierung: URL-Schemata Robert Tolksdorf und Peter Löhr Überblick 1. Vereinheitlichte Dienstnutzung in Java 3 2. Eigene URL-Schemata 24 3. Push- und Pull-Interaktion 28 Robert Tolksdorf und Peter
