当前位置:首页 > PHP

php实现记录

2026-01-29 14:43:16PHP

PHP实现日志记录的方法

使用PHP内置函数error_log记录日志 error_log函数可以将日志信息写入到指定位置,支持文件、系统日志或邮件发送。语法如下:

error_log("Error message", 3, "/path/to/error.log");

配置PHP错误日志路径 在php.ini文件中设置以下参数:

log_errors = On
error_log = /path/to/php_errors.log

使用Monolog日志库

安装Monolog 通过Composer安装Monolog:

composer require monolog/monolog

基本使用示例

require 'vendor/autoload.php';
use Monolog\Logger;
use Monolog\Handler\StreamHandler;

$log = new Logger('name');
$log->pushHandler(new StreamHandler('path/to/your.log', Logger::WARNING));
$log->warning('This is a warning');

自定义日志类实现

创建日志类

class CustomLogger {
    private $logFile;

    public function __construct($filePath) {
        $this->logFile = $filePath;
    }

    public function log($message, $level = 'INFO') {
        $timestamp = date('Y-m-d H:i:s');
        $logEntry = "[$timestamp][$level] $message" . PHP_EOL;
        file_put_contents($this->logFile, $logEntry, FILE_APPEND);
    }
}

使用示例

$logger = new CustomLogger('/path/to/logfile.log');
$logger->log('This is an informational message');
$logger->log('Something went wrong', 'ERROR');

数据库日志记录

创建日志表

CREATE TABLE system_logs (
    id INT AUTO_INCREMENT PRIMARY KEY,
    level VARCHAR(20),
    message TEXT,
    created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
    ip_address VARCHAR(45)
);

PHP实现数据库日志

function logToDatabase($message, $level = 'INFO') {
    $db = new PDO('mysql:host=localhost;dbname=yourdb', 'user', 'pass');
    $stmt = $db->prepare("INSERT INTO system_logs (level, message, ip_address) 
                         VALUES (?, ?, ?)");
    $stmt->execute([$level, $message, $_SERVER['REMOTE_ADDR']]);
}

日志轮转和归档

实现日志文件轮转

function rotateLog($filePath, $maxSize = 1048576) {
    if (file_exists($filePath) && filesize($filePath) >= $maxSize) {
        $backupFile = $filePath . '.' . date('YmdHis');
        rename($filePath, $backupFile);
    }
}

定时清理旧日志

function cleanOldLogs($dir, $daysToKeep = 30) {
    $files = glob($dir . '/*.log*');
    $now = time();

    foreach ($files as $file) {
        if (is_file($file) && ($now - filemtime($file)) > ($daysToKeep * 86400)) {
            unlink($file);
        }
    }
}

php实现记录

标签: php
分享给朋友:

相关文章

php实现打印功能

php实现打印功能

PHP 实现打印功能的方法 PHP 可以通过多种方式实现打印功能,具体取决于打印的目标(如打印机、PDF、网页等)和需求(如直接打印、生成打印预览等)。以下是几种常见的实现方式: 使用 JavaS…

php实现搜索功能

php实现搜索功能

实现基本的搜索功能 在PHP中实现搜索功能通常涉及数据库查询。以下是一个简单的实现方式,假设使用MySQL数据库: <?php // 连接数据库 $conn = new mysqli('loc…

git php实现

git php实现

Git 与 PHP 的集成实现 使用 PHP 执行 Git 命令 通过 PHP 的 exec()、shell_exec() 或 passthru() 函数可以直接调用 Git 命令,适用于服务器端操作…

php实现定时任务

php实现定时任务

PHP 实现定时任务的几种方法 在 PHP 中实现定时任务可以通过多种方式完成,具体选择取决于项目需求和服务器环境。以下是常见的实现方法: 使用 Cron 任务 Cron 是 Linux 系统中常用…

php实现表单

php实现表单

PHP 表单基础实现 创建一个简单的 PHP 表单需要 HTML 表单结构和 PHP 处理脚本。以下是一个完整的示例: HTML 表单部分 (form.html) <form actio…

php实现登录

php实现登录

PHP 登录功能实现 数据库连接与用户表创建 创建一个数据库连接文件 db.php,用于管理数据库连接。MySQL 示例代码如下: <?php $host = 'localhost'; $d…