theodorejb / iis-log-parser
Parse IIS log files
Installs: 3 051
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 0
Open Issues: 0
pkg:composer/theodorejb/iis-log-parser
Requires
- php: >=8.1
Requires (Dev)
- phpunit/phpunit: ^10.3
- psalm/plugin-phpunit: ^0.18.4
- vimeo/psalm: ^5.15
This package is auto-updated.
Last update: 2025-10-09 21:12:32 UTC
README
This package makes it easy to parse IIS log files using PHP. Supports the standard W3C log file format with default fields as well as the optional Host field.
Install via Composer
composer require theodorejb/iis-log-parser
Usage
Construct an SplFileObject instance for the IIS log file to be parsed.
Then call the IISLogFile::getEntries static method, passing it the SplFileObject.
This returns a generator which yields an IISLogEntry object for each entry in the file.
Code example which iterates over the entries of all log files in a directory:
use theodorejb\IISLogParser\IISLogFile; $directory = new \FilesystemIterator('C:/inetpub/logs/LogFiles/W3SVC1'); while ($directory->valid()) { $current = $directory->current(); echo "Processing {$current->getFilename()}\n"; $entries = IISLogFile::getEntries($current->openFile()); foreach ($entries as $entry) { echo "Request to {$entry->uri} occurred on {$entry->date->format(DATE_ATOM)}\n"; } echo "\n"; $directory->next(); }
The IISLogEntry class has the following public properties:
DateTimeImmutable $datestring $serverIPstring $methodstring $uristring $queryint $serverPortstring $usernamestring $clientIPstring $useragentstring $refererstring $hostint $statusCodeint $subStatusCodeint $win32StatusCodeint $timeTakenMs
It also has a public getUriExtension() method.
Required fields
Only the Date and Time logging fields (used for the $date property) are required.
Other properties will be set to a blank string (or 0, for int properties)
if the associated logging field is absent.