Budowa aplikacji wielowarstwowych. Zastosowanie szablonów, tabel oraz plików typu properties
|
|
- Oskar Wróblewski
- 5 lat temu
- Przeglądów:
Transkrypt
1 Budowa aplikacji wielowarstwowych. Zastosowanie szablonów, tabel oraz plików typu properties Laboratorium 3 Technologie internetowe Zofia Kruczkiewicz 1
2 Wykaz pytań dotyczących materiału wykorzystanego w lab3, które należy opracować (wykłady : 4,5, instrukcja do lab1). 1. Jak jest przechowywany obiekt typu Produkt1 w obiekcie typu Fasada_warstwy_biznesowej? 2. Do czego służy metoda items() w klasie typu Fasada_warstwy_biznesowej? Należy okreslić, jakie dane są przetwarzane w tej metodzie oraz gdzie są wykorzystane dane utworzone przez metodę items()? 3. Jaki atrybut w klasie Managed_ produkt zawiera dane prezentowane za pomocą komponentu <h:datatable> na stronie lista_produktow.xhtml? 4. Jak tworzona jest zawartość komponentu <h:datatable> na stronie lista_produktow.xhtml? Należy podać, do czego służą atrybuty items oraz item znacznika <h:datatable>: <h:datatable value="#{managed_produkt.items" var="item"... oraz jakie znaczniki są wykorzystane do tworzenia kolumnny w tabeli, jaki znacznik jest wykorzystany do tworzenia nagłówka tabeli oraz jaki znacznik służy do prezentacji danych w kolumnie tabeli. Nalezy to wykonać na podstawie znaczników podach poniżej: <h:column> <f:facet name="header"> <h:outputtext value="#{bundle.lista_produktow_nazwa"/> </f:facet> <h:outputtext value="#{item.get(0)"/> </h:column> 5. Kiedy na stronie lista_produktow.xhtml wyświetlany jest napis zdefiniowany w atrybucie value analizując fragment kodu strony JSF: <h:outputtext escape="false" value="#{bundle.lista_produktow_pusta" rendered="#{managed_produkt.items.rowcount == 0"/> 6. Kiedy na stronie lista_produktow.xhtml wyświetlana zawartość tabeli analizując fragment strony lista_produktow.xhtml: <h:panelgroup rendered="#{managed_produkt.items.rowcount > 0"> <h:datatable value="#{managed_produkt.items" var="item" Jaka rolę pełni plik Bundle.properties w budowie stron xhtml? Jak należy korzystać z tego pliku? 2
3 Przykład 3 Zastosowanie szablonu i znacznika h:datatable do prezentowania zbioru produktów. Należy w proponowanych zmianach w projekcie z przykładu 3 uwzględnić nowy/nowe atrybut/atrybuty obiektu typu Produkt1, wprowadzone podczas realizacji zadania w lab2. 3
4 1. Tworzenie kopii projektu typu Web Application o nazwie Sklep_3 z lab2 - Przykład1 (prawy klawisz myszy na nazwie projektu i wybór Copy na formularzu kopiowania należy podać nową nazwę projektu Sklep_3. Projekt źródłowy Sklep_2 należy zamknąć, spakować do formatu zip lub rar i usunąć wersję niespakowaną. 2. Należy zmienić nazwy plików dodaj_produkt1 i rezultat1 na dodaj_produkt2 i rezultat2 w folderze warstwa_internetowa_jsf następująco: kliknąć prawym klawiszem myszy na nazwę strony np. dodaj_produkt1.xtml i wybrać kolejno z list: Refactor/Rename. W formularzu Rename, w polu New Name należy wprowadzić nową nazwę: dodaj_produkt2. Podobnie należy zmienić nazwę strony rezultat2.xhtml.
5 2. Należy zmodyfikować kod klasy Fasada_warstwy_biznesowej package warstwa_biznesowa; import java.util.arraylist; import javax.ejb.stateless; import public class Fasada_warstwy_biznesowej { /* pozostały kod bez zmian */ public ArrayList<ArrayList<String>> items() { ArrayList<ArrayList<String>> dane = new ArrayList(); ArrayList<String> wiersz = new ArrayList(); if (produkt!=null) { wiersz.add(produkt.getnazwa()); wiersz.add("" + produkt.getcena()); wiersz.add("" + produkt.getpromocja()); wiersz.add("" + produkt.cena_brutto()); dane.add(wiersz); return dane; Dane przechowywanego obiektu typu Produkt1 przeznaczone do prezentacji w komponencie datatable Jest to kolekcja elementów, które są kolekcją elementów typu String reprezentująca atrybuty i wyliczoną cenę brutto obiektu typu Produkt1 5
6 package warstwa_internetowa; import warstwa_biznesowa.fasada_warstwy_biznesowej; import javax.ejb.ejb; import javax.faces.bean.managedbean; import javax.faces.bean.requestscoped; import javax.faces.model.datamodel; public class Managed_produkt { 3. Należy zmodyfikować definicję klasy private Fasada_warstwy_biznesowej fasada; private String nazwa; private String cena; private String promocja; private String cena_brutto; private DataModel items; DataModel model danych komponentu datatable public Managed_produkt() { public Fasada_warstwy_biznesowej getfasada() { return fasada; public void setfasada(fasada_warstwy_biznesowej fasada) { this.fasada = fasada; 6
7 public String getnazwa() { return nazwa; public void setnazwa(string nazwa) { this.nazwa = nazwa; public String getcena() { return cena; public void setcena(string cena) { this.cena = cena; public String getpromocja() { return promocja; public void setpromocja(string promocja) { this.promocja = promocja; public String getcena_brutto() { return cena_brutto; public void setcena_brutto(string cena_brutto) { this.cena_brutto = cena_brutto; 7
8 public DataModel utworz_datamodel() { return new ListDataModel(fasada.items()); public DataModel getitems() { if (items == null) { items = utworz_datamodel(); return items; Utworzenie modelu komponentu datatable na podstawie kolekcji zawierających elementy reprezentujące wiersz tabeli (kolekcja obiektów typu String reprezentująca atrybuty obiektu typu Produkt oraz cenę brutto) public void setitems(datamodel items) { this.items = items; 8
9 Dodane metod do klasy Managed_produkt obsługujących dodawanie produktu (dodaj_produkt) po pobraniu danych z formularza za pomocą atrybutów: nazwa, cena, promocja i wywołaniu metody utworz_produkt ziarna EJB z obiektu fasada klasy typu Fasada_warstwy_biznesowej oraz wyświetlanie danych za pomocą metody dane_produktu pobranych z warstwy biznesowej od obiektu typu EJB fasada za pomocą metody dane_produktu public String dodaj_produkt() { String[] dane = {nazwa, cena, promocja; fasada.utworz_produkt(dane); dane_produktu(); return "rezultat2"; public void dane_produktu() { String[] dane = fasada.dane_produktu(); nazwa = dane[0]; cena = dane[1]; promocja = dane[2]; cena_brutto = dane[3]; 9
10 4. Należy zmodyfikować definicję szablonu template.xhtml dodanie w części przeznaczonej na menu (id=left) linku do strony lista_produktow.xhtml oraz znacznik <h:panelgroup> do obsługi wyświetlania błędów podczas wstawiania danych <?xml version='1.0' encoding='utf-8'?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" " <html xmlns=" xmlns:ui=" xmlns:h=" <h:head> <meta http-equiv="content-type" content="text/html; charset=utf-8" /> <h:outputstylesheet name="css/default.css" /> <h:outputstylesheet name="css/csslayout.css"/> <title><ui:insert name="title">facelets Template</ui:insert></title> </h:head> <h:body> <div id="top"> <ui:insert name="top">top</ui:insert> </div> 10
11 <div> <div id="left"> <h:link outcome="/faces/warstwa_internetowa_jsf/dodaj_produkt2" value="dodaj produkt"/><br/> <h:link outcome="/faces/warstwa_internetowa_jsf/lista_produktow" value="lista produktow"/> </div> <div id="content" class="left_content"> <ui:insert name="content">content</ui:insert> </div> </div> <h:panelgroup id="messagepanel" layout="block"> <h:messages errorstyle="color: red" infostyle="color: green" /> </h:panelgroup> <div id="bottom"> <ui:insert name="bottom">bottom</ui:insert> </div> </h:body> </html> 11
12 5. Należy w pliku kaskadowego arkusza stylu csslayout.css w katalogu projektu: Web Pages/resources/css (okno Projects) wprowadzić zmianę stylu wyświetlania części strony: <div id="content" class="left_content"> <ui:insert name="content">content</ui:insert> </div> w stylu o nazwie.left_content, aby ustalić obszar przeznaczony na część roboczą strony.left_content { background-color: #dddddd; padding: 5px; margin-left: 170px;.left_content { background-color: #dddddd; padding: 5px; margin-left: 170px; min-height: 50px; 12
13 6. Należy dodać do projektu stronę lista_produktow.xhtml opartą na szablonie template.xhtml i umieścić w katalogu Web Pages/warstwa_internetowa_jsf (okno Projects) poniżej zawartość strony lista_produktow.xhtml do wyświetlania listy produktów dodana do projektu- New/Other/JavaServer Faces/ Facelets Template Client... <?xml version='1.0' encoding='utf-8'?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" " <html xmlns=" xmlns:ui=" xmlns:h=" xmlns:f=" <body> <ui:composition template="./../template.xhtml"> <ui:define name="title"> <h:outputtext value="#{bundle.lista_produktow_tytul"></h:outputtext> </ui:define> <ui:define name="content"> <h:form> <h:outputtext escape="false" value="#{bundle. Lista_produktow_pusta" rendered="#{managed_produkt.items.rowcount == 0"/> <h:panelgroup rendered="#{managed_produkt.items.rowcount > 0"> 13
14 <h:datatable value="#{managed_produkt.items" var="item" border="0" cellpadding="2" cellspacing="0" rowclasses="jsfcrud_odd_row,jsfcrud_even_row" rules="all" style="border:solid 1px"> Komponent typu datatable zbindowany z obiektem items typu DataModel <h:column> <f:facet name="header"> Nagłówek kolumny tabeli datatable <h:outputtext value="#{bundle.lista_produktow_nazwa"/> </f:facet> <h:outputtext value="#{item.get(0)"/> </h:column> <h:column> <f:facet name="header"> <h:outputtext value="#{bundle.lista_produktow_cena"/> </f:facet> <h:outputtext value="#{item.get(1)"/> </h:column> Item element kolekcji items (zawierający dane atrybutów obiektu typu Produkt oraz cenę brutto Kolejny element kolekcji item (zawierający dane atrybutu nazwa obiektu typu Produkt), która jest elementem kolekcji items typu DataModel Kolejny element kolekcji item (zawierający dane atrybutu cena obiektu typu Produkt), która jest elementem kolekcji items typu DataModel
15 <h:column> <f:facet name="header"> <h:outputtext value="#{bundle.lista_produktow_promocja"/> </f:facet> <h:outputtext value="#{item.get(2)"/> </h:column> <h:column> <f:facet name="header"> <h:outputtext value="#{bundle.lista_produktow_cenabrutto"/> </f:facet> <h:outputtext value="#{item.get(3)"/> </h:column> </h:datatable> </h:panelgroup> <h:commandbutton id="powrot" value="#{bundle.lista_produktow_powrot" action="/faces/index1"/> </h:form> </ui:define> </ui:composition> </body> </html> Kolejny element kolekcji item (zawierający dane atrybutu promocja obiektu typu Produkt), która jest elementem kolekcji items typu DataModel Kolejny element kolekcji item (zawierający dane ceny brutto wyznaczanej przez metodę cena_brutto obiektu typu Produkt), która jest elementem kolekcji items typu DataModel
16 7. Dodanie pliku konfiguracji projektu faces-config.xml (New/Other/JavaServer Faces/ JSF Faces Configuration) 16
17 Dodanie pliku konfiguracji projektu faces-config.xml 17
18 8. Dodanie pliku typu properties do projektu: prawy klawisz na Source Packages, New/Other/Other/Properties File
19 Dodanie pliku typu properties do projektu 19
20 Zawartość pliku Bundle.properties zawierająca treść komunikatów.
21 Zawartość pliku Bundle.properties zawierająca treść komunikatów używanych na stronie lista_produktow.xhtml. Należy w taki sam sposób zastąpić komunikaty w pozostałych plikach xhtml Lista_produktow_tytul=Lista produktow Lista_produktow_pusta=Brak danych Lista_produktow_nazwa=Nazwa produktu Lista_produktow_cena=Cena netto produktu Lista_produktow_promocja=Promocja produktu Lista_produktow_cenabrutto=Cena brutto Lista_produktow_powrot=Powrot 21
22 9. Należy zadeklarować plik Bundle.properties w pliku konfiguracyjnym facesconfig.xml. 22
23 10. Uruchomienie aplikacji Widok strony lista_produktow.xhtml po kliknięciu na Lista produktow 23
24 Widok po kliknięciu na Dodaj produkt na stronie index1.xhtml i kliknięciu na przycisk OK bez wprowadzenia danych produktu Widok po kliknięciu na Dodaj produkt na stronie index1.xhtml i wprowadzeniu danych Widok po kliknięciu na Ok na stronie dodaj_produkt2.xhtml po wprowadzeniyudanych produktu
25 Widok po kliknięciu na Powrot na stronie rezultat2.xhtml Widok po kliknięciu na Lista produktow na stronie index1.xhtml 25
26 Widok po kliknięciu na klawisz Powrot na stronie lista_produktow.xhtml, następnie wybranie pozycji z lewej strony okna: Dodaj produkt i po położeniu kursora myszy na polu z etykietą Podaj nazwe produktu wyświetlenie zawartości atrybutu tytul znacznika <h:inputtytul> <h:inputtext id="nazwa" title="podaj nazwe:" value="#{managed_produkt.nazwa" required="true" requiredmessage="blad: Podaj nazwe." > </h:inputtext>
27 11. Należy przenieść wszystkie komunikaty do pliku Bundle.properties ze stron dodaj_produkt2.xhtml, rezultat2.xhtml, rozróżniając w nazwie komunikatu przynależność do strony. Część komunikatów strony lista_produktow.xhtml można wykorzystać na stronie rezultat2.xhtml. Poniżej pokazano fragment pliku typu properties oraz przykład zastosowania komunikatów z tego pliku. Następny slajd pokazuje kolejny przykład wykorzystania pliku typu properties. Fragment zawartości pliku Bundle.properties po proponowanych zmianach lista_produktow.tytul=lista produktow lista_produktow.pusta=brak danych lista_produktow.nazwa=nazwa produktu lista_produktow.cena=cena netto produktu lista_produktow.promocja=promocja produktu lista_produktow.cena_brutto=cena brutto lista_produktow.powrot=powrot Fragment zawartości pliku lista_produktow.xhtml po proponowanych zmianach zmiana odwołania do komunikatu w postaci indeksowania nazwą komunikatu zawartości pliku Bundle.properties. Podobne odwołania należy wykonać we wszystkich plikach xhtml, zawierających komunikaty (atrybuty: value, requiredmessage) <body> <ui:composition template="./../template.xhtml"> <ui:define name="title"> <h:outputtext value="#{bundle['lista_produktow.tytul']" /> </ui:define> <ui:define name="content"> <h:form styleclass="jsfcrud_list_form"> <h:outputtext escape="false" value="#{bundle['lista_produktow.pusta']" rendered="#{managed_produkt.items.rowcount == 0"/>
Budowa aplikacji wielowarstwowych. Zastosowanie szablonów, tabel oraz plików typu properties
Budowa aplikacji wielowarstwowych. Zastosowanie szablonów, tabel oraz plików typu properties Laboratorium 3 Technologie internetowe Zofia Kruczkiewicz 1 Wykaz pytań dotyczących materiału wykorzystanego
Budowa aplikacji wielowarstwowych. Zastosowanie szablonów, tabel oraz plików typu properties
Budowa aplikacji wielowarstwowych. Zastosowanie szablonów, tabel oraz plików typu properties Laboratorium 4 Technologie internetowe Zofia Kruczkiewicz 1 Wykaz pytań dotyczących materiału wykorzystanego
Budowa aplikacji wielowarstwowych. Zastosowanie szablonów
Budowa aplikacji wielowarstwowych. Zastosowanie szablonów Laboratorium 2 Technologie internetowe Zofia Kruczkiewicz 1 Wykaz pytań dotyczących materiału wykorzystanego w lab2, które należy opracować (wykład
Wielowarstwowa aplikacja internetowa. Wykonanie widoku typu tabela. Pliki typu properties. wg
Wielowarstwowa aplikacja internetowa. Wykonanie widoku typu tabela. Pliki typu properties. wg https://docs.oracle.com/javaee/7/jeett.pdf Technologie internetowe 5 1 Przykład 12 wielowarstwowa aplikacja
Budowa aplikacji wielowarstwowych zastosowanie szablonów. Laboratorium 2 Programowanie komponentowe Zofia Kruczkiewicz
Budowa aplikacji wielowarstwowych zastosowanie szablonów Laboratorium 2 Programowanie komponentowe Zofia Kruczkiewicz Przykład 1 Zastosowanie szablonów Tworzenie kopii projektu typu Web Application o nazwie
Budowa aplikacji wielowarstwowych. Zastosowanie konwerterów oraz plików typu properties.
Budowa aplikacji wielowarstwowych. Zastosowanie konwerterów oraz plików typu properties. Laboratorium 4 Technologie internetowe Zofia Kruczkiewicz TINT_Lab_4, Zofia Kruczkiewicz 1 Wykaz pytań dotyczących
Projektowanie i wdrażanie systemów informatycznych. Dodanie aplikacji klienta uruchamianej przez przeglądarkę kontynuacja projektu:
Instrukcja tworzenia aplikacji EE na bazie aplikacji prezentowanej na zajęciach lab.4 z PIO zawierającej aplikację klienta typu EE oraz internetową aplikację uruchamianą za pomocą przeglądarki. Projektowanie
Budowa aplikacji wielowarstwowych, zastosowanie obiektów transferowych, konwerterów i walidatorów
Budowa aplikacji wielowarstwowych, zastosowanie obiektów transferowych, konwerterów i walidatorów Laboratorium 3 Programowanie komponentowe Zofia Kruczkiewicz Konieczne ustawienie kodowania UTF-8 w projektach
Budowa aplikacji wielowarstwowych. Zastosowanie Kaskadowych arkuszy stylów (CSS)
Budowa aplikacji wielowarstwowych. Zastosowanie Kaskadowych arkuszy stylów (CSS) Laboratorium 7 Technologie internetowe Zofia Kruczkiewicz TINT_Lab_7, Zofia Kruczkiewicz 1 Wykaz pytań dotyczących materiału
Zastosowanie słuchaczy zdarzeń wg
Zastosowanie słuchaczy zdarzeń wg https://docs.oracle.com/javaee/7/jeett.pdf Technologie internetowe 6 1. Obsługa zdarzeń typu valuechangelistener Rejestracja słuchaczy zdarzeń typu valuechangelistener
Budowa prostej aplikacji wielowarstwowej
Budowa prostej aplikacji wielowarstwowej Laboratorium 1 Technologie internetowe https://docs.oracle.com/javaee/7/javaserver-faces-2-2/vdldocs-facelets/toc.htm Zofia Kruczkiewicz 1 Wykaz pytań dotyczących
Złożone komponenty JSF wg
Złożone komponenty JSF wg https://docs.oracle.com/javaee/7/jeett.pdf http://www.coreservlets.com Technologie internetowe 9 1 Opis znaczników obsługiwanych przez Facelets (tutorial EE 7) 2 Przegląd znaczników
Budowa aplikacji wielowarstwowych. Obsługa zdarzeń
Budowa aplikacji wielowarstwowych. Obsługa zdarzeń Laboratorium 6 Technologie internetowe Zofia Kruczkiewicz TINT_Lab_6, Zofia Kruczkiewicz 1 Wykaz pytań dotyczących materiału wykorzystanego w lab6, które
Podstawowe informacje o technologii Java Persistence API - przykład
Podstawowe informacje o technologii Java Persistence API - przykład na podstawie https://docs.oracle.com/javaee/7/jeett.pdf Programowanie komponentowe 3_2 1 1. Wykonanie kopii programu Sklep_6 2 1. Wykonanie
Złożone komponenty JSF wg
Złożone komponenty JSF wg https://docs.oracle.com/javaee/7/jeett.pdf http://www.coreservlets.com Technologie internetowe 8 Technologie internetowe 8, Zofia 1 Opis znaczników obsługiwanych przez Facelets
Budowa aplikacji wielowarstwowych. Zastosowanie technologii Ajax
Budowa aplikacji wielowarstwowych. Zastosowanie technologii Ajax Laboratorium 5 Technologie internetowe Zofia Kruczkiewicz TINT_Lab_5, Zofia Kruczkiewicz 1 Wykaz pytań dotyczących materiału wykorzystanego
Budowa aplikacji wielowarstwowych. Zastosowanie technologii Ajax
Budowa aplikacji wielowarstwowych. Zastosowanie technologii Ajax Laboratorium 6 Technologie internetowe Zofia Kruczkiewicz TINT_Lab_6, Zofia Kruczkiewicz 1 Wykaz pytań dotyczących materiału wykorzystanego
Podstawy technologii JavaServer Faces wg
Podstawy technologii JavaServer Faces wg https://docs.oracle.com/javaee/7/jeett.pdf Technologie internetowe 4 1 (5) Dodawanie wybranych znaczników do strony Kontynuacja zagadnień z wykładu 3 2 (5) Dodawanie
Budowa aplikacji wielowarstwowych. Obsługa zdarzeń, zastosowanie walidatorów, wykonanie listy typu Drop Down List.
Budowa aplikacji wielowarstwowych. Obsługa zdarzeń, zastosowanie walidatorów, wykonanie listy typu Drop Down List. Laboratorium 5 Technologie internetowe Zofia Kruczkiewicz TINT_Lab_5, Zofia Kruczkiewicz
Programowanie komponentowe 5
Budowa warstwy klienta w architekturze typu klient-serwer zbudowanych z komponentów typu EE - klient desktopowy i internetowy. Zastosowanie komponentów opartych na technologii EJB 3.2. na podstawie https://docs.oracle.com/javaee/7/jeett.pdf
Zastosowanie komponentów EJB typu Session
Zastosowanie komponentów EJB typu Session na podstawie https://docs.oracle.com/javaee/7/jeett.pdf Programowanie komponentowe Lab1 1 1. Refaktoryzacja kodu programu Sklep_6 z lab5, TINT 1.1. Należy wykonać
Kontynuacja programu z lab2 refaktoryzacja kodu oparta na dodaniu obiektu transferowego oraz stronicowania tabeli w formularzu JSF
Kontynuacja programu z lab2 refaktoryzacja kodu oparta na dodaniu obiektu transferowego oraz stronicowania tabeli w formularzu JSF na podstawie https://docs.oracle.com/javaee/7/jeett.pdf Programowanie
Podstawowe informacje o technologii Java Persistence API - przykład
Podstawowe informacje o technologii Java Persistence API - przykład na podstawie https://docs.oracle.com/javaee/7/jeett.pdf Programowanie komponentowe lab5 1 1 (1). Przygotowanie projektów kopii projektów
Budowa prostej aplikacji wielowarstwowej. Laboratorium 1 Programowanie komponentowe Zofia Kruczkiewicz
Budowa prostej aplikacji wielowarstwowej Laboratorium 1 Programowanie komponentowe Zofia Kruczkiewicz Konfigurowanie edytora programu za pomocą Tools/Options/Editor Konfigurowanie edytora programu za pomocą
Internacjonalizacja i lokalizowanie aplikacji internetowych https://docs.oracle.com/javaee/7/tutorial/webi18n.htm http://www.coreservlets.com Zastosowanie arkuszy stylów http://www.w3.org/tr/css3-selectors/
Zastosowanie kaskadowych arkuszy stylów (CSS - Cascading Style Sheets) w technologii JavaServer Faces
Zastosowanie kaskadowych arkuszy stylów (CSS - Cascading Style Sheets) w technologii JavaServer Faces wg http://www.w3.org/tr/css3-selectors/ http://courses.coreservlets.com/course-materials/pdf/jsf/jsf2/jsf2-
Nr pyt. 5 zal 4.0
Indeks Lab1 16.10 Lab223.10 Lab36.11 Lab420.11 Lab526.11 Lab610.12 Lab717.12 Lab88.01 kol Sklep_1 ob Sklep_2 ob Sklep_3 ob Sklep_4 Sklep_5 ob Sklep_6 Sklep_7 ob Sklep_6_Ajax Sklep_7_Ajax ob Sklep_6_CSob
Kontynuacja programu z lab3 zaawansowane renderowanie formularzy JSF
Kontynuacja programu z lab3 zaawansowane renderowanie formularzy JSF na podstawie https://docs.oracle.com/javaee/7/jeett.pdf Programowanie komponentowe Lab4 1 1. Przygotowanie projektów kopii projektów
Zastosowanie konwerterów wg
Zastosowanie konwerterów wg https://docs.oracle.com/javaee/7/jeett.pdf Technologie internetowe 5 (1) Konwertery liczbowe i daty Konwertery - javax.faces.convert Klasa w pakiecie javax.faces.convert BigDecimalConverter
Budowa aplikacji wielowarstwowych. zastosowanie walidatorów.
Budowa aplikacji wielowarstwowych. zastosowanie walidatorów. Laboratorium 9 Technologie internetowe Zofia Kruczkiewicz TINT_Lab_9, Zofia Kruczkiewicz 1 Wykaz pytań dotyczących materiału wykorzystanego
Przykłady tworzenia aplikacji komponentowych w technologii JavaServer Faces 2.1 na podstawie
Przykłady tworzenia aplikacji komponentowych w technologii JavaServer Faces 2.1 na podstawie http://docs.oracle.com/javaee/6/tutorial/doc/ Przykłady na podstawie zadań lab. z przedmiotu Technologie internetowe
1. Czynności przygotowujące aplikację działającą na platformie Java SE Biblioteka5 (należy ją pobrać z załącznika z p.1)
Instrukcja tworzenia aplikacji EE na podstawie aplikacji z dostępem do bazy danych, prezentowanej na zajęciach lab.5 z PIO umożliwiająca przez sieć dostęp wielu użytkownikom. Projektowanie i wdrażanie
Instrukcja tworzenia aplikacji EE na bazie aplikacji prezentowanej na zajęciach lab.4 z PIO umożliwiająca przez sieć dostęp wielu użytkownikom.
Instrukcja tworzenia aplikacji EE na bazie aplikacji prezentowanej na zajęciach lab.4 z PIO umożliwiająca przez sieć dostęp wielu użytkownikom. Projektowanie i wdrażanie systemów informatycznych Przekształcenie
Facelets ViewHandler
JSF i Facelets Wprowadzenie JSP (JavaServer Pages) są natywną i najczęściej używaną technologią do tworzenia warstwy prezentacyjnej dla JSF (JavaServer Faces) Istnieją alternatywne technologie opisu wyglądu
Przykłady pytań do zaliczenia programu wykonywanego w ramach zajęć laboratoryjnych 6-8 z Programowania komponentowego w Javie. Zofia Kruczkiewicz
Przykłady pytań do zaliczenia programu wykonywanego w ramach zajęć laboratoryjnych 6-8 z Programowania komponentowego w Javie Zofia Kruczkiewicz 1. Jakie warstwy zawiera aplikacja internetowa? 2. Wymień
termin Podobna wada 2) jak w Sklep_ , zal. 3.0 termin
Indeks Lab1-15.10 Lab2-22.10 Lab3-6.11 Lab4-20.11 Lab5- Lab6- Lab7- Lab8- Sklep_1 8.01 ob Sklep_2 ob Sklep_3 ob Sklep_4 Sklep_5 ob Sklep_6 Sklep_7 obsklep_6_ajax Sklep_7_Ajax ob ob Kol 5838 + - Błędy na
termin Podobna wada 2) jak w Sklep_ , zal. 3.0 termin
Indeks Lab1-15.10 Lab2-22.10 Lab3-6.11 Lab4-20.11 Lab5-27.11 Lab6- Lab7- Lab8- Sklep_1 8.01 ob Sklep_2 ob Sklep_3 ob Sklep_4 Sklep_5 ob Sklep_6 Sklep_7 obsklep_6_ajax Sklep_7_Ajax ob ob Kol 5838 + - 27.11
termin. Podobna wada 2) jak w Sklep_6
Indeks Lab1-15.10 Lab2-22.10 Lab3-6.11 Lab4-20.11 Lab5- Lab6- Lab7- Lab8- Sklep_1 8.01 ob Sklep_2 ob Sklep_3 ob Sklep_4 Sklep_5 obsklep_6 Sklep_7 ob Sklep_6_Ajax Sklep_7_Ajax ob ob Kol 5838 + - 5805 +
)<h:commandLink action="#{managed _produkt.dane_pro duktu}" value="ok" actionlistener="#{m anaged_produkt.
Indeks Lab1-15.10 Lab2-22.10 Lab3-6.11 Lab4-20.11 Lab5- Lab6- Lab7- Lab8- Sklep_1 ob Sklep_2 ob Sklep_3 ob Sklep_4 Sklep_5 obsklep_6 Sklep_7 ob Sklep_6_Ajax Sklep_7_Ajax ob ob Kol 5801- - + - + - Błędy:
Programowanie wielowarstwowe i komponentowe
Programowanie wielowarstwowe i komponentowe JSF 2 wprowadzenie Konfiguracja Eclipse - dodanie szablonu XHTML dla potrzeb JSF 1. Otwórz menu Window/Preferences. Następnie z drzewka wybierz Web/HTML Files/Editor/Templates.
Konwersja danych. Programowanie komponentowe 4. wg http://docs.oracle.com/javaee/6/tutorial/doc/ bnaph.html
Konwersja danych wg http://docs.oracle.com/javaee/6/tutorial/doc/ bnaph.html Programowanie komponentowe 4 Znaczniki typu f: 1. Podstawowe znaczniki JSF Znaczniki do obsługi zdarzeń f:actionlistener f:phaselistener
Zastosowanie technologii Ajax w ramach technologii JavaServer Faces wg
Zastosowanie technologii Ajax w ramach technologii JavaServer Faces wg https://docs.oracle.com/javaee/7/jeett.pdf http://www.coreservlets.com Technologie internetowe 7 Technologie internetowe 7, Zofia
Wykład 2 TINT. XHTML tabele i ramki. Zofia Kruczkiewicz
Wykład 2 TINT XHTML tabele i ramki Zofia Kruczkiewicz 1. Tabele 1.1. Przykład tabeli zawierającej kalendarz na miesiąc marzec ... definiuje tabelę Atrybuty: border ="" obramowanie tabeli,
Podstawy technologii JavaServer Faces wg https://docs.oracle.com/javaee/7/jeett.pdf
Podstawy technologii JavaServer Faces wg https://docs.oracle.com/javaee/7/jeett.pdf Technologie internetowe 3 1 Z czego składa się technologia JavaServer Faces? (wykład 2, str.2-3, 7) interfejsu programowania
Wybierz kategorię Java Web i typ projektu Web Application. Kliknij przycisk Next >.
Zaawansowane aplikacje internetowe laboratorium Hibernate. Do wykonania ćwiczeń potrzebne jest zintegrowane środowisko programistyczne NetBeans IDE 6.7.1 (do pobrania z http://www.netbeans.org/downloads/index.html).
JavaServer Faces (JSF)
JavaServer Faces (JSF) Autor wykładu: Marek Wojciechowski Plan wykładu JSF jako infrastruktura aplikacji WWW JSF.x Nowe cechy JSF.0 Java Enterprise Edition (Java EE) JavaServer Faces (JSF) Java Enterprise
Zastosowanie technologii Ajax w ramach technologii JavaServer Faces wg
Zastosowanie technologii Ajax w ramach technologii JavaServer Faces wg https://docs.oracle.com/javaee/7/jeett.pdf http://www.coreservlets.com Technologie internetowe 8 Technologie internetowe 8, Zofia
Aplikacje RMI Lab4
Aplikacje RMI https://docs.oracle.com/javase/tutorial/rmi/overview.html Lab4 Dr inż. Zofia Kruczkiewicz Programowanie aplikacji internetowych 1 1. Koncepcja budowy aplikacji RMI (aplikacja rozproszonych
Sposoby tworzenia projektu zawierającego aplet w środowisku NetBeans. Metody zabezpieczenia komputera użytkownika przed działaniem apletu.
Sposoby tworzenia projektu zawierającego aplet w środowisku NetBeans. Metody zabezpieczenia komputera użytkownika przed działaniem apletu. Dr inż. Zofia Kruczkiewicz Dwa sposoby tworzenia apletów Dwa sposoby
Podstawy technologi JavaServer Faces
Podstawy technologi JavaServer Faces wg http://docs.oracle.com/javaee/6/tutorial/doc/bnaph.html Programowanie komponentowe 3 Z czego składa się technologia JavaServer Faces? interfejsu programowania aplikacji
Instrukcja 10 Laboratorium 13 Testy akceptacyjne z wykorzystaniem narzędzia FitNesse
Instrukcja 10 Laboratorium 13 Testy akceptacyjne z wykorzystaniem narzędzia FitNesse 1 Cel laboratorium: Nabycie umiejętności przygotowywania testów akceptacyjnych za pomocą narzędzia FitNesse 1. Wg wskazówek
Budowa aplikacji wielowarstwowych cd Dostęp do bazy danych w oparciu o technologię ORM (Object Relational Mapping)
Budowa aplikacji wielowarstwowych cd Dostęp do bazy danych w oparciu o technologię ORM (Object Relational Mapping) Laboratorium 5 Programowanie komponentowe Zofia Kruczkiewicz Konieczne ustawienie kodowania
Aplikacje WWW - laboratorium
Aplikacje WWW - laboratorium JavaServer Pages Standard Tag Library Celem ćwiczenia jest zapoznanie ze standardową biblioteką znaczników JSTL. W ramach ćwiczenia zostanie skonstruowany prosty sklep internetowy
Komunikatory typu TCP/IP lab2. Dr inż. Zofia Kruczkiewicz Programowanie aplikacji internetowych
Komunikatory typu TCP/IP lab2 Dr inż. Zofia Kruczkiewicz Programowanie aplikacji internetowych Zadanie1 - klient wysyła jeden komunikat (typu String) do serwera i kończy swoje istnienie, a serwer go odbiera
Java Server Faces - wprowadzenie
Java Server Faces - wprowadzenie Java Server Faces (JSF) jest najpopularniejszą technologią opartą o język JAVA, służącą do tworzenia aplikacji webowych (dynamicznych stron WWW). pomimo że JSF i EJB wchodzą
Wprowadzenie do technologii JavaServer Faces 2.2 na podstawie Wykład 2 Technologie internetowe
Wprowadzenie do technologii JavaServer Faces 2.2 na podstawie https://docs.oracle.com/javaee/7/jeett.pdf Wykład 2 Technologie internetowe Technologie internetowe 2, Zofia Kruczkiewicz 1 Technologia JavaServer
Materiały oryginalne: ZAWWW-2st1.2-l11.tresc-1.0kolor.pdf. Materiały poprawione
Materiały oryginalne: ZAWWW-2st1.2-l11.tresc-1.0kolor.pdf Materiały poprawione Rozwiązanie zadania w NetBeans IDE 7.4: Jarosław Ksybek, Adam Miazio Celem ćwiczenia jest przygotowanie prostej aplikacji
Języki i metody programowania Java Lab2 podejście obiektowe
Języki i metody programowania Java Lab2 podejście obiektowe https://docs.oracle.com/javase/tutorial/ http://zofia.kruczkiewicz.staff.iiar.pwr.wroc.pl/wyklady/pojava/javazk4_2.pdf Zofia Kruczkiewicz 1 Zadanie
Projektowanie oprogramowania. Warstwa integracji z bazą danych oparta na technologii ORM Platforma Java EE Autor: Zofia Kruczkiewicz
Projektowanie oprogramowania Warstwa integracji z bazą danych oparta na technologii ORM Platforma Java EE Autor: Zofia Kruczkiewicz 1 Wykonanie czterowarstwowej aplikacji EE z dostępem do bazy danych,
Wstęp - Prosta aplikacja internetowa w technologii Java EE 5. Programowanie komponentowe 1
Wstęp - Prosta aplikacja internetowa w technologii Java EE 5 Programowanie komponentowe 1 Przykład 1- Wykonanie prostej aplikacji internetowej w technologii JavaEE w środowisku Netbeans 5.5 z wykorzystaniem
D:\DYDAKTYKA\ZAI_BIS\_Ćwiczenia_wzorce\04\04_poprawiony.doc 2009-lis-23, 17:44
Zaawansowane aplikacje internetowe EJB 1 Rozróżniamy dwa rodzaje beanów sesyjnych: Stateless Statefull Celem tego laboratorium jest zbadanie różnic funkcjonalnych tych dwóch rodzajów beanów. Poszczególne
Laboratorium 6 Tworzenie bloga w Zend Framework
Laboratorium 6 Tworzenie bloga w Zend Framework Przygotowanie bazy danych 1. Wykonaj skrypt blog.sql, który założy w bazie danych dwie tabele oraz wpisze do nich przykładowe dane. Tabela blog_uzytkownicy
Wykład 2 Tabele i ramki 1. Tabele 1.1. Podstawy budowy tabel na stronach WWW
Wykład 2 Tabele i ramki 1. Tabele 1.1. Podstawy budowy tabel na stronach WWW Rys.1. Przykład prostej tabeli zawierającej kalendarz na miesiąc marzec ... definiuje tabelę Atrybuty: border
Laboratorium z przedmiotu: Inżynieria Oprogramowania INP002017_ Laboratorium 11 Testy akceptacyjne z wykorzystaniem narzędzia FitNesse
Laboratorium 11 Testy akceptacyjne z wykorzystaniem narzędzia FitNesse 1 Cel laboratorium: Nabycie umiejętności przygotowywania testów akceptacyjnych za pomocą narzędzia FitNesse 1. Wg wskazówek podanych
Zaawansowane aplikacje internetowe - laboratorium
Zaawansowane aplikacje internetowe - laboratorium Hibernate. Do wykonania ćwiczeń potrzebne jest zintegrowane środowisko programistyczne NetBeans IDE 5.5 wraz z serwerem Sun Java System Application Server
Laboratorium z przedmiotu: Inżynieria Oprogramowania INP
Laboratoria 5-7- część 1 Identyfikacja klas reprezentujących logikę biznesową projektowanego oprogramowania, definicja atrybutów i operacji klas oraz związków między klasami - na podstawie analizy scenariuszy
Budowa aplikacji z graficznym interfejsem użytkownika - GUI (Graphic User Interface)
Budowa aplikacji z graficznym interfejsem użytkownika - GUI (Graphic User Interface) 1. Udostępnianie wszystkich prywatnych atrybutów do prezentacji, wprowadzenie standardu nazewnictwa plików nazwy plików
Instrukcja 2 Laboratorium z Podstaw Inżynierii Oprogramowania
Instrukcja 2 Laboratorium z Podstaw Inżynierii Oprogramowania Opis biznesowy świata rzeczywistego Wymagania funkcjonalne i niefunkcjonalne aplikacji Diagram przypadków życia Diagramy klas i sekwencji:
E:\DYDAKTYKA\ZAI\ZWWW\Laboratoria\L07\Java Persistence.doc 2011-lis-24, 17:0 Zaawansowane aplikacje internetowe Laboratorium Java Persistence.
Zaawansowane aplikacje internetowe Laboratorium Java Persistence. Adaptacja rozwiązania dla środowiska NetBeans 7.0.1: Łukasz Przytuła, opracowanie materiałów: Andrzej Dawidowicz Do wykonania ćwiczeń potrzebne
Wykład 5_2 Arkusze stylów dziedziczenie. Technologie internetowe Zofia Kruczkiewicz
Wykład 5_2 Arkusze stylów dziedziczenie Technologie internetowe Zofia Kruczkiewicz 1. Dziedziczenie stylów Zagnieżdżone elementy dziedziczą styl od elementów zagnieżdżających. Dziedziczenie stylu wynika
Laboratorium 1. Wzorce oprogramowania lab1, Zofia Kruczkiewicz
Aplikacja internetowa zbudowana w oparciu o środowisko Visual Web Java Server Faces. Zarządzanie obiektami typu SesionBeans, RequestBeen i ApplicationBeans, Laboratorium 1 Wzorce oprogramowania lab1, Okres
Programowanie wielowarstwowe i komponentowe JSP, JSF
Programowanie wielowarstwowe i komponentowe JSP, JSF JSP Cykl życia strony JSP Strony JSP są przetwarzane jako servlety, więc dziedziczą po nich wiele cech Kiedy następuje odwołanie do strony JSP, jest
Danuta ROZPŁOCH-NOWAKOWSKA Strona 1 2007-11-06. Moduł 4. Przykład 1. Przykład 2. HTML 4.01 Transitional).
Danuta ROZPŁOCH-NOWAKOWSKA Strona 1 2007-11-06 Moduł 4. Style Zajęcia poświęcone będą kaskadowym arkuszom stylów (por. slajdy 18.-27. z wykładu 2.) Wiele uwagi poświęcaliśmy do tej pory planowaniu szkieletu
Wykład 4 Delegat (delegate), właściwości indeksowane, zdarzenie (event) Zofia Kruczkiewicz
Wykład 4 Delegat (delegate), właściwości indeksowane, zdarzenie (event) Zofia Kruczkiewicz Zagadnienia 1. Delegaty wiązane, właściwości indeksowane 2. Delegaty niewiązane 3. Nowa wersja kalkulatora, delegaty
Aplikacje internetowe i rozproszone - laboratorium
Aplikacje internetowe i rozproszone - laboratorium Enterprise JavaBeans (EJB) Celem tego zestawu ćwiczeń jest zapoznanie z technologią EJB w wersji 3.0, a w szczególności: implementacja komponentów sesyjnych,
Protokół JDBC współpraca z relacyjnymi bazami danych lab3
Protokół JDBC współpraca z relacyjnymi bazami danych lab3 Dr inż. Zofia Kruczkiewicz Programowanie aplikacji internetowych JPA, lab3 Zofia Kruczkiewicz 1 Zadanie1 Połączenie z bazą danych Sample systemu
Aplikacje WWW - laboratorium
Aplikacje WWW - laboratorium JavaServer Pages Celem ćwiczenia jest zbudowanie kilku prostych stron internetowych z użyciem technologii JSP. Podczas ćwiczenia wykorzystany zostanie algorytm sortowania bąbelkowego
Programowanie komponentowe. Przykład 1 Bezpieczeństwo wg The Java EE 5 Tutorial Autor: Zofia Kruczkiewicz
Programowanie komponentowe Przykład 1 Bezpieczeństwo wg The Java EE 5 Tutorial Autor: Zofia Kruczkiewicz Struktura wykładu 1. Utworzenie użytkowników i ról na serwerze aplikacji Sun Java System Application
Diagram stanów Laboratorium 9
Diagram stanów Laboratorium 9 Zofia Kruczkiewicz Zofia Kruczkiewicz lab_inp002017_9 1 Modelowanie zachowania obiektu za pomocą diagramu stanów. Opracowanie diagramu stanów dla obiektu wybranej klasy, reprezentującego
plansoft.org Zmiany w Plansoft.org
Zmiany w Plansoft.org Mapy Google... 1 Tworzenie mapy... 2 Wprowadzanie szerokości i długości geograficznej... 2 Tworzenie mapy... 2 Dostosowanie wyglądu mapy... 3 Ograniczanie liczby zasobów do wyświetlenia
Microsoft.NET: LINQ to SQL, ASP.NET AJAX
Microsoft.NET: LINQ to SQL, ASP.NET AJAX Do realizacji projektu potrzebne jest zintegrowane środowisko programistyczne Microsoft Visual Studio 2008 oraz serwer bazy danych SQL Server Express 2005 (lub
Zaawansowane aplikacje internetowe - laboratorium Web Services (część 1).
Zaawansowane aplikacje internetowe - laboratorium Web Services (część 1). Celem ćwiczenia jest przygotowanie prostej aplikacji internetowej wykorzystującej technologię usług sieciowych (ang. Web Services).
Young Programmer: HTML+PHP. Dr inż. Małgorzata Janik, Zajęcia #2
Young Programmer: HTML+PHP Dr inż. Małgorzata Janik, Zajęcia #2 Ramowy program warsztatów Zajęcia 1: Zajęcia wprowadzające, HTML Zajęcia 2: Style CSS (tabele i kaskadowe arkusze stylów) Zajęcia 3: Podstawy
Projektowanie obiektowe. dr Jarosław Skaruz
Projektowanie obiektowe dr Jarosław Skaruz http://ii3.uph.edu.pl/~jareks jaroslaw@skaruz.com Zadanie Na terenie Siedlec funkcjonuje piekarnia Klawisz, która dostarcza swoje produkty do sklepów spożywczych.
Projekt INP Instrukcja 1. Autor Dr inż. Zofia Kruczkiewicz
Projekt INP002017 Instrukcja 1 Autor Dr inż. Zofia Kruczkiewicz I. Czynności wykonane zgodnie z harmonogramem grupy w tygodniach 1-6 1. Czynności (str. 3-12) wg instrukcji do lab3: http://zofia.kruczkiewicz.staff.iiar.pwr.wroc.pl/wyklady/inp002017/lab_inp002017_3.pdf
Zaawansowane aplikacje WWW - laboratorium
Zaawansowane aplikacje WWW - laboratorium Przetwarzanie XML (część 2) Celem ćwiczenia jest przygotowanie aplikacji, która umożliwi odczyt i przetwarzanie pliku z zawartością XML. Aplikacja, napisana w
Laboratorium 7 Blog: dodawanie i edycja wpisów
Laboratorium 7 Blog: dodawanie i edycja wpisów Dodawanie nowych wpisów Tworzenie formularza Za obsługę formularzy odpowiada klasa Zend_Form. Dla każdego formularza w projekcie tworzymy klasę dziedziczącą
ASP.NET MVC. Podstawy. Zaawansowane programowanie internetowe Instrukcja nr 3
3 ASP.NET MVC Podstawy 1 1. Cel zajęć Celem zajęć jest zapoznanie się z podstawami ASP.NET MVC 2.0 Framework. 2. Zadanie Proszę zbudować prostą aplikację WWW przy zastosowaniu framework a ASP.NET MVC 2.0
Java EE: JSF + EJB + JPA + CDI + BV
Java EE: JSF + EJB + JPA + CDI + BV Ćwiczenie 1 Celem ćwiczenia jest utworzenie prostej aplikacji bazodanowej umożliwiającej przeglądanie i dodawanie zleceń serwisowych. Ćwiczenie pokazuje współpracę technologii
Instrukcja 3 Laboratorium z Podstaw Inżynierii Oprogramowania
Instrukcja 3 Laboratorium z Podstaw Inżynierii Oprogramowania Diagramy klas i sekwencji: Relacja 1 do 0..* między klasami modelu obiektowego Cele laboratorium 3 Dokończyć 1-y etap z lab2. 2-i etap projektu.
Ćwiczenia 9 - Swing - część 1
Ćwiczenia 9 - Swing - część 1 Utwórz nowy projekt wybierając: File->New Project->Java Application, przy czym odznacz opcję Create Main Class. Kliknij prawym przyciskiem myszy na podfolder Source Packages
Laboratorium 8 Diagramy aktywności
Laboratorium 8 Diagramy aktywności Zofia Kruczkiewicz Zofia Kruczkiewicz Lab_INP002017_8 1 Modelowanie zachowania obiektów za pomocą diagramów aktywności. Modelowanie zachowania obiektów za pomocą diagramów
Tworzenie projektu zawierającego aplet w środowisku NetBeans. lab1. Dr inż. Zofia Kruczkiewicz Programowanie aplikacji internetowych
Tworzenie projektu zawierającego aplet w środowisku NetBeans. lab1 Dr inż. Zofia Kruczkiewicz Etap 1 - Tworzenie apletu 1. Wybierz z menu File\ New Project. Na formularzu New Project wybierz w oknie Categories
Wprowadzenie do technologii JavaServer Faces 2.1 na podstawie http://docs.oracle.com/javaee/6/tutorial/doc/
Wprowadzenie do technologii JavaServer Faces 2.1 na podstawie http://docs.oracle.com/javaee/6/tutorial/doc/ Aplikacja internetowa tworzona na podstawie bazy danych. Programowanie komponentowe 2, Zofia
I. Dlaczego standardy kodowania mailingów są istotne?
1 Tabela zawartości: I. Dlaczego standardy kodowania mailingów są istotne? 3 II. Budowa nagłówka wiadomości. 4 III. Style kaskadowe CSS. 4 IV. Elementarna budowa szablonu. 6 V. Podsumowanie. 9 2 I. Dlaczego
Wprowadzenie do laboratorium. Zasady obowiązujące na zajęciach. Wprowadzenie do narzędzi wykorzystywanych podczas laboratorium.
Wprowadzenie do laboratorium. Zasady obowiązujące na zajęciach. Wprowadzenie do narzędzi wykorzystywanych podczas laboratorium. Prowadzący Dr inż. Zofia 1 La1 La2 Forma zajęć - laboratorium Wprowadzenie
Tworzenie warstwy prezentacji w wielowarstwowej aplikacji Przykład w środowisku Visual Web JSP
Tworzenie warstwy prezentacji w wielowarstwowej aplikacji Przykład w środowisku Visual Web JSP Autor Zofia Kruczkiewicz Programowanie i wdrażanie systemów informatycznych 1. Wykonanie formularzy typy JSP