PHP5. Programowanie z wykorzystaniem Symfony, CakePHP, Zend Framework 9788324644117, 9788324625215, 8324625216, 8324644113

Na rynku dostępnych jest obecnie mnóstwo rozwiązań umożliwiających szybkie tworzenie serwisów internetowych z wykorzysta

195 87 8MB

Polish Pages 360 [358] Year 2009

Report DMCA / Copyright

DOWNLOAD PDF FILE

Table of contents :
Spis treści
Rozdział 1. Szybki start
Struktura serwisu
Ruszamy z projektem
Potrzebna aplikacja
Tworzymy moduł
Pierwsza akcja
Szablony akcji
Instalacja layoutu
Sprzątanie wewnątrz layoutu
Konfiguracja widoku aplikacji
Edycja pliku layoutu
Prezentowanie wyniku akcji
Brakujące elementy serwisu
Powiązanie akcji z menu
Stopka — i to by było na tyle
Podsumowanie
Rozdział 2. Warstwa kontrolera
Budowa aplikacji Symfony
Kontroler frontowy
Jak startuje aplikacja Symfony?
Czy można używać więcej niż jednego kontrolera frontowego?
Jak użyć innego kontrolera?
Co to jest środowisko pracy kontrolera?
Gdzie są konfigurowane środowiska pracy?
Czy można utworzyć własne środowisko pracy?
Akcje
Pliki z akcją
W jaki sposób przekazać parametr do akcji?
Zaglądamy do środka akcji
Przesyłanie parametrów w żądaniu HTTP
Czy formularze można tworzyć inaczej?
Szablon widoku
Co musisz wiedzieć na początek?
Jak sterować widokami?
Czy mogę używać własnych widoków?
Co z akcjami, które nie mogą być prezentowane w przeglądarce?
Warunkowe zwracanie widoków
Przekierowania
Żądanie nietrafione
Inne rodzaje przekierowań
Przed akcją i po akcji
Obiekt obsługujący żądania
Informacje o żądaniu
Informacje o zasobie
ParameterHolder i funkcje proxy
Funkcje proxy
Ciasteczka
Przesyłanie plików na serwer
Obsługa sesji
Proste logowanie
Usuwanie zmiennej z sesji
Zmienne sesji w widokach
Atrybuty jednorazowe
Kilka słów o konfiguracji sesji
System uprawnień
Przegląd funkcji systemu uprawnień
Zaawansowane listy uwierzytelnień
Walidacja
Mechanizm walidacji
Podsumowanie
Rozdział 3. Warstwa modelu
Od bazy do modelu
Baza danych
Generowanie schematu YML na podstawie bazy danych
Konfiguracja propela
Generowanie bazy danych na podstawie schematu YML
Anatomia pliku schema.yml
Dostępne typy danych
Definiowanie pól
Indeksy
Właściwości połączenia
Dwa schematy. Czy to możliwe?
Co w modelu piszczy
Katalogi modelu
Model w akcji
Konstruowanie kryteriów
Warunkowe pobieranie danych
Typy porównywania dozwolone dla metody add
Inne metody obiektu Criteria
Zliczanie rekordów
Surowe zapytania SQL
Korzystanie z Creole
Rozszerzanie modelu
Połączenia z bazą danych
Więcej o pliku database.yml
Podsumowanie
Rozdział 4. Warstwa widoku
Domyślna akcja i jej widok
Reguły dla szablonów widoku
Logika a szablon
Pomocniki
Pomocniki ogólnie dostępne
Layouty
Inny layout
Pomocniki w layoutach
Zmiana layoutu dla modułu
Zmiana layoutu dla szablonu widoku
Zmiana layoutu dla akcji
Usuwanie layoutu
Elementy widoku
Proste dołączanie pliku
Partiale
Komponenty
Sloty
Konfiguracja
Pliki view.yml
Kaskada plików konfiguracyjnych
Obiekt Response
Sterowanie sekcją meta poprzez obiekt odpowiedzi
Pliki zewnętrzne
Pliki CSS i JS
Manipulowanie kolejnością dołączanych plików
Określanie medium
Komponenty slotowe
Podsumowanie
Rozdział 5. Przykładowa aplikacja
Świat wizytówek
Projekt bazy danych
Instalacja layoutu i konfiguracja widoku
Wykonanie modelu
Budowa menu
Strona o firmie
Panel administracyjny — o firmie
Interfejs użytkownika — o firmie
Strona referencji
Panel administracyjny — referencje
Interfejs użytkownika — referencje
Strony z ofertą
Panel administracyjny — kategorie
Panel administracyjny — produkty
Panel administracyjny — kategorie — ciąg dalszy
Panel administracyjny — zdjęcia
Interfejs użytkownika — oferta
Sentencje — panel administracyjny i interfejs użytkownika
Licznik odwiedzin
Podsumowanie
Rozdział 6. Aplikacja Zend
Szybka instalacja
Test instalacji
Po instalacji
Pierwsza akcja na rozgrzewkę
Konfiguracja projektu
Layout
Interfejs klienta
Strona o firmie
Menu
Referencje
Oferta
Submenu
Kategoria
Szczegóły produktu
Dodatki
Panel administracyjny
Inny layout dla panelu
Zarządzanie stroną o firmie
Administracja referencjami
Kategorie
Zarządzanie produktami
Sentencje
Podsumowanie
Rozdział 7. Aplikacja CakePHP
Instalacja frameworka
Konfiguracja bazy danych
O firmie
Model
Kontroler
Widok
Layout
Logowanie na ekranie
Menu
Komponent
Helper
Referencje
Model referencji
Oferta
Model na rozgrzewkę
Oferta w poszczególnych kategoriach
Szczegóły wizytówki
Sentencje
Komponent
Uruchomienie komponentu Sentencje
Licznik
Komponent licznika
Uruchamianie licznika
Panel administracyjny
Zmiana layoutu
Strona administracyjna o firmie
Referencje
Kategorie
Produkty
Dodawanie nowego produktu
Sentencje
Podsumowanie
Podsumowanie
Dodatek A. Środowisko pracy web developera
Serwer HTTP
Interpreter PHP
Serwer baz danych
Wszystko w jednym, czyli scyzoryk
Środowisko projektowania baz danych
Edytory kodu
Przeglądarki
Narzędzia do pracy w grupie
Dodatek B. Wirtualne hosty
Importowanie wirtualnych hostów do pliku konfiguracyjnego Apache
Definiowanie wirtualnych hostów
Wirtualny host dla lokalnego hosta
Konfiguracja systemu Windows
Dodatek C. Szybka instalacja
Odtworzenie bazy danych
Zainstalowanie projektu Symfony, Zend i CakePHP
Dodatek D. Zarządzanie projektem
Bibliografia
Skorowidz
Dodatkowe materiały
Recommend Papers

