PENGANTAR TEKNOLOGI WEB Pengantar Internet (HTTP) Antonius Rachmat C LAN • LAN consists of the following components: – LAN file server is a repository of various software and data files for the network (optional) – Nodes are the client machines on the LAN – Wired or wireless communication media that connects the devices • LAN network interface card (NIC) is a special adapter that links an individual device to the communication medium and specifies: – The rate of data transmission; – The size of the message units; – Addressing information attached to each message – The network topology WAN + Wireless • Wide area networks (WANs) are networks that cover large geographic areas. – WANs typically connect multiple LANs – WANs have large capacity and combine multiple channels (fiber optic, satellite, microwave, etc.) – WANs are provided by common carriers, such as telephone companies (Sprint, AT&T, etc.) • Wireless: – Wifi - simple wireless networks – WLAN - expanding the wireless connection – WiMax - Long-range wireless What is Internet? Server Client Intranet vs Extranet • Intranet: is a private enterprise network for information gathering and distribution within an organization. • Extranet: is a community of interest created by extending an intranet to selected entities external to an organization. Internet • Inter-connections network – Memiliki bnyk sub network – Komputer yg berbeda-beda, media penghubung yg berbeda-beda = heterogen • Internet = hardware, WWW (web) = software • Beberapa komponen: – Router, client, server, modem, DNS, protocol, TCP/IP Internet • Router: hardware yang mengatur jalur data sebuah paket (message) • Client: bagian yg meminta layanan ke server • Server: bagian yg melayani client (response) • Modem (modulator/demodulator): – Modulator merupakan bagian yang mengubah sinyal informasi kedalam sinyal pembawa (Carrier) dan siap untuk dikirimkan. – Demodulator adalah bagian yang memisahkan sinyal informasi (yang berisi data atau pesan) dari sinyal pembawa (carrier) yang diterima sehingga informasi tersebut dapat diterima dengan baik. • DNS : Domain Name Services – Mengasosiasikan setiap node (komputer) yg terhubung ke Internet dengan sebuah nama yg “human readable” – Mis: 202.134.201.137 => google.com • Protocol: aturan komunikasi data • TCP/IP: Transmission Control Protocol / Internet Protocol – Protocol untuk Internet • TCP: mengatur transmisi data – Data dibagi menjadi paket2 kecil (~1.5kb) – Paket tsb dikirim lwt router • IP: menerjemahkan aturan dari satu network ke network yg lain – Memungkinkan antar jaringan berbeda saling berkomunikasi Penjelasan • Protokol application layer: bertanggung jawab untuk menyediakan akses kepada aplikasi terhadap layanan jaringan TCP/IP. • Protokol host to network: berguna untuk membuat komunikasi menggunakan sesi koneksi yang bersifat connection-oriented atau broadcast yang bersifat connectionless. Penjelasan • Protokol lapisan network: bertanggung jawab untuk melakukan pemetaan (routing) dan enkapsulasi paket-paket data jaringan menjadi paket-paket IP. • Protokol lapisan physical: bertanggung jawab untuk meletakkan frame-frame jaringan di atas media jaringan yang digunakan. Sejarah Internet 1969 DARPA (Defence Advance Research Project Agency) memulai Riset Internet 1972 Diperkenalkan sebuah jaringan dengan nama ARPANET 1977 Terdapat 100 PC dan Mainframe yang terkoneksi ke ARPANET dan sebagian besar dari Universitas : UCLA, Stanford Institute, UC Santa Barbara, dan University of Utah 1980 ARPANET pecah menjadi ARPANET dan MILNET (militer) 1986 National Science Foundation (NSF) mengeluarkan NSFNET. Jaringan dengan kecepatan 56kbps dan merupakan embrio dari Internet sekarang ini 1987 Berdiri UUNET merupakan provider Internet komersial pertama 1990 ARPANET dibubarkan. Australia, Skandinavia, Inggris, Perancis, Jerman, Kanada, dan Jepang terkoneksi dengan NSFNET 1992 Jumlah Host Internet mencapai 1 juta 2004 Jumlah Host Internet mencapai 5 juta diseluruh dunia Internet di Indonesia 1985 Berdiri UUNET yang menghubungkan Universitas Indonesia, Universitas Terbuka, Institut Teknologi Bandung, Universitas Gajahmada, dan Institut Teknologi Surabaya. 1990 Dibangun infrastruktur jaringan Nasional 1992 Pertemuan pertama membahas teknologi internet oleh BPP Teknologi, LAPAN, STT Telkom Bandung, dan Universitas Indonesia. Dibentuk Internet Paguyuban 1994 Top Level Domain Id masuk ke Indonesia 1994 IPTEKNET Sebagai Internet Service Provider Pertama di Indonesia Domain • Adalah alamat permanen situs di dunia internet • Identifikasi sebuah situs Istilah yang umum digunakan adalah URL. http://www.fppti.or.id http://www.ipi.or.id http://www.iwapi-jabar.or.id Generic Domains tata nama • xxx.com : commercial http://www.kompas.com • xxx.edu : dunia pendidikan http://www.upi.edu • xxx.ac.id : pendidikan • xxx.go.id : pemerintahan http://www.bandung.go.id • xxx.or.id :organisasi non profit http://www.ipi.or.id Country-Specific Domains • Berektensi dua huruf second level domain) - Indonesia berekstensi id http://www.itb.ac.id - Australia au http://nla.gov.au - Jepang berekstensi .jp http://www.jla.or.jp • Di Indonesia: dikenal dengan domain-co.id, .ac.id, .go.id, .mil.id, .or.id Types of Websites • • • • • • • • • Portal Web site- www.yahoo.com News Web site- www.cnn.com Informational web site- www.smidec.gov.my Business/ Marketing web site- www.kraft.com Educational website- www.resepi.mesra.net Entertainment web site- www.shockwave.com Advocacy web site- www.hsus.org Personal web site- www.ukm.my/radzuan Blog HTTP • Hypertext Transport Protocol (RFC 1945) • Tim Berners-Lee, 1991 • Language of the Web – Protocol yang digunakan untuk komunikasi antara web browsers dan web servers – Since 1990 • TCP port 80 • Penyempurnaan HTTP 1.0 menjadi versi 1.1 dispesifikasikan oleh IETF dengan RFC 2616 • HTTP merupakan implementasi dari protokol TCP • Bersifat “Stateless” – Tidak ada informasi yang disimpan – Solusi? Cookies & Session HTTP (2) • HTTP bersifat request – response: – HTTP client (user agent misalnya) mengirimkan permintaan (request) ke HTTP server dan server meresponse sesuai request tersebut • User agent: Mozilla, Netscape, Microsoft Internet Explorer atau browser berbasis teks, Lynx atau links • Perbedaan mendasar antara HTTP/1.1 dengan HTTP/1.0 adalah penggunaan hubungan persistent. • HTTP/1.0 membuka satu koneksi untuk tiap permintaan URI – header = Connection: close • HTTP/1.1 dapat menggunakan sebuah koneksi TCP untuk beberapa permintaan URI (persistent) – header = Connection: Keep-Alive – kecuali jika client menyatakan tidak hendak menggunakan hubungan persistent (header = Connection: close). HTTP Client (Browser) • • • • • • • • NCSA Mosaic (M. Andreesen) Netscape Navigator (M. Andreesen) Microsoft Internet Explorer Browser Wars of the 1990's Mozilla (Netscape Open Sourced) Now Mozilla Firefox Apple Safari (from Konqueror) Others (Opera, Lynx) Universal Resource Location (URL) http://www.stanford.edu:80/class/cs193i/schedule.html Protocol (Scheme) Universal Resource Location (URL) http://www.stanford.edu:80/class/cs193i/schedule.html Host Name Universal Resource Location (URL) http://www.stanford.edu:80/class/cs193i/schedule.html Port Universal Resource Location (URL) http://www.stanford.edu:80/class/cs193i/schedule.html Path URL Path = File System Path • URL Path “/” maps to Document Root • Let’s say Document Root is C:\htdocs\ / => C:\htdocs\ /images/ => C:\htdocs\images\ /a/X.html => C:\htdocs\a\X.html HTTP 1.0 is Stateless • Each request/response pair uses its own connection; doesn't know about other pairs • "One-Shot" – Server Fulfills Request, and closes connection + Simple ─ Hard to design pages that are "logically connected" (e.g. Amazon checkout) What is the URL path? • http://foo.com:8080/a/b/bar.html?hello.there#binky • query begins with ? – hello.there • fragment begins with # – binky • So, path is between host and query/fragment – /a/b/bar.html • But Request-Line includes Query Fragment • Used by client side to scroll to named anchors • <a name="Chapter1">...</a> • http://foo.com/b.html#Chapter1 Request String • The path & query part of the URL • NOT the fragment part • http://foo.com/dir/b.html?info=extra&hello – /dir/b.html?info=extra&hello is the Request String HTTP Request Messages • GET – retrieve document specified by URL • PUT – store specified document under given URL • HEAD – retrieve info. about document specified by URL • POST – give information (eg. annotation) to the server • DELETE – remove document specified by URL • CONNECT – for use by caches Example Request / Response • Client requests http://solaria.stanford.edu/food/index.html • Client sends GET /food/index.html HTTP/1.0\r\n\r\n • Server sees request with path /food/index.html • Server maps onto Document Root G:/webroot + /food/index.html • Server sends back file over HTTP (e.g. HTML file) Method: Head • Gunakan Telnet Hasil Method: GET • Buat file cobaget.php GET • Ketik perintah berikut: Hasil GET Method : POST Hasil POST HTTP Response Codes • 1xx – Informational – request received, processing • 2xx – Success – action received, understood, accepted • 3xx – Redirection – further action necessary • 4xx – Client Error – bad syntax or cannot be fulfilled • 5xx – Server Error – server failed NEXT