PHP - Implemente o mecanismo de registro para arquivar em várias classes
Eu gostaria de implementar mecanismo de registro para arquivo em PHP:
caminho do arquivo de log estará no arquivo de configuração config.phpem várias classes gostaria de registrar alguns eventos no arquivo de logPor exemplo:
Class A {
public function f_A {
log_to_file($message);
}
}
Class B {
public function f_B {
log_to_file($message);
}
}
Ficarei muito grato por qualquer dica. Eu gostaria de implementar algumas soluções fáceis e elegantes.
Eu estava pensando nisso (obrigado pelas suas respostas) e acho que vou fazer desse jeito (talvez, há alguns erros, eu estava escrevendo do zero):
interface Logger {
public function log_message($message);
}
class LoggerFile implements Logger {
private $log_file;
public function __construct($log_file) {
$this->log_file = $log_file;
}
public function log_message($message) {
if (is_string($message)) {
file_put_contents($this->log_file, date("Y-m-d H:i:s")." ".$message."\n", FILE_APPEND);
}
}
}
//maybe in the future logging into database
class LoggerDb implements Logger {
private $db;
public function __construct($db) {
//some code
}
public function log_message($message) {
//some code
}
}
Class A {
private $logger;
public function __construct(Logger $l) {
$this->logger = $l;
}
public function f_A {
$this->logger->log_message($message);
}
}
Class B {
private $logger;
public function __construct(Logger $l) {
$this->logger = $l;
}
public function f_B {
$this->logger->log_message($message);
}
}
//usage:
//in config.php:
define("CONFIG_LOG_FILE", "log/app_log.log");
//in the index.php or some other files
$logger = new LoggerFile(CONFIG_LOG_FILE);
$instance_a = new A($logger);
$instance_b = new B($logger);