PHP5. Programowanie z wykorzystaniem Symfony, CakePHP, Zend Framework
 9788324644117, 9788324625215, 8324625216, 8324644113

  • 0 0 0
  • Like this paper and download? You can publish your own PDF file online for free in a few minutes! Sign Up
File loading please wait...
Citation preview

Wszelkie prawa zastrzeżone. Nieautoryzowane rozpowszechnianie całości lub fragmentu niniejszej publikacji w jakiejkolwiek postaci jest zabronione. Wykonywanie kopii metodą kserograficzną, fotograficzną, a także kopiowanie książki na nośniku filmowym, magnetycznym lub innym powoduje naruszenie praw autorskich niniejszej publikacji. Wszystkie znaki występujące w tekście są zastrzeżonymi znakami firmowymi bądź towarowymi ich właścicieli. Autor oraz Wydawnictwo HELION dołożyli wszelkich starań, by zawarte w tej książce informacje były kompletne i rzetelne. Nie biorą jednak żadnej odpowiedzialności ani za ich wykorzystanie, ani za związane z tym ewentualne naruszenie praw patentowych lub autorskich. Autor oraz Wydawnictwo HELION nie ponoszą również żadnej odpowiedzialności za ewentualne szkody wynikłe z wykorzystania informacji zawartych w książce. Redakcja: Michał Mrowiec Projekt okładki: Mateusz Obarek, Maciej Pokoński Wydawnictwo HELION ul. Kościuszki 1c, 44-100 GLIWICE tel. 32 231 22 19, 32 230 98 63 e-mail: [email protected] WWW: http://helion.pl (księgarnia internetowa, katalog książek) Drogi Czytelniku! Jeżeli chcesz ocenić tę książkę, zajrzyj pod adres http://helion.pl/user/opinie?php5sy_ebook Możesz tam wpisać swoje uwagi, spostrzeżenia, recenzję. Pliki z przykładami omawianymi w książce można znaleźć pod adresem: ftp://ftp.helion.pl/przyklady/php5sy_ebook.zip ISBN: 978-83-246-4411-7 Copyright © Helion 2010 Printed in Poland.

• Poleć książkę na Facebook.com • Kup w wersji papierowej • Oceń książkę

• Księgarnia internetowa • Lubię to! » Nasza społeczność

Spis treści Rozdział 1. Szybki start . ................................................................................... 9 Struktura serwisu ................................................................................................................9 Ruszamy z projektem ...................................................................................................... 10 Potrzebna aplikacja .......................................................................................................... 11 Tworzymy moduł . ........................................................................................................... 12 Pierwsza akcja . ................................................................................................................ 13 Szablony akcji . ................................................................................................................ 15 Instalacja layoutu ............................................................................................................. 16 Sprzątanie wewnątrz layoutu . ................................................................................ 17 Konfiguracja widoku aplikacji . .............................................................................. 17 Edycja pliku layoutu ............................................................................................... 18 Prezentowanie wyniku akcji ............................................................................................ 20 Brakujące elementy serwisu ............................................................................................ 21 Powiązanie akcji z menu ................................................................................................. 22 Stopka — i to by było na tyle .......................................................................................... 22 Podsumowanie . ................................................................................................................ 23

Rozdział 2. Warstwa kontrolera . ...................................................................... 25 Budowa aplikacji Symfony .............................................................................................. 25 Kontroler frontowy .......................................................................................................... 26 Jak startuje aplikacja Symfony? . ............................................................................ 27 Czy można używać więcej niż jednego kontrolera frontowego? ........................... 28 Jak użyć innego kontrolera? .................................................................................... 28 Co to jest środowisko pracy kontrolera? . ............................................................... 28 Gdzie są konfigurowane środowiska pracy? . ......................................................... 29 Czy można utworzyć własne środowisko pracy? . .................................................. 29 Akcje . .............................................................................................................................. 29 Pliki z akcją ............................................................................................................ 31 W jaki sposób przekazać parametr do akcji? . ........................................................ 32 Zaglądamy do środka akcji ..................................................................................... 33 Przesyłanie parametrów w żądaniu HTTP . ..................................................................... 34 Czy formularze można tworzyć inaczej? . .............................................................. 36 Szablon widoku . .............................................................................................................. 37 Co musisz wiedzieć na początek? . ......................................................................... 37 Jak sterować widokami? ......................................................................................... 37 Czy mogę używać własnych widoków? . ................................................................ 38

4

PHP5. Programowanie z wykorzystaniem Symfony, CakePHP, Zend Framework Co z akcjami, które nie mogą być prezentowane w przeglądarce? ........................ 38 Warunkowe zwracanie widoków . .......................................................................... 39 Przekierowania ................................................................................................................ 40 Żądanie nietrafione ................................................................................................. 42 Inne rodzaje przekierowań ...................................................................................... 44 Przed akcją i po akcji ....................................................................................................... 44 Obiekt obsługujący żądania ............................................................................................. 46 Informacje o żądaniu .............................................................................................. 48 Informacje o zasobie ............................................................................................... 48 ParameterHolder i funkcje proxy ..................................................................................... 49 Funkcje proxy ......................................................................................................... 50 Ciasteczka . ....................................................................................................................... 51 Przesyłanie plików na serwer .......................................................................................... 52 Obsługa sesji . ................................................................................................................... 53 Proste logowanie ..................................................................................................... 54 Usuwanie zmiennej z sesji ...................................................................................... 56 Zmienne sesji w widokach ...................................................................................... 57 Atrybuty jednorazowe ............................................................................................. 57 Kilka słów o konfiguracji sesji . .............................................................................. 59 System uprawnień ........................................................................................................... 60 Przegląd funkcji systemu uprawnień . .................................................................... 64 Zaawansowane listy uwierzytelnień . ..................................................................... 64 Walidacja . ........................................................................................................................ 66 Mechanizm walidacji .............................................................................................. 67 Podsumowanie . ................................................................................................................ 68

