定制 bilfeldt/laravel-request-logger 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

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

bilfeldt/laravel-request-logger

最新稳定版本:v3.6.0

Composer 安装命令:

composer require bilfeldt/laravel-request-logger

包简介

Log Laravel application request and responses for debugging or statistics

README 文档

README

bilfeldt/laravel-request-logger

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

Zero configuration logging of Requests and Responses to database or custom drivers in Laravel applications - no more issues debugging customer support requests.

Version Laravel PHP
1.* 8.* | 9.* 7.4.* | 8.0.* | 8.1.*
2.* 10.* 8.1.* | 8.2.*
3.* 10.* | 11.* | 12.* 8.1.* | 8.2.* | 8.3.* | 8.4.*

Installation

You can install the package via composer:

composer require bilfeldt/laravel-request-logger

Publish and run the migrations with:

php artisan vendor:publish --provider="Bilfeldt\RequestLogger\RequestLoggerServiceProvider" --tag="request-logger-migrations"
php artisan migrate

You can publish the config file with:

php artisan vendor:publish --provider="Bilfeldt\RequestLogger\RequestLoggerServiceProvider" --tag="request-logger-config"

Usage

It is possible to enable logging of all or some requests conditionally using one of the approaches below.

Enable log via middleware (Recommended)

This package comes with a convenient requestlog middleware that can be used to enable logging of request by simply registering the middleware on the routes (or route groups) you wish to log:

Route::middleware('requestlog')->get('/', function () {
    return 'Hello World';
});

Enable via config file

The config file includes some convenient settings for enabling logging of all or some requests:

// Enable all requests:
'log_methods' => ['*'],

// or enable all server errors
'log_statuses' => ['5**'],

Enable log via request

This package adds a macro on the Illuminate\Http\Request class making it possible to enable logging directly from the request:

/**
 * Index posts.
 *
 * @param  Request  $request
 * @return Response
 */
public function index(Request $request)
{
    $request->enableLog();

    //
}

Extending with custom Drivers

This package implements the Laravel Manager Class making it possible to easily register custom drivers either in your application or by third party packages.

An example driver can be specified as middleware parameters:

Route::middleware('log:example')->get('/', function () {
    return 'Hello World';
});

or via request macro:

$request->enableLog('example');

Pruning

The number of logged requests can quickly grow if you are not pruning the logs regularly. In order to keep the logs manageable, you can use the prune command to remove old logs as described in the Laravel Docs:

$schedule->command('requestlog:prune')->daily();

Note that the default RequestLog model setup by this package will not be discovered as a "Prunable" model by Laravel default model:prune command as it does not reside in the app/Models directory. If you change this class in the configuration to a custom class this will be auto registered and the command above will be needless.

Notes and advises

Proxies and load balancers

When using proxies and/or load balancers then the IP address of the proxy/load balancer must be listed as a Trusted Proxy for the users IP address to be correctly logged as the IP of the proxy itself will be logged otherwise.

Testing

composer test

Changelog

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

Contributing

Please see CONTRIBUTING for details.

Security Vulnerabilities

Please review our security policy on how to report security vulnerabilities.

Credits

License

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

统计信息

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

GitHub 信息

  • Stars: 120
  • Watchers: 2
  • Forks: 11
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2021-11-08