Podobnie jak inne, miałem pliki dziennika całkowicie przestały zapisywać dane.
Źródło błędu - pliki dziennika nie zapisują danych
W app/Mage.php
zrobili tę zmianę:
// Validate file extension before save. Allowed file extensions: log, txt, html, csv
- if (!self::helper('log')->isLogFileExtensionValid($file)) {
+ $_allowedFileExtensions = explode(
+ ',',
+ (string) self::getConfig()->getNode('dev/log/allowedFileExtensions', Mage_Core_Model_Store::DEFAULT_CODE)
+ );
+ $logValidator = new Zend_Validate_File_Extension($_allowedFileExtensions);
+ $logDir = self::getBaseDir('var') . DS . 'log';
+ if (!$logValidator->isValid($logDir . DS . $file)) {
return;
}
która szuka konfiguracji zatwierdzonej oddzielonych przecinkami listy zatwierdzonych rozszerzeń plików. NIE dodali jednak tej listy do konfiguracji - nawet nie ma opcji w Administratorze Maga, abyśmy mogli skonfigurować ją samodzielnie.
Rozwiązanie problemu - pliki dziennika nie zapisują danych
Aby rozwiązać ten problem, po prostu wprowadź dane do bazy danych w core_config_data
tabeli.
INSERT INTO core_config_data VALUES ( NULL, 'default', 0, 'dev/log/allowedFileExtensions', 'log,txt,html,csv' );
Wyczyść także pamięć podręczną obiektów i powinieneś ponownie zobaczyć zapis danych do plików dziennika.
ls -lrt var/log/ | tail
Dla odniesienia ten problem dotyczy EE 1.14.2.0 ze wszystkimi zastosowanymi poprawkami zabezpieczeń.
Otworzyłem zgłoszenie do pomocy technicznej Magento w tej sprawie, ale nie otrzymałem jeszcze odpowiedzi od technika. Jestem w kolejce.
To, co naprawdę dezorientuje mnie w tym błędzie, to fakt, że Magento ma już metodę sprawdzania poprawności rozszerzeń plików dziennika, które dodały za pośrednictwem SUPEE-10415 pod koniec 2017 roku.
app/code/core/Mage/Log/Helper/Data.php
/**
* Checking if file extensions is allowed. If passed then return true.
*
* @param $file
* @return bool
*/
public function isLogFileExtensionValid($file)
{
$result = false;
$validatedFileExtension = pathinfo($file, PATHINFO_EXTENSION);
if ($validatedFileExtension && in_array($validatedFileExtension, $this->_allowedFileExtensions)) {
$result = true;
}
return $result;
}
Dlaczego nie wykorzystali tej logiki zamiast próby niepełnego ponownego wynalezienia koła z bali?