Rozdział 3. Warstwa modelu . .......................................................................... 69 Od bazy do modelu .......................................................................................................... 69 Baza danych ............................................................................................................ 70 Generowanie schematu YML na podstawie bazy danych . ............................................. 73 Konfiguracja propela .............................................................................................. 73 Generowanie bazy danych na podstawie schematu YML . ............................................. 77 Anatomia pliku schema.yml ................................................................................... 79 Dostępne typy danych ............................................................................................. 81 Definiowanie pól .................................................................................................... 83 Indeksy . ................................................................................................................... 84 Właściwości połączenia .......................................................................................... 84 Dwa schematy. Czy to możliwe? . .......................................................................... 85 Co w modelu piszczy ....................................................................................................... 87 Katalogi modelu ...................................................................................................... 88 Model w akcji ......................................................................................................... 88 Konstruowanie kryteriów .............................................................................................. 100 Warunkowe pobieranie danych . ........................................................................... 100 Typy porównywania dozwolone dla metody add . ................................................ 102 Inne metody obiektu Criteria . .............................................................................. 103 Zliczanie rekordów ............................................................................................... 107 Surowe zapytania SQL .................................................................................................. 107 Korzystanie z Creole ............................................................................................. 108 Rozszerzanie modelu ..................................................................................................... 109 Połączenia z bazą danych .............................................................................................. 112 Więcej o pliku database.yml . ............................................................................... 112 Podsumowanie ............................................................................................................... 114

Spis treści

5

Rozdział 4. Warstwa widoku . ........................................................................ 115 Domyślna akcja i jej widok ........................................................................................... 115 Reguły dla szablonów widoku . ............................................................................ 116 Logika a szablon ................................................................................................... 117 Pomocniki . ..................................................................................................................... 117 Pomocniki ogólnie dostępne . ............................................................................... 119 Layouty . ......................................................................................................................... 120 Inny layout ............................................................................................................ 121 Pomocniki w layoutach ......................................................................................... 123 Zmiana layoutu dla modułu . ................................................................................ 123 Zmiana layoutu dla szablonu widoku . ................................................................. 124 Zmiana layoutu dla akcji . ..................................................................................... 125 Usuwanie layoutu ................................................................................................. 126 Elementy widoku ........................................................................................................... 127 Proste dołączanie pliku ......................................................................................... 127 Partiale .................................................................................................................. 128 Komponenty . ................................................................................................................. 133 Sloty . ............................................................................................................................. 136 Konfiguracja . ................................................................................................................. 139 Pliki view.yml ....................................................................................................... 139 Kaskada plików konfiguracyjnych . ...................................................................... 140 Obiekt Response ................................................................................................... 141 Sterowanie sekcją meta poprzez obiekt odpowiedzi . ........................................... 142 Pliki zewnętrzne ............................................................................................................ 143 Pliki CSS i JS ........................................................................................................ 144 Manipulowanie kolejnością dołączanych plików . ................................................ 144 Określanie medium ............................................................................................... 145 Komponenty slotowe ..................................................................................................... 146 Podsumowanie ............................................................................................................... 149

Rozdział 5. Przykładowa aplikacja . ................................................................ 151 Świat wizytówek ........................................................................................................... 151 Projekt bazy danych ...................................................................................................... 152 Instalacja layoutu i konfiguracja widoku . ..................................................................... 154 Wykonanie modelu ........................................................................................................ 158 Budowa menu . ............................................................................................................... 158 Strona o firmie ............................................................................................................... 160 Panel administracyjny — o firmie . ...................................................................... 161 Interfejs użytkownika — o firmie . ....................................................................... 164 Strona referencji ............................................................................................................ 164 Panel administracyjny — referencje . ................................................................... 165 Interfejs użytkownika — referencje . .................................................................... 175 Strony z ofertą ............................................................................................................... 176 Panel administracyjny — kategorie . .................................................................... 177 Panel administracyjny — produkty . ..................................................................... 179 Panel administracyjny — kategorie — ciąg dalszy . ............................................. 185 Panel administracyjny — zdjęcia . ........................................................................ 188 Interfejs użytkownika — oferta . .......................................................................... 191 Sentencje — panel administracyjny i interfejs użytkownika . ....................................... 197 Licznik odwiedzin ......................................................................................................... 202 Podsumowanie ............................................................................................................... 203

6

PHP5. Programowanie z wykorzystaniem Symfony, CakePHP, Zend Framework

Rozdział 6. Aplikacja Zend . ........................................................................... 205 Szybka instalacja ........................................................................................................... 205 Test instalacji . ................................................................................................................ 206 Po instalacji . .................................................................................................................. 206 Pierwsza akcja na rozgrzewkę ....................................................................................... 207 Konfiguracja projektu .................................................................................................... 208 Layout . ........................................................................................................................... 209 Interfejs klienta .............................................................................................................. 210 Strona o firmie ...................................................................................................... 210 Menu . .................................................................................................................... 214 Referencje ............................................................................................................. 216 Oferta . ............................................................................................................................ 217 Submenu ............................................................................................................... 220 Kategoria . ............................................................................................................. 221 Szczegóły produktu ............................................................................................... 223 Dodatki . ................................................................................................................ 224 Panel administracyjny .................................................................................................... 229 Inny layout dla panelu ........................................................................................... 229 Zarządzanie stroną o firmie .................................................................................. 230 Administracja referencjami . ................................................................................. 234 Kategorie .............................................................................................................. 243 Zarządzanie produktami ........................................................................................ 252 Sentencje ............................................................................................................... 264 Podsumowanie ............................................................................................................... 269

