Portál AbcLinuxu, 12. května 2025 12:25

Dotaz: PHP: Class not found, přestože třída je definována

18.5.2012 17:04 Tatar
PHP: Class not found, přestože třída je definována
Přečteno: 266×
Odpovědět | Admin
Ahoj všem, dostal jsem se do zajímavého problému, se kterým si nějak nevím rady, resp. moc nerozumím jeho podstatě, takže by se mi hodil pohled jinýma očima.

Situace je taková, že jsem dostal za úkol přestěhovat nějaké zprovozněné weby postavené na Typo3 z jednoho webserveru na druhý, přičemž původní server běží na Debianu s PHP 5.2 a na novém serveru je CentOS 5.3.

Typo3 ve verzi 4.4.x a ještě i 4.5.x si s PHP 5.3 chvílemi nerozumí (je laděné pro PHP 5.2). Jeden z problémů na novém serveru se projevuje na přihlašovací obrazovce backendu: dole se zobrazuje chybové hlášení:

Fatal error: Class 't3lib_div' not found in /var/lib/typo3/typo3_src-4.5.15/t3lib/error/class.t3lib_error_errorhandler.php on line 128

Při hledání příčiny jsem zkusil těsně před tento řádek vložit následující výpis:

echo (class_exists('t3lib_div') ? 'existuje' : 'NEexistuje');

Po této úpravě se vypíše "existuje" a chybové hlášení se změní na:

Fatal error: Exception thrown without a stack frame in Unknown on line 0

Asi úplně nechápu, jak může být třída v určité části kódu definovaná, ale nedostupná. Co mi uniká?

(případné rady k opravě Typo3 instalace beru taky, ale hlavní podstata dotazu je v té programátorské rovině).

Předem díky za všechny rady!
Nástroje: Začni sledovat (0) ?Zašle upozornění na váš email při vložení nového komentáře.

Odpovědi

18.5.2012 17:06 Tatar
Rozbalit Rozbalit vše Re: PHP: Class not found, přestože třída je definována
Odpovědět | | Sbalit | Link | Blokovat | Admin
Upřesňující doplnění: tím "před tento řádek" mám na mysli před řádek 128 (zmíněný v chybovém hlášení), na kterém je v kódu Typo3 toto volání:

t3lib_div::sysLog($message, $logTitle, $severity);
18.5.2012 19:12 Kit
Rozbalit Rozbalit vše Re: PHP: Class not found, přestože třída je definována
Odpovědět | | Sbalit | Link | Blokovat | Admin
Typo3 neznám, asi by ta otázka měla směřovat spíš k autorům. Ovšem Google velmi rychle našel, že je to způsobeno chybnou kombinací error handleru a vyhození výjimky v destruktoru.

Třída tedy existuje, ale je v ní chyba.

Jen tak pro zajímavost: Na podobné testy můžeš využít funkci assert()
assert("class_exists('t3lib_div');");
Výhodou je, že ji v tom kódu můžeš klidně nechat, případně globálně zakázat (nebude se vyhodnocovat).
19.5.2012 10:56 Tatar
Rozbalit Rozbalit vše Re: PHP: Class not found, přestože třída je definována
Díky za odpověď! I když jsem v otázce hodně zdůraznil to Typo3, tak mi šlo hlavně o tu programátorskou podstatu, jak může definovaná třída dělat takové blbiny (jinak opravy Typo3 milerád přenechám autorům a tohle konkrétně už nějaký ten pátek asi opravené mají).

Pokud jde o ten dotaz do Google, myslel jsem, že to bylo únavou, ale ani dneska se mi nedaří se zeptat tak, abych se dozvěděl to, co jsi mi napsal. Můžeš mi prosím aspoň pro zajímavost říct, jaký dotaz jsi položil? O:-)
19.5.2012 12:19 Kit
Rozbalit Rozbalit vše Re: PHP: Class not found, přestože třída je definována
Jistě. Ten dotaz zněl takto:
"Exception thrown without a stack frame in Unknown"
včetně uvozovek.

Založit nové vláknoNahoru

Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

ISSN 1214-1267, (c) 1999-2007 Stickfish s.r.o.