Differences between revisions 1 and 106 (spanning 105 versions)
Revision 1 as of 2009-09-15 09:36:12
Size: 887
Editor: jenca
Comment:
Revision 106 as of 2011-12-10 18:03:44
Size: 8448
Editor: jenca
Comment:
Deletions are marked like this. Additions are marked like this.
Line 3: Line 3:
2009/2010 -- zimný semester 2011/2012 -- zimný semester

== Domáce zadanie na 1. cviko ==

[[attachment:cviko1.pdf]]

== Zadanie na 2. cviko ==

[[attachment:zadanie2.pdf]]

== Zadanie na 3. cviko ==

<<Pozor>>
3. zápočtové cviko bude dňa 13.12.2011. Dostanete nejaké HTML a obrázok a Vašou úlohou bude napísať CSS
tak, aby sa vykreslilo približne tak, ako je na obrázku.
<<Pohov>>

<<Pozor>>
Náhradné zápočtové cviko (pre tých, čo boli chorí na niektorom z normálnych zápočtových cvičení) bude v piatok 16.12.2011,
čas bude špecifikovaný neskôr.

Domáce zadania na náhradné cviko sú rovnaké,
zadania v piatok budú však iné ako na normálnom cviku.
<<Pohov>>



<<TableOfContents()>>
Line 8: Line 35:

=== Konzultácie ===

Pondelok 16:00 -- 17:00

== Oznamy ==
<<Pozor>>
Druhé skúšobné počítačové cvičenie bude 28.11.2011. Budete písať cgi skript, ktorý
bude mať za úlohu zobrazenie nejakého webového formulára, načítanie údajov z neho a uloženie údajov v textovej podobe do nejakého súboru na disku.

Spôsob fungovania má byť taký, ako bolo odprednášané: zobrazenie prázdneho formulára
v GET vetve a spracovanie údajov v POST vetve toho istého skriptu. Môžete a máte
používať modul `cgi`. V repozitári je niekoľko skriptov vypisujúcich a spracujúcich formuláre, skript `sincos.py` z prednášky som dotiahol do konca.

Na cvičení vám potom budem špecifikovať formulár a požadovaný tvar, v ktorom
treba zapísať údaje.
<<Pohov>>

Line 14: Line 60:
 * Základy konfigurácie sietí a služieb
Line 19: Line 66:
 * Dynamické webové stránky cez CGI skripty
 * Šablónové jazyky
 * Dynamické webové stránky pomocou CGI skriptov
 * !JavaScript, AJAX
Line 28: Line 76:
 1. Craig Hunt, ''TCP/IP Network administration'', 3. vydanie, O'Reilly  1. Craig Hunt, ''TCP/IP Network administration'', 3. vydanie, O'Reilly, http://docstore.mik.ua/orelly/networking_2ndEd/tcp/index.htm
 1. David Gourley, Brian Totty, Marjorie Sayer, Anshu Aggarwal, Sailu Reddy, et al., ''HTTP: The Definitive Guide'', O'Reilly (2002)
 1. David Flanagan, ''!JavaScript: The Definitive Guide'', O'Reilly Media, Inc.; 5th edition (2006)

