Wprowadzenie

Zespół Zend Framework Auth bardzo docenia twój wkład w naszą listę email: fw-auth@lists.zend.com

W aplikacjach web używających PHP, a sesja reprezentuje logiczne połączenie jeden-do-jednego pomiędzy danymi o stanie użytkownika znajdującymi się na serwerze, a konkretną aplikacją użytkownika (np. przeglądarka stron internetowych). Zend_Session pomaga w zarządzaniu i zabezpieczaniu danych sesji, które są logicznym dopełnieniem danych w ciasteczku, pomiędzy wieloma żądaniami do serwisu przez tego samego klienta. W przeciwieństwie do danych z ciasteczka, dane sesji nie są przechowywane po stronie klienta i są one dostępne dla klienta tylko wtedy, gdy kod po stronie serwera dobrowolnie udostępni dane w odpowiedzi na żądanie klienta. Dla celów tego komponentu oraz dokumentacji, określenie "dane sesji" odnoszą się do danych przechowywanych po stronie serwera w tablicy $_SESSION, zarządzanych przez Zend_Session, oraz indywidualnie manipulowanych przez obiekty dostępowe Zend_Session_Namespace. Przestrzenie nazw sesji zapewniają dostęp do danych sesji używając klasycznych przestrzeni nazw implementowanych logicznie jako nazwane grupy asocjacyjnych tablic, o kluczach będących łańcuchami znaków. (analogicznie jak tablice PHP).

Instancje Zend_Session_Namespace są obiektami dostępowymi dla przestrzeni nazw będących wycinkami tablicy $_SESSION. Komponent Zend_Session rozszerza istniejącą funkcjonalność PHP ext/session dodając interfejs umożliwiający administrację i zarządzanie, a także zapewniając API dla przestrzeni nazw Zend_Session_Namespace. Zend_Session_Namespace zapewnia ustandaryzowany zorientowany obiektowo interfejs do pracy z przestrzeniami nazw istniejącymi wewnątrz standardowego mechanizmu sesji PHP. Wspierane są zarówno przestrzenie nazw dla anonimowych użytkowników, jak i dla uwierzytelnionych (np. zalogowanych). Zend_Auth, komponent autentykacji w Zend Framework używa Zend_Session_Namespace do przechowywania informacji związanych z autentykowanymi użytkownikami w przestrzeni nazw "Zend_Auth". Z tego względu, że Zend_Session używa normalnych wewnętrznych funkcji modułu sesji, oraz umożliwia użycie wszystkich znanych opcji konfiguracyjnych i ustawień (zobacz http://www.php.net/session), a dodatkowo umożliwia dostęp za pomocą zorientowanego obiektowo interfejsu, to użycie tego modułu jest przykładem dobrej praktyki programowania, a także gładko integruje się z Zend Framework. Zatem standardowy identyfikator sesji PHP przechowywany albo w ciasteczku klienta, albo dołączony do adresów URL, umożliwia połączenie klienta oraz danych stanu sesji.

Domyślna obsługa zapisu sesji nie rozwiązuje problemu zarządzania tym powiązaniem dla klastrów serwerów, ponieważ dane sesji przechowywane są w systemie plików serwera, który odpowiada na żądanie. Jeśli żądanie może byc przetworzone przez inny serwer niż ten, na którym zapisane są dane sesji, to przetwarzający serwer nie ma dostępu do danych sesji (jeśli nie są dostępne w systemie plików połączonym siecią). Dodatkowe odpowiednie możliwości obsługi zapisu będą zapewnione, gdy będzie to możliwe. Namawiamy członków społeczności aby wysyłali propozycje możliwości obsługi zapisu na listę fw-auth@lists.zend.com. Obsługa zapisu kompatybilna z Zend_Db została opisana na liście.