Langsung ke konten utama

Algoritma Web Server Statis dengan Python

Bagaimana Skema Connection ?

    Dikarenakan untuk komunikasi data kita menggunakan standard Socket (RFC 1928) dan protokol yang digunakan adalah TCP, maka skema connection ini tentunya mengikuti skema socket berbasis TCP. Silahkan diamati ilustrasi gambar diatas ya..

    Untuk pengembangan aplikasi web, konsentrasi kita adalah bagaimana membuat program server, atau kita istilahkan web server. Bagaimana dengan program client (browser)? Untuk sementara kita memanfaatkan browser yang sudah ada saja, seperti misalnya Google Chrome, Mozilla Firefox, Internet Explorer atau web browser lainnya.

    Dari skema diatas, untuk bagian TCP Server bisa kita susun algoritma pemrogramannya seperti yang terlihat pada ilustrasi gambar berikut ini. Untuk keperluan pengembangan aplikasi, tentunya kita belum butuh komputer server yang sesungguhnya. Tetapi dikarenakan aplikasi web server dan client ini butuh IP Address, maka kita bisa menggunakan IP Address localhost atau 127.0.0.1. Sedangkan untuk konfigurasi Port, kita bebas menggunakan port berapapun asalkan port tadi tidak digunakan oleh aplikasi lainnya. Contoh port yang jarang digunakan aplikasi lain adalah port 8080.

Uniform Resource Locator (URL)

    Agar program client bisa terhubung dengan program server, atau istilahnya adalah membangun koneksi (establish connection), maka perlu ada standar khusus yang mengatur tentang hal itu. Standar yang dimaksud tertuang dalam RFC 1738 yang berisi standar Uniform Resource Locator atau disingkat URL. Dalam penggunaan kesehariannya, biasanya kita mengetikkan URL ini pada address bar pada browser kita.
    Adapun aturan penulisan URL menurut RFC 1738 itu, khusus untuk protokol HTTP adalah seperti berikut ini.

Contoh :

  • https://www.google.com/index.html
  • https://www.facebook.com/index.php?groups=2920223131408328
  • https://www.google.com/search?q=rfc+2068&sxsrf=ALeKk00
  • http://www.localhost:8080/index.html
  • http://www.127.0.0.1/index.html?nama=hadi&alamat=banyuwangi
    Jika pada penulisan URL port tidak didefinikan, maka otomatis port akan terisi 80. Karena dalam konsensus protokol http, port yang digunakan adalah 80. Hanya untuk keperluan pengembangan aplikasi, kita bisa menggunakan port berapapun asalkan tidak bentrok dengan aplikasi lainnya. Nanti setelah aplikasinya dipasang di server yang sesungguhnya, maka port aplikasi harus dirubah menjadi 80.

Request Message (Pesan Permintaan)

    Setelah program client dan server terhubung, maka langkah pertama adalah program client mengirimkan pesan (request message) ke program server. Isi dari pesan permintaan (request message) ini sudah diatur pada RFC 2068 section 5. Ini saya contohkan isi pesan permintaan.

    Dari contoh diatas, aturan penulisan isi pesan permintaan (request message) yang ditetapkan pada RFC 2616 terdapat 2 bagian pokok yaitu :
  1. Request-line
  2. Request Header Fields
    Baris ke 0 yaitu “GET /index.html HTTP/1.1” disebut Request-line. Dimana pada bagian request-line ini terbagi menjadi 3 bagian seperti gambar berikut ini

Berikut ini adalah algoritma untuk menangani request (handle request).

Response

    Setelah server menerima dan menafsirkan pesan permintaan (request message), maka server merespon client dengan pesan respons HTTP (HTTP Response Message). Pada intinya isi dari response message itu adalah 

Response = status-line CRLF header CRLF message body

Contoh :

