Post
#1
|
|
|
Grupa: Developerzy Postów: 823 Pomógł: 12 Dołączył: 18.12.2005 Ostrzeżenie: (0%)
|
Witam Was… Ostatnio zainstalowałem sobie nowy serwer (zrobiłem update) z php 5.1.1 na 5.2.0. W rezultacie połowa tablic przestała mi działać… pięknie co? Powiem szczeże że się zdenerwowałem jak nic… już kilka dni badam o co chodzi. Przykładowy kod z widoku mojego frameworka:
Obiekt $oView oczywiście został wcześniej zainicjowany. Przejdźmy do rzeczy… Zaraz po zadeklarowaniu tablicy sprawdzamy ją tak dla pewności, że jest. „No dziwne by było żeby jej nie było” (masło maślane ale prawda sama w sobie (IMG:http://forum.php.pl/style_emoticons/default/smile.gif) ) Ok. jedziemy dalej… dodajemy do tablicy kolejne elementy poprzez użycie [] – co to oznacza każdy wie. Po dodaniu elementów lumpujemy tablice po raz kolejny. O dziwo jest pusta (IMG:http://forum.php.pl/style_emoticons/default/blink.gif) . Przypominam, że zrobiłem update z php 5.1.1 na 5.2.0. Czyżby wlepili tam jakiegoś buga? Zaraz po updacie ta część kodu przestała działać. Podobnie warstwa ACL, gdzie klasa User w podobny sposób sama sobie dodaje grupy użytkownika – dziwiłem się, że do żadnego kontrolera nie mam dostępu (IMG:http://forum.php.pl/style_emoticons/default/smile.gif) Teraz wszystko jasne. Zainteresowało mnie to, przeprowadziłem testy. Napisałem dwa przykłady, które działają… Test 01:
Test 02:
Co jest nie tak? Może załącze jeszcze klase mojego widoku I usera, aby pokazać, że dodaję elementy w taki sam sposób: User Class (patrz metody setGroup(), hasGroup(), getGroup() ) http://phpfi.com/179458 View Class (patrz metody __get(), __set() ) http://phpfi.com/179456 Ten post edytował Athlan 28.11.2006, 16:37:22 |
|
|
|
![]() |
Post
#2
|
|
|
Grupa: Developerzy Postów: 823 Pomógł: 12 Dołączył: 18.12.2005 Ostrzeżenie: (0%)
|
Dziś odkryłem swój błąd, który popełniłem przy tworzeniu tablic. Pokażę to na poniższym przykładzie:
Dump tablicy wykaże pustą – ma wykazać. Dlaczego? Do metody __get() dostaje się atrybut test – ok. Następnie deklarujemy atrybut test[]. Co pomyśli sobie __set() i __get() ? Dla zmiennej $sName oznacza po prostu $this->_aAttributes[test[]], a powinno $this->_aAttributes[test][]. Po części prawda, po części paradoks. Moim zdaniem php zamo sobie powinno wrzucać elementy w tablice przy __set() i __get(), no ale skoro nie… Więc jak można rozwiązać powyższy przykład? Ano bardzo podobnie, budowa klasy nie zmieni się:
Teraz działa? (IMG:http://forum.php.pl/style_emoticons/default/smile.gif) Sam jestem zaskoczony, można z tego wyciągnąć jakiś wniosek, dla mnie jest jednoznaczny: twórcy php engine nie popisali się pod tym względem, nie możemy operować na tablicach obiektu poprzez metodę __set(). Teoretycznie nawet nie powinniśmy, ba co przyjmie pierwszy argument tej funkcji? Przyjmie Stinga jak ma się nazywać zmienna (kolejny element tablicy private $_aAttributes. Teoretycznie nie powinno działać, ale ja i tak wnoszę sprzeciw. Takie jest moje zdanie (IMG:http://forum.php.pl/style_emoticons/default/smile.gif) Tak więc prostuje moje poprzednie pytanie (IMG:http://forum.php.pl/style_emoticons/default/smile.gif) . Fajnie jest dojść do takiego wniosku, więc zachęcam innych do tworzenia mnóstwa przykładów odwzorowujących kawałek naszego kodu, który rzekomo nie działa. To nauczka dla mnie, jak i przykład dla młodych programistów. Szczerze po tej wypowiedzi w ogóle nie wstydzę się pytania którego zadałem, gdyż nikt nie był w stanie mi na nie odpowiedzieć – nie ma pola do wstydu (IMG:http://forum.php.pl/style_emoticons/default/tongue.gif) Dziwną rzeczą jednak jest to, że kolizja wystąpiła dopiero w php 5.2.0, a w poprzedniej (mojej) wersji na serwerze 5.1.1 rzekomy błąd nowego pokolenia php 5 gładko działał. Zapraszam do dyskusji na ten temat w tym topicku – może ktos wie coś na owy przypadek traktowania zmiennych __set() w pierwszym parametrze. Pozdrawiam, Athlan (IMG:http://forum.php.pl/style_emoticons/default/smile.gif) ----- [EDIT] ----- P.S. Jak wspomniałem w pytaniu, przez to padł mi ACL a precyzując: klasa User, która nadawała grupy użytkownikowi do sesji. Kod wyglądał następująco:
Jak widać, sesja $this->_oUserSessionInfo jest obiektem (po prefiksie wiedeńskim). Zmienna groups[] przyjmowana jest do klasy sesji poprzez metodę __set() w pierwszym jej parametrze. Wczesniej udowodniłem, że tak nie może być… jak rozwiązać problem? Ano namotamy trochę w kodzie – ale będzie działało.
Najpierw pobieramy tablicę $aArray z sesji jako tablica grup. Potem wykonujemy operację dodania grupy już poza klasą nie używając metody __set(), po czym tablice ponownie zapisujemy do __set()’a. Innego sposobu nie ma… ale jakiegoś haka udało mi się wymyślić. Ten post edytował Athlan 30.11.2006, 17:07:18 |
|
|
|
Athlan Tablice w php 5.2.0 28.11.2006, 16:36:20
koala Witam
Nie instalowałem jeszcze 5.2 ale tutaj : htt... 29.11.2006, 00:17:53
hugo_amv Witam
Rozwiazaniem tego problemu jest użycie funkc... 29.11.2006, 12:44:33
J4r0d Pytanie dlaczego nie można przypisywać elementu w ... 29.11.2006, 15:04:48
Cysiaczek Potestowałem troszkę i nie zauważyłem różnic w obs... 29.11.2006, 15:29:03
hwao Musi Ci wywalać gdzieś jakiś errro, daj PEŁNE rapo... 29.11.2006, 19:19:42
Ace $oArrayTest = ArrayTest();
a nie powinno byc... 30.11.2006, 10:15:29
cassis Proponuje zamiast tablic w tym przypadku użyć Arra... 4.12.2006, 08:33:00 
J4r0d Cytat(cassis @ 4.12.2006, 08:33:00 ) ... 4.12.2006, 18:08:25
cassis Do tego właśnie służą magiczne metody __get() __se... 4.12.2006, 18:14:42
J4r0d Tylko jaki jest sens przypisywać nieistniejącej zm... 4.12.2006, 19:28:34
cassis maly przyklad
przed uzyciem skontaktuj sie z baza ... 4.12.2006, 20:57:58
Athlan Panowie, panowie
Chyba zupełnie odbiegli... 5.12.2006, 14:38:13
cassis no tak - troche poplynalem. Chcialem wytlumaczyc j... 5.12.2006, 16:20:24 ![]() ![]() |
|
Aktualny czas: 18.01.2026 - 14:20 |