Rozdział 7. Aplikacja CakePHP . .................................................................... 271 Instalacja frameworka .................................................................................................... 271 Konfiguracja bazy danych ............................................................................................. 272 O firmie . ........................................................................................................................ 273 Model . ................................................................................................................... 273 Kontroler ............................................................................................................... 274 Widok . .................................................................................................................. 275 Layout . ........................................................................................................................... 275 Logowanie na ekranie .................................................................................................... 276 Menu . ............................................................................................................................. 276 Komponent ........................................................................................................... 277 Helper . .................................................................................................................. 277 Referencje . ..................................................................................................................... 280 Model referencji .................................................................................................... 280 Oferta . ............................................................................................................................ 282 Model na rozgrzewkę ............................................................................................ 282 Oferta w poszczególnych kategoriach . ................................................................ 285 Szczegóły wizytówki ............................................................................................ 287 Sentencje . ...................................................................................................................... 288 Komponent ........................................................................................................... 288 Uruchomienie komponentu Sentencje . ................................................................ 289 Licznik . .......................................................................................................................... 290 Komponent licznika .............................................................................................. 290 Uruchamianie licznika .......................................................................................... 291 Panel administracyjny .................................................................................................... 292 Zmiana layoutu ..................................................................................................... 292 Strona administracyjna o firmie . .......................................................................... 293 Referencje ............................................................................................................. 296 Kategorie .............................................................................................................. 304

Spis treści

7 Produkty . ............................................................................................................... 310 Dodawanie nowego produktu . ............................................................................. 312 Sentencje ............................................................................................................... 324 Podsumowanie ............................................................................................................... 327

Podsumowanie . ........................................................................... 329 Dodatek A Środowisko pracy web developera . .............................................. 331 Serwer HTTP . ................................................................................................................ 331 Interpreter PHP .............................................................................................................. 332 Serwer baz danych ......................................................................................................... 332 Wszystko w jednym, czyli scyzoryk . ............................................................................ 332 Środowisko projektowania baz danych . ....................................................................... 333 Edytory kodu ................................................................................................................. 333 Przeglądarki . .................................................................................................................. 334 Narzędzia do pracy w grupie ......................................................................................... 334

Dodatek B Wirtualne hosty . .......................................................................... 337 Importowanie wirtualnych hostów do pliku konfiguracyjnego Apache ....................... 337 Definiowanie wirtualnych hostów . ............................................................................... 337 Wirtualny host dla lokalnego hosta . ............................................................................. 338 Konfiguracja systemu Windows . .................................................................................. 338

Dodatek C Szybka instalacja . ....................................................................... 341 Odtworzenie bazy danych .............................................................................................. 341 Zainstalowanie projektu Symfony, Zend i CakePHP . ................................................... 341

Dodatek D Zarządzanie projektem . ............................................................... 343 Bibliografia . ................................................................................ 345 Skorowidz . .................................................................................. 347

8

PHP5. Programowanie z wykorzystaniem Symfony, CakePHP, Zend Framework

Rozdział 1.

Szybki start Rozdział ten przeznaczony jest dla czytelników pragnących jak najszybciej zobaczyć framework Symfony w akcji. Motywem przewodnim będzie skonstruowanie statycznej strony firmowej fikcyjnego przedsiębiorstwa zarządzającego finansami. W pliku finanse.zip znajduje się kompletny layout startowy. W dalszej części wykorzystamy go do utworzenia poszczególnych elementów serwisu. Zakładam, że masz zainstalowany serwer Apache na swoim komputerze lokalnym. Z tego powodu we wszystkich linkach będę używał adresu 127.0.0.1 jako oznaczenia serwera.

Struktura serwisu Na rysunku 1.1 przedstawiony jest layout serwisu, który będziemy tworzyć w tym rozdziale. Wszystkie elementy graficzne zostały już wykonane i są dostępne w pliku finanse.zip. Łatwo zauważysz, że działanie serwisu jest mało skomplikowane. W menu dostępne są cztery opcje: 1. O FIRMIE — strona zawiera podstawowe informacje dotyczące firmy. 2. OFERTA — krótka charakterystyka oferowanych usług. 3. KONTAKT — przedstawia preferowane formy kontaktu. 4. REFERENCJE — lista instytucji, które zaufały firmie.

Wybranie dowolnej z opcji menu przeniesie internautę na stronę prezentującą właściwą treść. Treść taka umieszczana będzie bezpośrednio pod banerem. Pozostałe elementy serwisu, takie jak logo, hasła reklamowe, boks INFOLINIA itp., są statyczne.

10

PHP5. Programowanie z wykorzystaniem Symfony, CakePHP, Zend Framework

Rysunek 1.1. Zrzut ekranowy serwisu finansowego www.EXAMPLE.com

Ruszamy z projektem Na początek musimy utworzyć projekt Symfony. W tym celu wykonaj poniższe instrukcje: 1. W publicznym katalogu serwera Apache utwórz katalog finanse. 2. Rozpakuj zawartość pliku sf_sandbox.zip do katalogu utworzonego w poprzednim

punkcie. 3. Sprawdź, czy poprawnie utworzyłeś projekt. W tym celu należy wpisać

w przeglądarce adres http://127.0.0.1/finanse/web/index.php. Jeżeli projekt działa poprawnie, na ekranie powinieneś zobaczyć widok przedstawiony na rysunku 1.2. Rysunek 1.2. Strona prezentowana dla dobrze zainstalowanego projektu Symfony

Rozdział 1. ♦ Szybki start

11

Jeżeli zastanawiasz się teraz, dlaczego uruchomienie projektu trwało tak długo, odpowiedź jest dosyć prosta. Symfony podczas pierwszego uruchomienia projektu przetwarza pliki konfiguracyjne i zapisuje je w bardziej zoptymalizowanej formie. Więcej szczegółów będziesz mógł poznać w kolejnych rozdziałach. Pamiętaj, że archiwum sf_sandbox.zip zawiera wszystkie potrzebne biblioteki Symfony. Oczywiście możesz zainstalować projekt w inny sposób, ja wybrałem jednak tę metodę ze względu na jej prostotę.

