PHP에서 로그 파일을 만드는 방법은 무엇입니까?
내 시스템이 시스템 내부에서 수행하는 모든 작업을 등록 / 기록 할 로그 파일을 만들고 싶습니다. 그러나 나는 그것을하는 방법을 모른다.
예를 들어, 로그인 기능을 수행하는이 PHP 코드가 있습니다.
public function hasAccess($username,$password){
$form = array();
$form['username'] = $username;
$form['password'] = $password;
$securityDAO = $this->getDAO('SecurityDAO');
$result = $securityDAO->hasAccess($form);
//var_dump($form);
//var_dump($result);
if($result[0]['success']=='1'){
$this->Session->add('user_id', $result[0]['id']);
//$this->Session->add('username', $result[0]['username']);
//$this->Session->add('roleid', $result[0]['roleid']);
return $this->status(0,true,'auth.success',$result);
}else{
return $this->status(0,false,'auth.failed',$result);
}
}
이제 '오늘 날짜'라는 이름의 로그 파일을 만들고 싶습니다. 그 기능을 사용하여 로그인하면 다른 기능과 마찬가지로 해당 사용자가 로그인 한 것으로 기록됩니다. 하지만 매일 하나의 파일 만 원합니다.
누구든지 코드를 어떻게해야하는지 안내하고 가르쳐 줄 수 있습니까?
로그 파일에 기록하고 매일 새 파일을 만들 date("j.n.Y")
려면 파일 이름의 일부로 사용할 수 있습니다 .
//Something to write to txt log
$log = "User: ".$_SERVER['REMOTE_ADDR'].' - '.date("F j, Y, g:i a").PHP_EOL.
"Attempt: ".($result[0]['success']=='1'?'Success':'Failed').PHP_EOL.
"User: ".$username.PHP_EOL.
"-------------------------".PHP_EOL;
//Save string to log, use FILE_APPEND to append.
file_put_contents('./log_'.date("j.n.Y").'.log', $log, FILE_APPEND);
그래서 당신은 그것을 당신의 hasAccess()
방법에 넣을 것 입니다.
public function hasAccess($username,$password){
$form = array();
$form['username'] = $username;
$form['password'] = $password;
$securityDAO = $this->getDAO('SecurityDAO');
$result = $securityDAO->hasAccess($form);
//Write action to txt log
$log = "User: ".$_SERVER['REMOTE_ADDR'].' - '.date("F j, Y, g:i a").PHP_EOL.
"Attempt: ".($result[0]['success']=='1'?'Success':'Failed').PHP_EOL.
"User: ".$username.PHP_EOL.
"-------------------------".PHP_EOL;
//-
file_put_contents('./log_'.date("j.n.Y").'.txt', $log, FILE_APPEND);
if($result[0]['success']=='1'){
$this->Session->add('user_id', $result[0]['id']);
//$this->Session->add('username', $result[0]['username']);
//$this->Session->add('roleid', $result[0]['roleid']);
return $this->status(0,true,'auth.success',$result);
}else{
return $this->status(0,false,'auth.failed',$result);
}
}
php로 로그 파일을 생성하려면 함수에 대한 데이터를 전달해야하며 로그 파일을 생성합니다.
function wh_log($log_msg)
{
$log_filename = "log";
if (!file_exists($log_filename))
{
// create directory/folder uploads.
mkdir($log_filename, 0777, true);
}
$log_file_data = $log_filename.'/log_' . date('d-M-Y') . '.log';
// if you don't add `FILE_APPEND`, the file will be erased each time you add a log
file_put_contents($log_file_data, $log_msg . "\n", FILE_APPEND);
}
이 문서를 확인하십시오.
http://php.net/manual/en/function.error-log.php
예:
<?php
// Send notification through the server log if we can not
// connect to the database.
if (!Ora_Logon($username, $password)) {
error_log("Oracle database not available!", 0);
}
// Notify administrator by email if we run out of FOO
if (!($foo = allocate_new_foo())) {
error_log("Big trouble, we're all out of FOOs!", 1,
"operator@example.com");
}
// another way to call error_log():
error_log("You messed up!", 3, "/var/tmp/my-errors.log");
?>
내장 기능 trigger_error()
을 사용 하여 사용자 오류 / 경고 / 알림을 트리거하고 set_error_handler()
이를 처리 할 수 있습니다. 오류 처리기 내 에서 파일에 모든 레코드 를 사용 error_log()
하거나 file_put_contents()
저장할 수 있습니다. 매일 하나의 파일을 가지려면 파일 sprintf('%s.log', date('Y-m-d'))
이름 과 같은 것을 사용하십시오 . 이제 어디서부터 시작해야할지 알아야합니다 ... :)
이 코드를 확인하십시오. 잘 작동합니다.
$data = array('shopid'=>3,'version'=> 1,'value=>1'); //here $data is dummy varaible
error_log(print_r($data,true), 3, $_SERVER['DOCUMENT_ROOT']."/your-file-name.log");
//In $data we can mention the error messege and create the log
@jon 답변에 동의하십시오. 경로를 수정하여 log
내부에 디렉토리 를 생성했습니다 .root
function wh_log($log_msg) {
$log_filename = $_SERVER['DOCUMENT_ROOT']."/log";
if (!file_exists($log_filename))
{
// create directory/folder uploads.
mkdir($log_filename, 0777, true);
}
$log_file_data = $log_filename.'/log_' . date('d-M-Y') . '.log';
file_put_contents($log_file_data, $log_msg . "\n", FILE_APPEND);
}
방금 추가 $_SERVER['DOCUMENT_ROOT']
아래 기능 사용
// Enable error reporting
ini_set('display_errors', 1);
//Report runtime errors
error_reporting(E_ERROR | E_WARNING | E_PARSE);
//error_reporting(E_ALL & ~E_NOTICE);
// Tell php where your custom php error log is
ini_set('error_log', 'php_error.log');
$dateTime=date("Y-m-d H:i:s");
$ip= $_SERVER['REMOTE_ADDR'];
$errorString="Error occured on time $dateTime by ip $ip";
$php_error_msg.=$errorString;
// Append the error message to the php-error log
//error_log($php_error_msg);
error_log("A custom error has been triggered",1,"email_address","From: email_address");
위의 기능은 적절한 설명과 함께 php_error 파일에 로그인을 생성하고 이메일이 전송 될 것입니다.
This is my working code. Thanks to Paulo for the links. You create a custom error handler and call the trigger_error
function with the correct $errno
exception, even if it's not an error. Make sure you can write to the log file directory without administrator access.
<?php
$logfile_dir = "C:\workspace\logs\\"; // or "/var/log/" for Linux
$logfile = $logfile_dir . "php_" . date("y-m-d") . ".log";
$logfile_delete_days = 30;
function error_handler($errno, $errstr, $errfile, $errline)
{
global $logfile_dir, $logfile, $logfile_delete_days;
if (!(error_reporting() & $errno)) {
// This error code is not included in error_reporting, so let it fall
// through to the standard PHP error handler
return false;
}
$filename = basename($errfile);
switch ($errno) {
case E_USER_ERROR:
file_put_contents($logfile, date("y-m-d H:i:s.").gettimeofday()["usec"] . " $filename ($errline): " . "ERROR >> message = [$errno] $errstr\n", FILE_APPEND | LOCK_EX);
exit(1);
break;
case E_USER_WARNING:
file_put_contents($logfile, date("y-m-d H:i:s.").gettimeofday()["usec"] . " $filename ($errline): " . "WARNING >> message = $errstr\n", FILE_APPEND | LOCK_EX);
break;
case E_USER_NOTICE:
file_put_contents($logfile, date("y-m-d H:i:s.").gettimeofday()["usec"] . " $filename ($errline): " . "NOTICE >> message = $errstr\n", FILE_APPEND | LOCK_EX);
break;
default:
file_put_contents($logfile, date("y-m-d H:i:s.").gettimeofday()["usec"] . " $filename ($errline): " . "UNKNOWN >> message = $errstr\n", FILE_APPEND | LOCK_EX);
break;
}
// delete any files older than 30 days
$files = glob($logfile_dir . "*");
$now = time();
foreach ($files as $file)
if (is_file($file))
if ($now - filemtime($file) >= 60 * 60 * 24 * $logfile_delete_days)
unlink($file);
return true; // Don't execute PHP internal error handler
}
set_error_handler("error_handler");
trigger_error("testing 1,2,3", E_USER_NOTICE);
?>
참고URL : https://stackoverflow.com/questions/19898688/how-to-create-a-logfile-in-php
'Development Tip' 카테고리의 다른 글
셸에 URL이 존재하고 아마도 컬이 있는지 확인하는 방법은 무엇입니까? (0) | 2020.12.07 |
---|---|
Mockito로 콜백 호출 (0) | 2020.12.07 |
Elastic Beanstalk T2 서버는 내 node.js 앱 파일을 어디에 저장하나요? (0) | 2020.12.07 |
if-else가 아닌 switch 문이 필요한 이유는 무엇입니까? (0) | 2020.12.07 |
가장 가까운 달러로 반올림 된 통화를 더블로 포맷하려면 어떻게합니까? (0) | 2020.12.07 |