This package can parse, filter and export to CSV via PHP or CLI your APACHE/Nginx/Microsoft/WhatYouWant logs.
FR: https://piedweb.com/seo/logs
Via Packagist
$ composer require piedweb/logs-analyzer
Tu use it directly in php, see bin/analyzer example.
Else, you can use the command tools to filter and export to CSV your log files. Get the last args list via --help
:
bin/analyzer --help
Default parser work with Apache Access Logs :
^(?P<host>[a-zA-Z0-9\-\._:]+) (?P<logname>(?:-|[\w-]+)) (?P<user>(?:-|[\w\-\.]+)) \[(?P<time>\d{2}/(?:Jan|Feb|Mar|Apr|May|Jun|Jul|Aug|Sep|Oct|Nov|Dec)/\d{4}:\d{2}:\d{2}:\d{2} (?:-|\+)\d{4})\] "(?P<request>(?:(?:[A-Z]+) .+? HTTP/(1\.0|1\.1|2\.0))|-|)" (?P<status>\d{3}|-) (?P<responseBytes>(\d+|-)) "(?P<HeaderReferer>.*?)" "(?P<HeaderUserAgent>.*?)"$
You can change the regex directly via the CLI or by creating a new Class managing your special format. Your new class must extends \PiedWeb\LogsAnalyzer\LogLine
.
This arg permits to have only unique request (requestMethod
+ url
+ status
) keeping only the first date
and time
and counting the number of hit
$ composer test
Please see contributing
The MIT License (MIT). Please see License File for more information.