PHPackages                             elmijo/php-error-log - PHPackages - PHPackages  [Skip to content](#main-content)[PHPackages](/)[Directory](/)[Categories](/categories)[Trending](/trending)[Leaderboard](/leaderboard)[Changelog](/changelog)[Analyze](/analyze)[Collections](/collections)[Log in](/login)[Sign up](/register)

1. [Directory](/)
2. /
3. [Logging &amp; Monitoring](/categories/logging)
4. /
5. elmijo/php-error-log

ActiveLibrary[Logging &amp; Monitoring](/categories/logging)

elmijo/php-error-log
====================

Una pequeña libreria para manejar los logs de tu aplicación de forma simple.. rapida.. y directa!!

2.0(10y ago)11.2k↓50%4MITPHPPHP &gt;=5.3.0

Since Aug 13Pushed 10y ago1 watchersCompare

[ Source](https://github.com/ElMijo/php-error-log)[ Packagist](https://packagist.org/packages/elmijo/php-error-log)[ Docs](https://github.com/ElMijo/php-error-log)[ RSS](/packages/elmijo-php-error-log/feed)WikiDiscussions master Synced 1mo ago

READMEChangelog (3)Dependencies (2)Versions (4)Used By (4)

PHP Error Log
=============

[](#php-error-log)

[![Build Status](https://camo.githubusercontent.com/d550b37c39ed2ce0aa33acab6878b6f4581d8d925f28a98ce0e58e30a713c823/68747470733a2f2f7472617669732d63692e6f72672f456c4d696a6f2f7068702d6572726f722d6c6f672e737667)](https://travis-ci.org/ElMijo/php-error-log) [![Coverage Status](https://camo.githubusercontent.com/5cb5ee731319f7cb56ba29f51c14831140fe04771247b4e8f406b69d90901049/68747470733a2f2f636f766572616c6c732e696f2f7265706f732f456c4d696a6f2f7068702d6572726f722d6c6f672f62616467652e737667)](https://coveralls.io/r/ElMijo/php-error-log) [![Scrutinizer Code Quality](https://camo.githubusercontent.com/c7c68e9a4231345b3546fed6ddde7412557886011e239dbc2a9109799b4a6ba5/68747470733a2f2f7363727574696e697a65722d63692e636f6d2f672f456c4d696a6f2f7068702d6572726f722d6c6f672f6261646765732f7175616c6974792d73636f72652e706e673f623d6d6173746572)](https://scrutinizer-ci.com/g/ElMijo/php-error-log/?branch=master)

Una pequeña libreria para manejar los logs de tu aplicación de forma simple.. rapida.. y directa!!. En lineas lo que se hizo fue crear una capa de abstracción entre el programador y la función **error\_log()** de PHP.

Entonces.. ¿Que tiene de especial?
----------------------------------

[](#entonces-que-tiene-de-especial)

- La gran ventaja es que puedes escribir logs de las tres formas posibles usando **error\_log()** con una sola función solo cambiando los parametros.
- **SIEMPRE!!** va ha escribir el log, a menos que el mensaje sea *empty*.

Guia Rapida
-----------

[](#guia-rapida)

### Instalación

[](#instalación)

Lo podemos hacer a travéz de [composer](https://getcomposer.org/doc/00-intro.md):

```
"require":{
  ...
  "elmijo/php-error-log": "2.0"
  ...
}
```

### Uso Rapido

[](#uso-rapido)

```
require '../vendor/autoload.php';

$logger = new PHPTools\PHPErrorLog\PHPErrorLog();

$logger->write('probando...');
```

¿Cuantas maneras de escribir logs tengo disponibles?
----------------------------------------------------

[](#cuantas-maneras-de-escribir-logs-tengo-disponibles)

> **erro\_log** te permite escribir o manejar los logs de tres maneras, como lo son: en el archivo error.log por defecto, enviandola por correo electronico o escribiendo los en un archivo definido por el usuario

Conociendo a la función magica..
--------------------------------

[](#conociendo-a-la-función-magica)

Esta libreria esta compuesta por una unica clase, la cual contiene un metodo *pulic static* llamado ***write***, el cual nos sirve para manejar los logs en cualquiera de las formas posibles.

- Descripción: Función para escribir logs
- Parametros:
    - message: *string* **(requerida)** Cadena de texto con el mensaje.
    - type: *integer* **(opcional,default 3)** Nivel del error con el que queremos etiquetar el log, acepta valores del 0 - 7.
    - destination: *string* **(opcional)** puede ser una lista de correos electronicos o un path absoluto del archivo donde queremos que se escriban los logs.
    - headers: *array* **(opcional)** Arreglo asociativo con las cabeceras adicionales que deseamos agregar al correo electronico, este parametro solo tendra valides si vamos a enviar el log por email.
- Return : **TRUE** si se realizo la operación o **FALSE** en caso contrario.

### Nivel del error

[](#nivel-del-error)

La clase provee al desarrollador de 8 constantes para facilitar el uso de este parametro

constatntevalortextoPEL\_EMERGENCY0emergencyPEL\_ALERT1alertPEL\_CRITICAL2criticalPEL\_ERROR3errorPEL\_WARNING4warningPEL\_NOTICE5noticePEL\_INFO6infoPEL\_DEBUG7debug### Cabeceras Adicionales(SMTP)

[](#cabeceras-adicionalessmtp)

**error\_log()** utiliza la funcion **mail()** cuando se pasa un email como destinatario del log, eso quiere decir que las mismas cabeceras que podemos definir en **mail()** al momento de enviar un correo las vamos a poder definir el la función **error\_log()**. Sin embargo, **PHPLorError** solo soportara una pequeña lista de cabeceras y aqui se la presentamos:

- **From**: Es el mas **IMPORTANTE** de todos!!, ya que sin el **NO SE ENVIARA EL CORREO**.
- **Subject**: Asunto del correo.
- **Reply-To**: Correo al cual ira la respuesta del usuario.
- **Content-type**: el tipo de contenido por defecto es *text/plain charset=iso-8859-1*.
- **Cc**: Enviar una copia a otro correo.
- **Bcc**: Enviar una copia oculta a otro correo.
- **Return-Path**: correo al cual van a llegar los errores de envio.

**NOTA**: La cabecera **To** es agregada automaticamente por **PHPErrorLog** y cualquier otra cabecera que se pase sera eliminada.

### Enviando Logs al archivo por defecto

[](#enviando-logs-al-archivo-por-defecto)

```
$logger->write('PHPErrorLog: probando... logs');

$logger->write('MiSistema: probando... logs\n\t\notra forma de hacer logs');
```

### Enviando Logs por Email

[](#enviando-logs-por-email)

Para poder enviar email es necesario que tengamos instalado y configurado un servidor de correo en nuestra maquina o en la maquina donde se ejecutara nuestra aplicación, si utilizan LINUX 👍 les recomiendo este [link](https://github.com/ElMijo/php-error-log/edit/master/README.md)

```
$headers = array(
  'From'    => 'usuario@dominio.com',
  'Subject' => 'Probando PHPErrorLog',
  'Cc'      => 'otrocorreo@dominio.com'
);

$logger->write('probando...',PEL_CRITICAL,"Jerry Anselmi ,Pedro Perez ,fulano@dominio.com",$headers);
```

#### Email con contenido HTML

[](#email-con-contenido-html)

```
$headers = array(
  'Content-type' => 'text/html; charset=iso-8859-1',
  'From'         => 'usuario@dominio.com',
  'Subject'      => 'Probando PHPErrorLog',
  'Cc'           => 'otrocorreo@dominio.com'
);

$logger->write('PHPErrorLogprobando...',PEL_WARNING,"Jerry Anselmi ,Pedro Perez ,fulano@dominio.com",$headers);
```

### Enviando Logs a un Archivo Definifo por el Usuario

[](#enviando-logs-a-un-archivo-definifo-por-el-usuario)

```
$logger->write('probando...',PEL_ERROR,realpath('dev.log'));
```

```
$logger->write('probando...',PEL_DEBUG,'/ruta/absoluta/del/dev.log');
```

Posibles impedimentos paraescribir el log
-----------------------------------------

[](#posibles-impedimentos-paraescribir-el-log)

- El mensaje es *empty*
- No se agrego la cabecera **From** en caso de que se desee enviar por correo
- Que no se tengan permisos de escritura en caso d eque el usuario defina el log, sin embargo el log se va a escribir en el archvio default

### El tema de los permisos

[](#el-tema-de-los-permisos)

En caso de que definamos el archivo log, tenemos que asignarle a apache como dueño del mismo o darle permisos de escritura

- opción 1: sudo chown www-data:www-data /ruta/absoluta/del/dev.log
- opción 2: sudo chmod 0766 /ruta/absoluta/del/dev.log

###  Health Score

31

—

LowBetter than 68% of packages

Maintenance20

Infrequent updates — may be unmaintained

Popularity20

Limited adoption so far

Community13

Small or concentrated contributor base

Maturity60

Established project with proven stability

 Bus Factor1

Top contributor holds 100% of commits — single point of failure

How is this calculated?**Maintenance (25%)** — Last commit recency, latest release date, and issue-to-star ratio. Uses a 2-year decay window.

**Popularity (30%)** — Total and monthly downloads, GitHub stars, and forks. Logarithmic scaling prevents top-heavy scores.

**Community (15%)** — Contributors, dependents, forks, watchers, and maintainers. Measures real ecosystem engagement.

**Maturity (30%)** — Project age, version count, PHP version support, and release stability.

###  Release Activity

Cadence

Every ~152 days

Total

3

Last Release

3987d ago

Major Versions

1.1 → 2.02015-06-14

PHP version history (2 changes)1.0PHP &gt;=5.3.3

2.0PHP &gt;=5.3.0

### Community

Maintainers

![](https://www.gravatar.com/avatar/f29cebdbb2fd15a592f0457549645e8197e9726e60bd91d23561339f22191645?d=identicon)[ElMijo](/maintainers/ElMijo)

---

Top Contributors

[![elmijo](https://avatars.githubusercontent.com/u/1669346?v=4)](https://github.com/elmijo "elmijo (14 commits)")

---

Tags

logphploggingerrorerror\_log

### Embed Badge

![Health badge](/badges/elmijo-php-error-log/health.svg)

```
[![Health](https://phpackages.com/badges/elmijo-php-error-log/health.svg)](https://phpackages.com/packages/elmijo-php-error-log)
```

###  Alternatives

[analog/analog

Fast, flexible, easy PSR-3-compatible PHP logging package with dozens of handlers.

3451.5M24](/packages/analog-analog)[hedii/laravel-gelf-logger

A Laravel package to send logs to a gelf compatible backend like graylog

1333.4M10](/packages/hedii-laravel-gelf-logger)[justbetter/magento2-sentry

Magento 2 Logger for Sentry

1851.5M3](/packages/justbetter-magento2-sentry)[saasscaleup/laravel-log-alarm

Laravel log Alarm help you to set up alarm when errors occur in your system and send you a notification via Slack and email

27025.0k](/packages/saasscaleup-laravel-log-alarm)[logtail/monolog-logtail

Logtail handler for Monolog

233.2M3](/packages/logtail-monolog-logtail)[e2ex/e2ex

Converts PHP Errors to Exceptions and (optionally) logs PHP Errors, Notices and Warnings with a PSR-3 compatible logger

101.5k](/packages/e2ex-e2ex)

PHPackages © 2026

[Directory](/)[Categories](/categories)[Trending](/trending)[Changelog](/changelog)[Analyze](/analyze)
