承接 alen-dev/xpath-log 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

alen-dev/xpath-log

最新稳定版本:v1.0.0

Composer 安装命令:

composer require alen-dev/xpath-log

包简介

Simple Laravel Logger

README 文档

README

Latest Version on Packagist GitHub Tests Action Status GitHub Code Style Action Status Total Downloads

A simple and extensible Laravel logging package for structured logging, transactions, and multiple output drivers — all with zero code changes when switching drivers.

🚀 Features

  • 🔧 Multiple log levels (debug, info, warning, error)
  • 🏷 Tagged log entries with custom attributes
  • 📁 Supports multiple drivers:
    • CLI (console output)
    • JSON file logging (rotated daily)
    • Simple text log file
  • 🔄 Transaction-based logging with start/end timestamps
  • 📆 Log viewer Artisan command with filters
  • ➕ Easily add custom drivers without modifying the core
  • 📦 Laravel-ready with automatic service provider & facade

📦 Installation

composer require alen-dev/xpath-log

🛠 Setup

Step 1: Publish the config

php artisan vendor:publish --tag=xpath-log-config

This is the contents of the published config file:

return [
    'driver_map' => [
        'cli' => \AlenDev\XpathLog\Drivers\CliDriver::class,
        'json' => \AlenDev\XpathLog\Drivers\JsonFileDriver::class,
        'log'  => \AlenDev\XpathLog\Drivers\LogFileDriver::class,
    ],
    'external_driver_map' => [],
    'default_drivers' => explode(',', env('XPATH_LOG_DEFAULT_DRIVERS', 'cli,log')),
    'file_name' => env('XPATH_LOG_FILENAME', 'xpath'),
];

Step 2: Optional ENV config

XPATH_LOG_DEFAULT_DRIVERS="cli,log"
XPATH_LOG_FILENAME=xpathlog

🧪 Usage

Basic Logging

$xPathLog = new XpathLog();
$xPathLog
    ->use('cli')
    ->log('warning', 'message', ['test' => '34234']);

Transaction Logging

$xPathLog
    ->use('json')
    ->startTransaction('TX-789', ['customerId' => 123]);
$xPathLog
    ->use('json')
    ->endTransaction('TX-789', ['status' => 'success']);

Or log custom transaction messages:

$xPathLog
    ->use('json')
    ->transaction('abc-123', 'Applied discount', ['code' => 'SUMMER']);

🖥 Artisan Log Viewer

Optional: you can add some sample data for Artisan Log Viewer. The log viewer is designed to view JSON log created by this package.

php artisan xpathlog:create-sample

View the most recent XpathLog entries from your JSON log file (other file formats coming soon)

php artisan xpathlog:view

Filter logs

php artisan xpathlog:view --level=error
php artisan xpathlog:view --search=payment
php artisan xpathlog:view --date=2025-08-01
php artisan xpathlog:view --from="2025-08-01" --to="2025-08-02"
php artisan xpathlog:view --search=payment --from="yesterday"

🧩 Custom Drivers

You can register custom drivers externally via config:

// config/xpath-log.php
'driver_map' => [
    'slack' => App\Logging\Drivers\SlackDriver::class,
],

Each driver must implement:

interface DriverInterface {
    public function handle(LogEntry $entry): void;
}

🧩 Request Logger

This feature is disabled by default. To enable just add the following variable to your .env file:

XPATH_LOG_ENABLE_REQUEST_LOGGER=true

If enabled, by default, this will log every request on your web middleware but you can change this by adding the following line to your .env file:

XPATH_LOG_MIDDLEWARE_GROUP=api

🧪 Testing

composer test

Changelog

Please see CHANGELOG for more information on what has changed recently.

Credits

License

The MIT License (MIT). Please see License File for more information.

统计信息

  • 总下载量: 2
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-08-04