Potrzebna aplikacja Każdy projekt Symfony składa się z przynajmniej jednej aplikacji. Taka aplikacja może być interfejsem użytkownika, panelem administratora itp. To, co uznasz za aplikację, w dużej mierze zależy od Ciebie. Symfony jest bardzo elastyczne, o czym wkrótce się przekonasz. Na potrzeby serwisu, który tworzymy, aplikację nazwiemy inwestycje. Jak utworzyć aplikację? W katalogu projektu znajdziesz plik o nazwie symfony.bat. Pozwala on na wykonywanie wielu operacji związanych z frameworkiem Symfony. Dla przykładu, przekazując do instrukcji odpowiednie parametry, możemy utworzyć nową aplikację, nowy moduł czy też wygenerować klasy modelu na podstawie bazy danych. Ponieważ staram się maksymalnie uprościć przykład, w tym miejscu poznamy sposób na tworzenie aplikacji: >symfony.bat init-app inwestycje

Po uruchomieniu polecenia powinieneś zobaczyć wydruk podobny do przedstawionego na rysunku 1.3. W kolejnych linijkach dostajemy informacje o czynnościach wykonywanych przez wywołaną instrukcję. Po zakończeniu tego procesu otrzymujemy kompletną strukturę aplikacji: katalogi, pliki itp. Aplikację testujemy, wpisując w adresie przeglądarki http://127.0.0.1/finanse/web/ inwestycje.php. Jeżeli wszystko wykonałeś poprawnie, na ekranie powinieneś zobaczyć efekt podobny do przedstawionego na rysunku 1.2. Pewnie zastanawiasz się teraz, co tak naprawdę utworzyłeś, wydając wcześniejsze polecenie. Wyjaśnienie wszystkiego w tym miejscu mija się z celem, skupimy się więc na najważniejszych rzeczach. Po pierwsze, musisz znać odpowiedź na pytanie, gdzie na dysku umieszczane są aplikacje. W tym celu otwórz dowolny menedżer plików i przejdź do katalogu projektu utworzonego w podrozdziale „Ruszamy z projektem”. W katalogu, w którym obecnie jesteś, łatwo zauważysz katalog apps. Przejdź do niego. W tym miejscu możesz zobaczyć znajomo wyglądającą nazwę inwestycja. Jesteś więc w miejscu, w którym Symfony zapisuje swoje aplikacje. Zapamiętaj je dobrze, ponieważ będziesz tutaj częstym gościem. Drugą rzeczą, na którą chciałbym zwrócić Twoją uwagę, jest struktura aplikacji. W tym celu musisz wejść do katalogu inwestycje. Znajdziesz tutaj kilka folderów:

12

PHP5. Programowanie z wykorzystaniem Symfony, CakePHP, Zend Framework

Rysunek 1.3. Proces tworzenia aplikacji  config — konfiguracja aplikacji;  i18n — wersje językowe;  lib — biblioteki aplikacji;  modules — moduły aplikacji;  templates — layouty aplikacji.

Więcej szczegółów na temat zawartości i znaczenia wymienionych katalogów poznasz w dalszych rozdziałach i sekcjach.

Tworzymy moduł Moduł dzieli aplikację na logiczne części. Za jego pomocą możemy odseparować od siebie poszczególne elementy serwisu. Dla przykładu, w sklepie internetowym moglibyśmy zrobić moduły: wystawa sklepowa, koszyk i wiele innych. Dzięki takiemu podejściu łatwiej analizować i przetwarzać kod. Ponadto można podzielić pracę między kilku programistów tak, żeby nie wchodzili sobie w drogę. Jak utworzyć moduł? Tak jak w przypadku aplikacji, musisz użyć wiersza poleceń. W tym celu wpisz poniższe polecenie: >symfony.bat init-mod inwestycje wizytowka

Łatwo zauważyć, że do tworzenia modułu służy polecenie init-mod. Wymaga ono dwóch argumentów. Pierwszy argument jest nazwą aplikacji, w której zostanie utworzony

Rozdział 1. ♦ Szybki start

13

moduł, drugi argument zaś jest nazwą modułu. Jeżeli wykonałeś już polecenie, zapewne zauważyłeś wydruk podobny do tego na rysunku 1.3. W tym przypadku również jesteśmy informowani o tym, jakie czynności wykonuje uruchomione polecenie. Jak możesz zobaczyć strukturę modułu? W poprzednim rozdziale dotarliśmy wspólnie do katalogu aplikacji. Tam znaleźliśmy katalog o nazwie modules. Teraz jest dobry moment, żeby do niego zajrzeć. Folder zawiera tylko jedną pozycję o nazwie wizytowka. Jest to całkiem logiczne, ponieważ do tej pory nie tworzyliśmy więcej modułów. Tak naprawdę będzie to jedyny moduł, jakiego potrzebujemy do wykonania całego serwisu. Przejdź do katalogu modułu i zwróć uwagę na jego zawartość:  actions — w tym katalogu umieszczamy wszystkie akcje;  config — katalog zawierający konfigurację dla modułu;  lib — katalog, w którym umieszczamy biblioteki wykorzystywane w module;  templates — w tym katalogu umieszczamy szablony widoków dla

poszczególnych akcji;  validate — katalog zawiera informacje o tym, w jaki sposób sprawdzać dane

otrzymane od internauty. O tym, w jaki sposób wykorzystać poszczególne katalogi, dowiesz się w dalszych rozdziałach. Na tym etapie jedyne, co musisz wiedzieć, to jak dotrzeć do katalogu, w którym umieszczane są akcje, oraz gdzie należy opisać wygląd danych produkowanych przez akcję. Ostatnia czynność, którą warto w tym miejscu zrobić, to test modułu. W tym celu wpisz w przeglądarce adres http://127.0.0.1/finanse/web/inwestycje.php/wizytowka. Jeżeli na ekranie pojawi się strona podobna do zaprezentowanej na rysunku 1.2, to znaczy, że tworzenie modułu zakończyło się powodzeniem.

