- Şəbəkə haqqında bir az danışaq.
- Gəlin müştəri-serverin strukturunu və üç səviyyəli arxitekturasını nəzərdən keçirək.
- HTTP/HTTPS protokollarına baxaq.
- Maven haqqında bilmək lazım olan hər şeyi öyrənək.
- Servletlər haqqında danışaq.
- Servlet qabları.
- Və nəhayət - MVC haqqında.
1-ci hissə. Şəbəkə haqqında bir az danışaq
Ən vacib şeydən başlayaq və bütün sosial şəbəkələrin, veb xidmətləri və tətbiqlərinin, ani mesajlaşmaların və sadə saytların qurulduğu əsas haqqında danışaq - şəbəkə haqqında ( bu məqalələr silsiləsi kontekstində "şəbəkə" termini deməkdir. Qlobal İnternet ). Şəbəkə çoxlu sayda kompüterdən ibarətdir: onlar bir-birinə bağlıdır və əlaqə qura bilir. Onların bunu necə etdiyini başa düşmək vacibdir, çünki veb proqramları məlumatın bir kompüterdən digərinə ötürülməsinə cavabdehdir.OSI şəbəkə modeli
OSI (Open Systems Interconnection) modeli şəbəkənin qurulmasına laylı yanaşma yaradır. Eyni şəbəkə üzvlərinin bir-biri ilə necə və hansı səviyyədə qarşılıqlı əlaqədə ola biləcəyini aydın şəkildə göstərir. Ümumilikdə bu model 7 səviyyəni ehtiva edir:7 | Tətbiq olunub |
6 | Nümayəndəlik |
5 | Sessiya |
4 | Nəqliyyat |
3 | Şəbəkə |
2 | Kanal |
1 | Fiziki |
-
1. Физический уровень — здесь свое дело делают законы физики, а задача человека — использовать и направлять это в своих целях. Например, создание кабелей и прокладывание их к членам сети.
Нам не интересен.
-
Канальный уровень — отвечает за передачу данных сетевым узлам, создание каналов передачи данных на физических an objectх.
Нам не интересен, если только нет желания писать прошивку для каналообразующей аппаратуры.
-
Сетевой уровень — для определения addressов отдельных пользователей сети и маршрутов к ним. На этом уровне стоит остановиться подробнее, а именно — на addressе пользователя в сети.
Он определяется специальным протоколом: самый распространённый — IPv4 (Internet Protocol version 4). Именно его нужно использовать веб-программисту для обращения к другому абоненту сети.
IPv4 состоит из четырех byteовых значений, разделенных точкой, например: 192.0.2.235. Стоит помнить, что значения byteовые, а значит, они лежат в пределах 0..255.
IP-address, в свою очередь, делятся на классы, и просто так присвоить себе красивую комбинацию циферок не получится, но так сильно углубляться мы не станем. Достаточно понимать, что IP-address — это уникальный идентификатор абонента в сети, по которому мы сможем к нему обратиться.
-
Транспортный уровень — занимается доставкой информации addressту. Для этого используются разные протоколы, которые нам пока не интересны. Гораздо больше нас интересует понятие, которое появляется на этом уровне, — port.
Порты отвечают за идентификацию конкретного applications на компьютере. Например, ты написал чат на Java, установил на 2 компа и хочешь отправить своему собеседнику. Твое сообщение упаковывается, отправляется по конкретному IP-addressу, доставляется твоему собеседнику, но его ПК не знает, что делать с полученной информацией, так How не понимает, Howое приложение должно обработать твое сообщение. Для этого и указываются порты при общении абонентов в сети.
Порт представляет собой число от 0 до 65535. Он добавляется к IP-addressу после двоеточия: 192.0.2.235:8080. Но нельзя использовать все порты из указанного диапазона: часть из них зарезервирована под операционную систему, еще часть принято использовать с конкретно оговоренной целью. В преднаmeaning разных портов углубляться не будем, пока достаточно понимать их роль в процессе общения в сети.
-
Сеансовый уровень — создает и управляет сеансами связи приложений. На этом уровне становится возможным взаимодействие приложений, отправка requestов служебного уровня. Для нас важно знать, что на этом уровне между двумя абонентами открывается сессия (session), с которой нам часто придется работать.
Sessiya iki istifadəçi arasında əlaqə qurulduqda yaradılan bir qurumdur. Orada istifadəçi və onların qarşılıqlı əlaqə tarixi haqqında bizə lazım olan məlumatları saxlaya bilərik. Əhəmiyyətli bir detal ondan ibarətdir ki, məlumat mübadiləsi dayandırıldıqda, sessiya yoxa çıxmır, müəyyən müddət ərzində öz vəziyyətini saxlayır, beləliklə, istifadəçilər fasilədən sonra məlumat mübadiləsini davam etdirə bilərlər.
Tətbiq eyni vaxtda bir neçə istifadəçi ilə əlaqə saxlayırsa, müvafiq sayda əlaqə və buna görə də sessiyalar qurulur. Hər bir sessiyanın unikal identifikatoru (ID) var ki, bu da proqrama ünsiyyətin baş verdiyi istifadəçiləri ayırd etməyə imkan verir.
-
Təqdimat səviyyəsi - məlumatların kodlaşdırılması/şifrlənməsi üçün cavabdehdir. Aydındır ki, əgər “Salam web” sətirini başqa istifadəçiyə göndərmək lazımdırsa, o, əvvəlcə ikili koda çevrilir (kodlaşdırılır) və yalnız bundan sonra göndərilir. Təyinat yerinə çatdıqdan sonra mesaj geri çevrilir (deşifrə edilir) və alıcı orijinal sətri görə bilir. Bu hərəkətlər təqdimat səviyyəsində baş verir.
-
Tətbiq təbəqəsi bizim üçün ən maraqlı təbəqədir. Tətbiqlərə şəbəkə ilə qarşılıqlı əlaqə yaratmağa imkan verir. Bu səviyyədə biz qəbul edəcəyik, mesajlar göndərəcəyik, xidmətlərə və uzaq verilənlər bazalarına sorğular edəcəyik.
Bu səviyyədə istifadə olunan bir çox protokollar var: POP3, FTP, SMTP, XMPP, RDP, SIP, TELNET və əlbəttə ki, HTTP/HTTPS. Protokol mesajlar yazarkən əməl etdiyimiz universal razılaşmadır. Biz mütləq HTTP/HTTPS protokolları haqqında ayrıca və daha ətraflı danışacağıq.
- IP ünvanı - şəbəkədəki abunəçinin ünvanı;
- Port — konkret abunəçinin müraciət ünvanı;
- Sessiya iki abunəçi arasında bütün ünsiyyət zamanı mövcud olan bir qurumdur;
- Tətbiq protokolları (HTTP/HTTPS) mesajlar tərtib edərkən və göndərərkən bizə rəhbərlik edəcək qaydalardır.
GO TO FULL VERSION