php日志工具类 - 纯原生

class Logger {
    private $logFile; // 存储日志文件的路径
    private $placeholderValue; // 占位符值
    private $fieldsToNull; // 需要置空的字段列表

    /**
     * 构造函数,初始化日志记录器
     *
     * @param string $logFilePath 日志文件的完整路径
     * @param mixed $placeholderValue 用作占位符的值
     * @param array $fieldsToNull 需要置空的字段名数组
     */
    public function __construct($logFilePath, $placeholderValue = null, $fieldsToNull = []) {
        $this->logFile = $logFilePath;
        $this->placeholderValue = $placeholderValue;
        $this->fieldsToNull = $fieldsToNull;
    }

    /**
     * 记录日志消息到日志文件
     *
     * @param mixed $message 要记录的日志消息
     * @param string $logLevel 日志级别(默认为 'info')
     */
    public function log($message, $logLevel = 'info') {
        $timestamp = date('Y-m-d H:i:s');
        $logMessage = "[$timestamp][$logLevel] " . $this->formatMessage($message) . PHP_EOL;
        file_put_contents($this->logFile, $logMessage, FILE_APPEND);
    }

    /**
     * 格式化日志消息
     *
     * @param mixed $message 要格式化的消息
     * @return string 返回格式化后的消息
     */
    public function formatMessage($message) {
        $message = $this->nullFieldsRecursively($message, $this->fieldsToNull);
        return json_encode($message, JSON_PRETTY_PRINT);
    }

    /**
     * 递归地将字段置空
     *
     * @param mixed $data 要处理的数据
     * @param array $fields 需要置空的字段名数组
     * @return mixed 处理后的数据
     */
    private function nullFieldsRecursively($data, $fields) {
        if (is_array($data)) {
            foreach ($fields as $field) {
                if (array_key_exists($field, $data)) {
                    $data[$field] = $this->placeholderValue;
                }
            }
            foreach ($data as $key => $value) {
                $data[$key] = $this->nullFieldsRecursively($value, $fields);
            }
        }
        return $data;
    }

    /**
     * 记录信息级别的日志
     *
     * @param mixed $message 要记录的信息消息
     */
    public function info($message) {
        $this->log($message, 'info');
    }

    /**
     * 记录错误级别的日志
     *
     * @param mixed $message 要记录的错误消息
     */
    public function error($message) {
        $this->log($message, 'error');
    }

    /**
     * 记录警告级别的日志
     *
     * @param mixed $message 要记录的警告消息
     */
    public function warning($message) {
        $this->log($message, 'warning');
    }

    /**
     * 记录调试级别的日志
     *
     * @param mixed $message 要记录的调试消息
     */
    public function debug($message) {
        $this->log($message, 'debug');
    }
}

// 用法示例:
$log = new Logger('/path/to/app.log', '***', ['sensitive_field']);
$data = [
    'user' => [
        'id' => 123,
        'name' => 'John',
        'sensitive_field' => 'sensitive_data',
    ],
    'action' => 'login',
    'timestamp' => time(),
];
$log->info($data);

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

南风拂衣

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值