Baik kita fokus ke response status-line dulu ya.
    Response status-line terdiri dari 3 bagian yaitu : HTTP version, status code dan reason phrase. Ilustrasi ke-3 bagian itu seperti gambar berikut ini

    Oke, setelah paham mengenai konsep dari respon message, maka kita akan belajar bagaimana menangani respon (handle response) itu tadi. Berikut ini saya tunjukkan sebuah iluastrasi yang menggambarkan algoritma handle method GET.

Flowchart Web Server Statis

Berikut ini merupakan flowchart dari code program web server statis (artikel sebelumnya) 

Komentar

Postingan populer dari blog ini

Membuat Halaman Profil Konsumen Dengan NextJS & Bulma

Apa itu Next.js?  Next.js merupakan sebuah React framework yang dibentuk buat mengatasi kasus client-side rendering yang dimiliki React. Sebuah halaman website yang dibentuk memakai React ‘terasa ringan’ lantaran tampilan website sangat interaktif.  Selain itu, ketika data berubah, React menggunakan efisien akan mengupdate bagian menurut halaman website yang memang perlu diupdate tanpa perlu reload satu halaman penuh.  Untuk menerima itu seluruh, client wajib load seluruh file JavaScript sebelum konten halaman ditampilkan. apabila file JS relatif akbar maka ketika yang diperlukan buat load pertama kali pula sebagai lebih lama.  Masalah lain menurut client-side rendering merupakan SEO, terdapat kemungkinan web crawler berusaha mengindex halaman yang belum terselesaikan dirender sepenuhnya (lantaran ketika load yang lama). Dan menduga web tadi blank.  Kedua kasus diatas bisa diselesaikan menggunakan teknik pre-rendering. Yaitu halaman HTML dan file JavaScript pada...

Membuat Database Menggunakan Aplikasi Excel ~ Part 4

Pengertian Normalisasi Database Normalisasi database adalah proses pengelompokan atribut data yang membentuk entitas sederhana, nonredundant, fleksibel, dan mudah beradaptasi. Sehingga dapat dipastikan bahwa database yang dibuat berkualitas baik. Tujuan Normalisasi Database Tujuan utama dari normalisasi database adalah: Menghilangkan dan mengurangi redudansi data. Memastikan dependensi data (data berada pada tabel yang tepat). Jika sebuah database belum dinormalisasi, kemungkinan terburuk yang akan merugikan sistem adalah: INSERT Anomali Situasi dimana tidak memungkinkan untuk memasukkan beberapa jenis data secara langsung di database. UPDATE Anomali Situasi dimana nilai yang diubah mengakibatkan ketidakkonsistenan database, artinya data yang diubah tidak sesuai dengan yang diinginkan. DELETE Anomali Penghapusan data tidak sesuai yang diharapkan, artinya data yang seharusnya tidak terhapus malah terhapus. Pada proses normalisasi terhadap tabel pada database dapat dilakukan dengan tiga ...

Design Sprint Alur Fitur Dari Wlijo

Design Sprint Fitur Wlijo      Wlijo adalah platform yang menghubungankan antara petani, pedagang sayur dan konsumen melalui aplikasi belanja sayur online. Saat ini wlijo masih dalam tahap pengembangan dan perbaikan. Untuk membantu proses pengembangan wlijo agar bisa selesai sesuai waktu yang ditargetkan diperlukannya sebuah metode efektif yakni metode design sprint. Apa Itu Metode Desain Sprint ?     Design sprint merupakan sebuah metode 5 langkah kerja untuk membantu perusahaan agar dapat membuat suatu produk berdasarkan design thinking dengan waktu lima hari. Design thinking sendiri merupakan proses yang mencakup proses strategis, kognitif, dan praktis. Design sprint sendiri dibuat pada tahun 2010 oleh seseorang yang berasal dari Google Venture bernama Jake Knapp. Sampai saat ini, sudah banyak perusahaan yang memakai design tersebut sampai keseluruh dunia.      Konsep kerjanya yaitu menggunakan waktu selama lima hari untuk membangun suatu ...