Pierwsza akcja Ponieważ projekt i moduł są już poprawnie zainstalowane, możemy napisać pierwszą akcję. Zakładam, że masz swój ulubiony edytor, w którym programujesz. Zachęcam jednak do korzystania z edytora Eclipse, który posiada wiele ciekawych funkcji ułatwiających kodowanie. Znajdziesz go na stronach http://www.eclipse.org/ w dziale downloads. Czym jest akcja? Najprościej mówiąc, akcja jest pewną operacją wykonywaną w serwisie. Lepiej zrozumiesz to na przykładzie sklepu internetowego. Możemy z niego wyodrębnić kilka podstawowych operacji, takich jak: pokaż towary, pokaż towar, prezentuj wystawę, dodaj towar, edytuj towar i wiele innych. Każda taka operacja reprezentowana jest w Symfony przez akcję.

14

PHP5. Programowanie z wykorzystaniem Symfony, CakePHP, Zend Framework

Serwis, który teraz tworzymy, wymaga co najmniej czterech akcji — po jednej dla każdej pozycji w menu. Na początek utworzymy jedną akcję reprezentującą działanie linku O FIRMIE. Dalsze akcje utworzymy dopiero po zainstalowaniu i konfiguracji layoutu. W jaki sposób utworzyć akcję? Przede wszystkim musisz wejść do katalogu actions i otworzyć plik actions.class.php. W oknie edytora zobaczysz poniższy kod: class wizytowkaActions extends sfActions { /** * Executes index action * */ public function executeIndex() { $this->forward('default', 'module'); } }

Warto zwrócić uwagę na kilka konwencji nazewnictwa. Na początek przyjrzyj się nazwie klasy wizytowkaActions. Nazwa zbudowana jest według wzorca Actions. Dzięki takiej konwencji Symfony zawsze wie, o którą akcję chodzi. Obecnie klasa zawiera jedną akcję Index. Nazwy akcji również należy budować według z góry określonego schematu. Wszystkie metody poprzedzone przedrostkiem execute są akcjami. Inne typy metod poznamy w dalszej części książki. Wracając do przykładu, metodę akcji skojarzonej z linkiem O FIRMIE nazwij execute ´OFirmie. Metoda musi być umieszczona wewnątrz klasy wizytowkaActions. Po tej operacji listing klasy jest następujący: class wizytowkaActions extends sfActions { /** * Executes index action * */ public function executeIndex() { $this->forward('default', 'module'); } public function executeOFirmie() { } }

Ponieważ metody reprezentujące akcje statyczne są zwykle puste, akcja jest już skończona. Teraz musisz przetestować, czy Symfony wywoła metodę akcji. W tym celu wpisz w pasku adresu http://127.0.0.1/finanse/web/inwestycje.php/wizytowka/oFirmie. Wynik, jaki powinieneś zobaczyć, przedstawiony jest na rysunku 1.4.

Rozdział 1. ♦ Szybki start

15

Rysunek 1.4. Błąd wewnętrzny frameworka

Niestety, wywołanie akcji zakończyło się wewnętrznym błędem Symfony. Błąd ten może wystąpić w wielu sytuacjach i czasami trudno od razu stwierdzić, co tak naprawdę się stało. Tym razem jednak odpowiedź jest dosyć oczywista. Otóż Symfony uruchomił akcję, ale nie wie, jak ją przedstawić, ponieważ nie utworzyliśmy pliku szablonu.

Szablony akcji Szablon widoku akcji to plik php zawierający prezentację danych akcji. Jeżeli akcja jest statyczna, szablon może zawierać jedynie instrukcje HTML. Na początek musisz wiedzieć, że Symfony pozwala używać różnych typów szablonów. Podstawowym widokiem jest widok Success. Wywoływany jest wtedy, kiedy uruchomienie akcji zakończyło się powodzeniem. Czy szablon widoku musi być odpowiednio nazwany? Tak. Odpowiednie nazewnictwo pozwala na elastyczność, którą oferuje Symfony. W tym przypadku szablon powinieneś więc nazwać oFirmieSuccess.php. Łatwo zauważysz, że nazwa budowana jest według schematu Success.php. Zwróć też uwagę na pierwszą literę nazwy, która zawsze musi być mała. Gdzie należy zapisać szablon widoku? Wszystkie szablony dla akcji zapisywane są w katalogu templates umieszczonym bezpośrednio w katalogu modułu. Przejdź więc do tego katalogu i utwórz plik oFirmieSuccess.php. Poniżej przykładowy listing pliku: O Firmie Jesteśmy firmą oferującą doradztwo finansowe.

Kod jest bardzo prosty i zawiera niewielką ilość informacji. Zajmiemy się nim ponownie po zainstalowaniu layoutu. Teraz wystarczy odświeżyć stronę i zobaczyć, czy nastąpiła poprawa. Częstym problemem na początku są tak zwane „krzaczki” na stronie. Na rysunku 1.5 przedstawiony jest wynik akcji OFirmie zawierający niepoprawnie wyświetlone znaki. Dlaczego tak się dzieje? Symfony używa kodowania UTF8, z tego względu staraj się tak samo kodować pliki, które tworzysz.

16

PHP5. Programowanie z wykorzystaniem Symfony, CakePHP, Zend Framework

Rysunek 1.5. Niepoprawnie zakodowane znaki

Instalacja layoutu Każdy serwis skonstruowany jest na podstawie pewnego projektu graficznego. Jeżeli jest to serwis firmowy, to projekt graficzny zawiera logo, hasła kojarzone z firmą itp. W tej części pokażę Ci, w jaki sposób dane produkowane przez akcję umieścić wewnątrz grafiki przygotowanej na potrzeby strony. Instalacja layoutu wymaga przekopiowania jego plików w odpowiednie miejsca. Oczywiście wszystkie te miejsca znajdują się w katalogu projektu, który już utworzyłeś. Podczas instalacji layoutu dla całego serwisu musimy skorzystać z następujących katalogów:  apps/inwestycje/templates — tutaj umieszczamy pliki php szablonów;  web/images — tutaj umieszczamy obrazki;  web/css — tutaj umieszczamy style;  web/js — tutaj umieszczamy kod JavaScript.