== Webové stránky ==

 1. [[http://www.earchiv.cz/i_prednasky.php3 | e-archiv Jiřího Peterky: Přednášky:]]
 1. HTML and CSS Tutorials, References, and Articles, http://htmldog.com/
 1. Jak psát web, http://www.jakpsatweb.cz/
 1. Color scheme designer, http://colorschemedesigner.com/
 1. Selectutorial: CSS selectors, http://css.maxdesign.com.au/selectutorial/
 1. Allowed nesting of elements in HTML 4 (and XHTML 1.0), http://www.cs.tut.fi/~jkorpela/html/nesting.html
 1. The W3C Markup Validation Service, http://validator.w3.org/
 1. The W3C CSS Validation Service, http://jigsaw.w3.org/css-validator/
 1. CSS Zen Garden, http://www.csszengarden.com/
 1. Mercurial SCM, http://mercurial.selenic.com/
 1. Mercurial: The Definitive Guide by Bryan O'Sullivan, http://hgbook.red-bean.com/

== O mercuriali ==
[[mercurial]]
Line 32: Line 99:
 * Dve zápočtové cvičenia vypracované ako rozšírenie domácich zadaní
   * TCP/IP a sockety
   * CGI skript
 * Jedno domáce zadanie z web dizajnu a šablón
 * Počas semestra sa bude udeľovať 40 bodov. Na zápočet je potrebných 20 bodov.
 * 40 bodov bude udeľovaných za tieto veci:
  * Tri zápočtové cvičenia vypracované ako rozšírenie domácich zadaní
    * TCP/IP a sockety
    * CGI skripty
    * Jedno zápočtové cvičenie z CSS


== Výsledky ==

[[/Vysledky]]

== Témy jednotlivých prednášok ==

 1. Vrstvové referenčné modely.
   a. Model ISO/OSI
   a. Model TCP/IP
 1. Problém riadenia súbežného prístupu (MAC)
   a. Centralizované a decentralizované modely, deterministické a nedeterministické modely
   a. Modely s centrálnym arbitrom, token ring
   a. ALOHA, slotted ALOHA, CSMA, CD, Ethernet
 1. Sieťová vrstva, adresácia, smerovanie
   a. IPv4 adresy, triedy A,B,C
   a. Privátne adresy
   a. Sieťová a broadcast adresa
   a. Preklad IP adries (masquerading)
 1. Transportná vrstva, UDP, TCP
   a. Protokoly TCP a UDP
   a. Softwarové rozhranie pre prístup k transportnej vrstve - sockety
   a. Šablóny programov "klient" a "server" - fork prístup k servru.
 1. Aplikačné protokoly
   a. Základy fungovania DNS, SMTP
   a. Protokol HTTP
 1. HTML a CSS
   a. XHTML 1.0
   a. Štylizácia HTML pomocou kaskádových štýlov
 1. Dynamický web
   a. Základné princípy dynamického webu
   a. CGI
 1. Pokročilé aspekty HTTP
   a. Autorizácia (Basic)
   a. Cookies
 1. Web 2.0
   a. !JavaScript cez jquery
   a. Techniky AJAX

== Skúška ==

 1. "Teoretická otázka", vysvetliť dôležité aspekty niektorej z týchto tém.
  a. IP protokol - adresácia, smerovanie
  a. TCP a UDP protokol, spoločné vlastnosti, rozdiely, spôsob použitia v programoch -- sockety.
  a. Princípy fungovania TCP protokolu, emulácia spoľahlivého spájaného prenosu cez IP.
  a. HTTP protokol - základy.
  a. CGI skripty - spôsob fungovania, použitie s HTML formulármi.
  a. Pokročilé aspekty HTTP - cookies, autorizácia.
 1. Budem chcieť navrhnúť a ústne obhájiť nejaký aplikačný protokol. Podrobnosti toho, ako si to predstavujem, poviem na prednáške.

=== Príklad zadania na skúšku z roku 2010 ===

[[attachment:skuska_2010.pdf]]

== Zadania na cviko ==
 
== Šablóny programov, programy, html a css súbory ==

Na bitbucket.org: http://bitbucket.org/gjenca/python_vyuka_public/ .

=== Stiahnuť všetko naraz ako zip ===

http://bitbucket.org/gjenca/python_vyuka_public/get/tip.zip

alebo (s inštalovaným mercurialom) príkazom

{{{
hg clone http://bitbucket.org/gjenca/python_vyuka_public/
}}}

Ak už máte raz stiahnuté dáta pomocou {{{hg clone}}}, stačí už len v adresári projektu napísať
{{{
hg pull
hg update
}}}.

V prípade, že sa mercurial pri príkaze {{{update}}} sťažuje na konflikty, znamená to, že ste
niečo zmenili v pracovnom adresári. Vtedy treba napísať
{{{
hg update -C
}}}



=== TCP/UDP klient/server ===

|| TCP server bez súbežnej obsluhy viacerých klientov || http://bitbucket.org/gjenca/python_vyuka_public/raw/tip/tcp_server.py ||
|| TCP server so súbežnou obsluhou viacerých klientov || http://bitbucket.org/gjenca/python_vyuka_public/raw/tip/tcp_server_fork.py ||
|| TCP klient || http://bitbucket.org/gjenca/python_vyuka_public/raw/tip/tcp_client.py ||
|| UDP server || http://bitbucket.org/gjenca/python_vyuka_public/raw/tip/udp_server.py ||
|| UDP klient || http://bitbucket.org/gjenca/python_vyuka_public/raw/tip/udp_client.py ||

=== Sumátor klient a server ===

|| Sumátor server || http://bitbucket.org/gjenca/python_vyuka_public/raw/tip/tcp_sumator_server.py ||
|| Sumátor klient || http://bitbucket.org/gjenca/python_vyuka_public/raw/tip/tcp_sumator_client.py ||

=== Jednoduchý HTTP server ===

|| Jednoduchý HTTP server || http://bitbucket.org/gjenca/python_vyuka_public/raw/tip/http_server.py ||

=== CGI skripty ===
|| Testovací bez CGI modulu || http://bitbucket.org/gjenca/python_vyuka_public/raw/tip/cgiserver/cgi-bin/test.py ||
|| Testovací s CGI modulom || http://bitbucket.org/gjenca/python_vyuka_public/raw/tip/cgiserver/cgi-bin/test2.py ||
|| Vypisovanie a spracovanie formulára || http://bitbucket.org/gjenca/python_vyuka_public/raw/tip/cgiserver/cgi-bin/form.py ||
|| Vypisovanie a spracovanie formulára - matematika || http://bitbucket.org/gjenca/python_vyuka_public/raw/tip/cgiserver/cgi-bin/matika.py ||
|| Vypisovanie a spracovanie formulára - sin a cos || http://bitbucket.org/gjenca/python_vyuka_public/raw/tip/cgiserver/cgi-bin/sincos.py ||
=== XHTML stránky ===
|| Stránka so základnými XHTML elementami || http://bitbucket.org/gjenca/python_vyuka_public/raw/tip/simple2.html ||
|| Stránka pre skúšanie CSS || http://bitbucket.org/gjenca/python_vyuka_public/raw/tip/pagelayout.html ||
|| Minimálna stránka || http://bitbucket.org/gjenca/python_vyuka_public/raw/tip/kostra.html ||

## == Odovzdávanie programov ==

## [[/OdovzdavanieProgramov | Stránka pre odovzdávanie programov ]]

Počítačové siete

2011/2012 -- zimný semester

Domáce zadanie na 1. cviko

cviko1.pdf

Zadanie na 2. cviko

zadanie2.pdf

Zadanie na 3. cviko

3. zápočtové cviko bude dňa 13.12.2011. Dostanete nejaké HTML a obrázok a Vašou úlohou bude napísať CSS tak, aby sa vykreslilo približne tak, ako je na obrázku.

Náhradné zápočtové cviko (pre tých, čo boli chorí na niektorom z normálnych zápočtových cvičení) bude v piatok 16.12.2011, čas bude špecifikovaný neskôr.

Domáce zadania na náhradné cviko sú rovnaké, zadania v piatok budú však iné ako na normálnom cviku.

Vyučujúci

Konzultácie

Pondelok 16:00 -- 17:00

Oznamy

Druhé skúšobné počítačové cvičenie bude 28.11.2011. Budete písať cgi skript, ktorý bude mať za úlohu zobrazenie nejakého webového formulára, načítanie údajov z neho a uloženie údajov v textovej podobe do nejakého súboru na disku.

Spôsob fungovania má byť taký, ako bolo odprednášané: zobrazenie prázdneho formulára v GET vetve a spracovanie údajov v POST vetve toho istého skriptu. Môžete a máte používať modul cgi. V repozitári je niekoľko skriptov vypisujúcich a spracujúcich formuláre, skript sincos.py z prednášky som dotiahol do konca.

Na cvičení vám potom budem špecifikovať formulár a požadovaný tvar, v ktorom treba zapísať údaje.

Stručná osnova predmetu

  • Taxonómia počítačových sietí
  • Vrstvový model
  • Sieťová vrstva, routing
  • Základy konfigurácie sietí a služieb
  • Transportná vrstva, sockety
  • Aplikačná vrstva
  • Aplikačné protokoly
  • HTTP
  • HTML a CSS, dizajn web stránok
  • Dynamické webové stránky pomocou CGI skriptov
  • JavaScript, AJAX

Literatúra

  1. Andrew S. Tanenbaum, Computer Networks, 4. vydanie, Prentice-Hall

  2. Craig Hunt, TCP/IP Network administration, 3. vydanie, O'Reilly, http://docstore.mik.ua/orelly/networking_2ndEd/tcp/index.htm

  3. David Gourley, Brian Totty, Marjorie Sayer, Anshu Aggarwal, Sailu Reddy, et al., HTTP: The Definitive Guide, O'Reilly (2002)

  4. David Flanagan, JavaScript: The Definitive Guide, O'Reilly Media, Inc.; 5th edition (2006)

Webové stránky

  1. e-archiv Jiřího Peterky: Přednášky:

  2. HTML and CSS Tutorials, References, and Articles, http://htmldog.com/

  3. Jak psát web, http://www.jakpsatweb.cz/

  4. Color scheme designer, http://colorschemedesigner.com/

  5. Selectutorial: CSS selectors, http://css.maxdesign.com.au/selectutorial/

  6. Allowed nesting of elements in HTML 4 (and XHTML 1.0), http://www.cs.tut.fi/~jkorpela/html/nesting.html

  7. The W3C Markup Validation Service, http://validator.w3.org/

  8. The W3C CSS Validation Service, http://jigsaw.w3.org/css-validator/

  9. CSS Zen Garden, http://www.csszengarden.com/

  10. Mercurial SCM, http://mercurial.selenic.com/

  11. Mercurial: The Definitive Guide by Bryan O'Sullivan, http://hgbook.red-bean.com/

O mercuriali

mercurial

Podmienky na zápočet

  • Počas semestra sa bude udeľovať 40 bodov. Na zápočet je potrebných 20 bodov.
  • 40 bodov bude udeľovaných za tieto veci:
    • Tri zápočtové cvičenia vypracované ako rozšírenie domácich zadaní
      • TCP/IP a sockety
      • CGI skripty
      • Jedno zápočtové cvičenie z CSS

Výsledky

/Vysledky

Témy jednotlivých prednášok

  1. Vrstvové referenčné modely.
    1. Model ISO/OSI
    2. Model TCP/IP
  2. Problém riadenia súbežného prístupu (MAC)
    1. Centralizované a decentralizované modely, deterministické a nedeterministické modely
    2. Modely s centrálnym arbitrom, token ring
    3. ALOHA, slotted ALOHA, CSMA, CD, Ethernet
  3. Sieťová vrstva, adresácia, smerovanie
    1. IPv4 adresy, triedy A,B,C
    2. Privátne adresy
    3. Sieťová a broadcast adresa
    4. Preklad IP adries (masquerading)
  4. Transportná vrstva, UDP, TCP
    1. Protokoly TCP a UDP
    2. Softwarové rozhranie pre prístup k transportnej vrstve - sockety
    3. Šablóny programov "klient" a "server" - fork prístup k servru.
  5. Aplikačné protokoly
    1. Základy fungovania DNS, SMTP
    2. Protokol HTTP
  6. HTML a CSS
    1. XHTML 1.0
    2. Štylizácia HTML pomocou kaskádových štýlov
  7. Dynamický web
    1. Základné princípy dynamického webu
    2. CGI
  8. Pokročilé aspekty HTTP
    1. Autorizácia (Basic)
    2. Cookies
  9. Web 2.0
    1. JavaScript cez jquery

    2. Techniky AJAX

Skúška

  1. "Teoretická otázka", vysvetliť dôležité aspekty niektorej z týchto tém.
    1. IP protokol - adresácia, smerovanie
    2. TCP a UDP protokol, spoločné vlastnosti, rozdiely, spôsob použitia v programoch -- sockety.
    3. Princípy fungovania TCP protokolu, emulácia spoľahlivého spájaného prenosu cez IP.
    4. HTTP protokol - základy.
    5. CGI skripty - spôsob fungovania, použitie s HTML formulármi.
    6. Pokročilé aspekty HTTP - cookies, autorizácia.
  2. Budem chcieť navrhnúť a ústne obhájiť nejaký aplikačný protokol. Podrobnosti toho, ako si to predstavujem, poviem na prednáške.

Príklad zadania na skúšku z roku 2010

skuska_2010.pdf

Zadania na cviko

Šablóny programov, programy, html a css súbory

Na bitbucket.org: http://bitbucket.org/gjenca/python_vyuka_public/ .

Stiahnuť všetko naraz ako zip

http://bitbucket.org/gjenca/python_vyuka_public/get/tip.zip

alebo (s inštalovaným mercurialom) príkazom

hg clone http://bitbucket.org/gjenca/python_vyuka_public/

Ak už máte raz stiahnuté dáta pomocou hg clone, stačí už len v adresári projektu napísať

hg pull
hg update

.

V prípade, že sa mercurial pri príkaze update sťažuje na konflikty, znamená to, že ste niečo zmenili v pracovnom adresári. Vtedy treba napísať

hg update -C

TCP/UDP klient/server

TCP server bez súbežnej obsluhy viacerých klientov

http://bitbucket.org/gjenca/python_vyuka_public/raw/tip/tcp_server.py

TCP server so súbežnou obsluhou viacerých klientov

http://bitbucket.org/gjenca/python_vyuka_public/raw/tip/tcp_server_fork.py

TCP klient

http://bitbucket.org/gjenca/python_vyuka_public/raw/tip/tcp_client.py

UDP server

http://bitbucket.org/gjenca/python_vyuka_public/raw/tip/udp_server.py

UDP klient

http://bitbucket.org/gjenca/python_vyuka_public/raw/tip/udp_client.py

Sumátor klient a server

Sumátor server

http://bitbucket.org/gjenca/python_vyuka_public/raw/tip/tcp_sumator_server.py

Sumátor klient

http://bitbucket.org/gjenca/python_vyuka_public/raw/tip/tcp_sumator_client.py

Jednoduchý HTTP server

Jednoduchý HTTP server

http://bitbucket.org/gjenca/python_vyuka_public/raw/tip/http_server.py

CGI skripty

Testovací bez CGI modulu

http://bitbucket.org/gjenca/python_vyuka_public/raw/tip/cgiserver/cgi-bin/test.py

Testovací s CGI modulom

http://bitbucket.org/gjenca/python_vyuka_public/raw/tip/cgiserver/cgi-bin/test2.py

Vypisovanie a spracovanie formulára

http://bitbucket.org/gjenca/python_vyuka_public/raw/tip/cgiserver/cgi-bin/form.py

Vypisovanie a spracovanie formulára - matematika

http://bitbucket.org/gjenca/python_vyuka_public/raw/tip/cgiserver/cgi-bin/matika.py

Vypisovanie a spracovanie formulára - sin a cos

http://bitbucket.org/gjenca/python_vyuka_public/raw/tip/cgiserver/cgi-bin/sincos.py

XHTML stránky

Stránka so základnými XHTML elementami

http://bitbucket.org/gjenca/python_vyuka_public/raw/tip/simple2.html

Stránka pre skúšanie CSS

http://bitbucket.org/gjenca/python_vyuka_public/raw/tip/pagelayout.html

Minimálna stránka

http://bitbucket.org/gjenca/python_vyuka_public/raw/tip/kostra.html

KMaDGWiki: PocitacoveSiete (last edited 2024-04-29 10:38:09 by jenca)