Wszystkie potrzebne pliki znajdziesz w finanse.zip. Plik index.html przekopiuj do katalogu apps/inwestycje/templates. Następnie zmień mu nazwę na layout.php. W ten sposób nadpisałeś szablon domyślny. Następnie całą zawartość katalogu images (z archiwum finanse.zip) przekopiuj do web/images. Musisz również przekopiować zawartość katalogu css do web/css. Ostatnia rzecz, jaką należy zrobić, to przekopiowanie plików z katalogu js do katalogu web/js. Instalacja szablonu została zakończona. Teraz należy przetestować uzyskany efekt. Na rysunku 1.6 możesz zobaczyć dane prezentowane w przeglądarce po wywołaniu adresu http://127.0.0.1/finanse/web/inwestycje.php/wizytowka/oFirmie.

Rysunek 1.6. Wynik akcji OFirmie po zainstalowaniu layoutu

Niestety, wiesz już o tym, że nie wszystko poszło tak, jak oczekiwaliśmy. Z jednej strony można zauważyć pewne dane zawarte wewnątrz layoutu, z drugiej jednak — grafika została całkowicie zignorowana. Dlaczego tak się stało? Ponieważ instalowaliśmy pliki layoutu w różnych miejscach, musimy teraz troszeczkę posprzątać w samym szablonie serwisu.

Rozdział 1. ♦ Szybki start

17

Sprzątanie wewnątrz layoutu Przeprowadźmy króciutką analizę kodu. Zwróć uwagę na poniższą instrukcję:

Instrukcja odpowiada za dołączanie stylów CSS do dokumentu HTML. Według atrybutu href przeglądarka powinna załadować style z lokalizacji css/style.css. Niestety, po instalacji szablonu okazuje się, że taka lokalizacja jest niepoprawna. Musimy to zatem zmienić. Możliwych rozwiązań jest kilka. Nie wszystkie jednak będą spełniały przyszłe oczekiwania. Bez trudu moglibyśmy poprawić ścieżki i wpisać nowe, poprawne lokalizacje. Niestety, nie jest to najlepszy pomysł. Ponieważ zwykle, tworząc aplikację, korzystamy z dwóch serwerów — testowego i produkcyjnego — najprawdopodobniej musielibyśmy przechowywać dwa różnie opisane layouty. Z całą pewnością wcześniej czy później odczułbyś uciążliwość takiego rozwiązania. Z tego powodu lepiej skorzystać z metod wbudowanych w Symfony. Metody te pozwalają określać względne położenia plików i uwzględniają katalog instalacyjny frameworka.

Konfiguracja widoku aplikacji Konfiguracja Symfony odbywa się za pomocą plików YML. Musimy więc użyć odpowiedniego z nich do określenia parametrów szablonu naszego serwisu. W tym celu należy otworzyć do edycji plik view.yml zapisany w katalogu apps/inwestycje/config. Poniżej przedstawiam domyślną zawartość tego pliku: default: http_metas: content-type: text/html metas: title: robots: description: keywords: language:

symfony project index, follow symfony project symfony, project en

stylesheets:

[main]

javascripts:

[]

has_layout: layout:

on layout

Nie przejmuj się, jeżeli nie wszystko teraz rozumiesz. Konfigurację Symfony będziemy omawiali praktycznie w każdej części tej książki. Teraz skupmy się na zadaniu i poprawmy jedynie potrzebne dyrektywy z przedstawionego listingu. Zanim przystąpimy do edycji pliku, musisz wiedzieć kilka rzeczy. Pliki YML wymagają przestrzegania ściśle określonych reguł. Po pierwsze, po nazwie sekcji musimy umieścić znak dwukropka, tak jak to widać dla sekcji default i metas. Sekcje mogą zawierać

18

PHP5. Programowanie z wykorzystaniem Symfony, CakePHP, Zend Framework

podsekcje, tak jak jest to w przypadku default. Podsekcja musi zawierać dwie spacje wcięcia względem sekcji, w której jest zawarta. Pamiętaj, to muszą być dwie spacje. Jeżeli użyjesz znaku tabulatora lub innej kombinacji, konfiguracja nie będzie poprawna. Ostatecznie w pliku zawarte są również dyrektywy, którym możemy nadawać wartości. Dla przykładu, dyrektywa title ma wartość symfony project. Więcej o konfiguracji dowiesz się w dalszych częściach. Jeżeli używałeś kiedykolwiek języka HTML, z pewnością zauważyłeś już, że sekcja metas zawiera dyrektywy kojarzące się z sekcją HEAD. W rzeczywistości Symfony na podstawie danych zamieszczonych w tej części tworzy metaznaczniki dla dokumentu HTML. Przetestujemy to na przykładzie. Zmień wartość dyrektywy title na Zaopiekujemy się Twoimi finansami. Dyrektywa będzie teraz wyglądała jak poniżej: title:

Zaopiekujemy się Twoimi finansami

Teraz odświeżamy stronę z wynikiem akcji OFirmie, czytamy napis umieszczany w pasku tytułu i... nic się nie stało. Dlaczego? Musimy dopisać do layoutu potrzebne instrukcje pobierające dane z pliku konfiguracyjnego. Zanim to zrobimy, przetwórzmy do końca plik konfiguracyjny, żeby do tego tematu więcej nie wracać. Zmień więc plik view.yml tak, żeby zawierał zawartość przedstawioną na listingu. default: http_metas: content-type: text/html metas: title: robots: description: keywords: language:

Zaopiekujemy się Twoimi finansami index, follow Strona o finansach. finanse, inwestycje pl

stylesheets:

[style]

javascripts:

[app, jquery]

has_layout: layout:

on layout

Z punktu widzenia grafiki najważniejsze są wpisy w dyrektywach stylesheets i java ´scripts. Zwróć uwagę na to, że wartości dla tych dyrektyw umieszczone są w nawiasach. Jest to konieczne, ponieważ w ten sposób przekazujemy wartości dla dyrektyw, które mogą mieć więcej niż jedną wartość (są to opcje tablicowe). Ważne jest również to, że nie musimy tutaj podawać rozszerzeń plików. Symfony dopisze rozszerzenia automatycznie na podstawie sekcji, w której umieszczone zostały nazwy.

Edycja pliku layoutu Wracamy do layoutu po to, żeby dopisać instrukcje pobierające dane z plików konfiguracyjnych. Problem, który zauważyliśmy, polega na błędnie skonstruowanych wpisach w sekcji HEAD. Obecnie sekcja zawiera następujący kod:

Rozdział 1. ♦ Szybki start

19



New Web Project

Zmień sekcję HEAD tak, aby zawierała poniższe instrukcje:



Ponownie odśwież stronę prezentującą dane akcji OFirmie. Jak teraz wygląda sytuacja? „Wygląda” na to, że kiepsko „wygląda”. Tym razem również nic nie zadziałało. Jeżeli zastanawiasz się teraz, co z tym Symfony jest nie tak, to powiem Ci, że nie zrobiliśmy jeszcze jednej ważnej rzeczy. W podrozdziale „Ruszamy z projektem” pisałem o tym, że Symfony przetwarza pliki konfiguracyjne i przechowuje je w formie pozwalającej na szybsze działanie. Uwaga ta dotyczy również pliku konfiguracyjnego view.yml. Skoro tak, to musimy na Symfony wymusić odświeżenie zapisanych informacji. Zrobimy to dosyć prosto. Przejdź do katalogu głównego projektu. W tym katalogu znajduje się katalog o nazwie cache. Wejdź do niego. Powinieneś szybko zauważyć katalog o nazwie inwestycje. To właśnie tutaj Symfony zapisał wszystkie przetworzone informacje o plikach konfiguracyjnych. Wystarczy ten plik skasować, co teraz zrobimy. Następnie odśwież stronę w przeglądarce. Tym razem jest już dużo lepiej, chociaż nie idealnie. Na rysunku 1.7 przedstawiony jest zrzut ekranowy wyniku, który powinieneś zobaczyć.

Rysunek 1.7. Błędnie wyświetlona strona serwisu

W porównaniu z rysunkiem 1.1 łatwo można stwierdzić, że brakuje w wyniku kilku ważnych elementów. Hasła reklamowe firmy finansowej gdzieś się zapodziały, nie wspominając już w ogóle o logo. Co się znowu stało? Niestety, tak jest zawsze, kiedy w pliku layoutu podajemy dla znacznika img ścieżkę do pliku graficznego. Tym razem winowajcami są poniższe znaczniki:

20

PHP5. Programowanie z wykorzystaniem Symfony, CakePHP, Zend Framework

Instrukcje zawarte są, odpowiednio, w liniach 15., 16., 30. i 33. pliku layout.php. Każda z nich zawiera ścieżkę nieuwzględniającą instalacji. Co teraz? Teraz musimy ścieżki napisać tak, żeby Symfony zawsze wiedział, gdzie ma szukać tych plików. Ma to robić na tyle skutecznie, żeby nie było ważne, gdzie framework został zainstalowany. Zobacz na poniższym przykładzie, jak należy postąpić z każdym znacznikiem img:





Zwróć uwagę na funkcję textarea_tag. Wyświetla ona pole edycyjne. Pierwszy argument definiuje nazwę tego pola, drugi jego zawartość, trzeci zaś to opcje. W tym przypadku chcemy mieć pole, w którym możemy nie tylko wpisywać tekst, ale również go formatować — oznaczamy to opcją rich="true". Takie pole edycyjne nie zostało przewidziane w języku HTML, dlatego w celu jego utworzenia posłużymy się dodatkowym komponentem TinyMCE. Na rysunku 5.8 możesz zobaczyć ten komponent umieszczony w naszej aplikacji.

Rozdział 5. ♦ Przykładowa aplikacja

163

Rysunek 5.8. Komponent TinyMCE w panelu administracyjnym — edycja strony o firmie

Komponent TinyMCE możesz pobrać z internetu (ze strony http://tinymce.moxiecode. com/) lub skorzystać z wersji umieszczonej na dołączonej płycie (została ona spolszczona). W celu użycia komponentu wystarczy, że skopiujesz katalog tiny_mce do katalogu web/js, a następnie poinformujesz Symfony, że powinien go użyć. W tym celu w pliku settings.yml z katalogu apps/panel/config dodaj odpowiednią linię do sekcji prod. Poniżej listing tej sekcji: prod: .settings: no_script_name: rich_text_js_dir:

off js/tiny_mce

Zwróć też uwagę na pozostałe opcje przekazane do funkcji textarea_tag. Parametr size oznacza oczywiście wielkość pola, natomiast parametr tinymce_options przekazuje opcje do edytora — w tym przypadku ustawia w nim język interfejsu na polski (działa to tylko w przypadku użycia spolszczonej wersji TinyMCE). Nasza aplikacja potrafi już wyświetlić zawartość pobraną z bazy. Pora umożliwić jej jeszcze zapisanie zmian. W tym celu utworzymy odpowiednią akcję w module admini ´strator. Będzie ona wyglądała tak: public function executeSubmitOFirmie() { $oRequest = $this->getRequest(); $oSystemowa = SystemowaPeer::doSelectOne( new Criteria() ); $oSystemowa->setSysOFirmie( $oRequest->getParameter( 'o_firmie' ) ); $oSystemowa->save(); $this->redirect( 'administrator/oFirmie?zmiany=1' ); }

164

PHP5. Programowanie z wykorzystaniem Symfony, CakePHP, Zend Framework

Jak widzisz, nie jest to skomplikowane — pobieramy wiersz z tabeli SYSTEMOWA, modyfikujemy pole o_firmie na podstawie parametru otrzymanego z formularza. Następnie zapisujemy zmodyfikowany wiersz z powrotem do bazy. Ostatnia linia przekierowuje użytkownika na tę samą stronę widoku, ale z dodatkowym komunikatem informującym o zapisaniu zmian.

Interfejs użytkownika — o firmie Utworzymy teraz stronę o firmie przeznaczoną dla użytkownika. W tym celu utwórz akcję index w module o_firmie, tzn. w pliku actions.class.php z katalogu apps/wizytowki/ module/o_firmie/actions umieść funkcję: public function executeIndex() { $this->oSystemowa = SystemowaPeer::doSelectOne( new Criteria() ); }

Treść akcji jest identyczna z treścią akcji oFirmie w module administrator. Następnie utwórzmy widok dla tej akcji, tzn. plik indexSuccess.php w katalogu apps/wizytowki/ modules/o_firmie/templates:

O firmie