PHP Conference Fukuoka 2025

lstat

(PHP 4, PHP 5, PHP 7, PHP 8)

lstatDevuelve información sobre un fichero o un enlace simbólico

Descripción

lstat(string $filename): array|false

Devuelve información sobre un fichero o un enlace simbólico.

Parámetros

filename

Ruta de acceso a un fichero o un enlace simbólico.

Valores devueltos

Consúltese la página del manual de stat() para obtener más información sobre la estructura del array devuelto por lstat(). Esta función es idéntica a la función stat() excepto que si filename es un enlace simbólico, la información se basará en el enlace simbólico.

En caso de error, se devuelve false.

Errores/Excepciones

En caso de fallo, se emitirá una advertencia de tipo E_WARNING.

Ejemplos

Ejemplo #1 Comparación entre stat() y lstat()

<?php
symlink
('uploads.php', 'uploads');

// Se destaca la diferencia de información
array_diff(stat('uploads'), lstat('uploads'));
?>

Resultado del ejemplo anterior es similar a :

Información que difiere entre los 2 ficheros.

Array
(
    [ino] => 97236376
    [mode] => 33188
    [size] => 34
    [atime] => 1223580003
    [mtime] => 1223581848
    [ctime] => 1223581848
    [blocks] => 8
)

Notas

Nota: Los resultados de esta función están en caché. Véase la función clearstatcache() para más detalles.

Sugerencia

A partir de PHP 5.0.0, esta función también puede ser utilizada con algunos protocolos url. Lea Protocolos y Envolturas soportados para conocer los protocolos que soportan la familia de funcionalidades de stat().

Ver también

  • stat() - Proporciona información sobre un fichero

add a note

User Contributed Notes 2 notes

up
-1
HP@SG
4 years ago
Just for information and in reply to a previous message left 4 years ago by "salsi at icosaedro dot it" :Files larger than 2 GiB can be handled on 64-bit Linux systems.My test in a terminal is as follow (using <?php ;?> tags to colour the results for ease of reading) :$ php -v<?php"PHP 7.2.24-0ubuntu0.18.04.7 (cli) (built: Oct  7 2020 15:24:25) ( NTS )Copyright (c) 1997-2018 The PHP GroupZend Engine v3.2.0, Copyright (c) 1998-2018 Zend Technologies    with Zend OPcache v7.2.24-0ubuntu0.18.04.7, Copyright (c) 1999-2018, by Zend Technologies";?>$ date ; dd if=/dev/zero of=/tmp/php_test_huge bs=1024K count=2100 ; date ; ls -l /tmp/php_test_huge<?php"Wed Nov 11 15:35:46 +08 20202100+0 records in2100+0 records out2202009600 bytes (2.2 GB, 2.1 GiB) copied, 4.79192 s, 460 MB/sWed Nov 11 15:35:51 +08 2020-rw-r--r-- 1 harold harold 2202009600 Nov 11 15:35 /tmp/php_test_huge";?>$ php -r 'var_dump(lstat("/tmp/php_test_huge"));'<?php"array(26) {  [0]=>  int(2050)  [1]=>  int(19923027)  [2]=>  int(33188)  [3]=>  int(1)  [4]=>  int(1000)  [5]=>  int(1000)  [6]=>  int(0)  [7]=>  int(2202009600)  [8]=>  int(1605079647)  [9]=>  int(1605080149)  [10]=>  int(1605080149)  [11]=>  int(4096)  [12]=>  int(4300808)  ["dev"]=>  int(2050)  ["ino"]=>  int(19923027)  ["mode"]=>  int(33188)  ["nlink"]=>  int(1)  ["uid"]=>  int(1000)  ["gid"]=>  int(1000)  ["rdev"]=>  int(0)  ["size"]=>  int(2202009600)  ["atime"]=>  int(1605079647)  ["mtime"]=>  int(1605080149)  ["ctime"]=>  int(1605080149)  ["blksize"]=>  int(4096)  ["blocks"]=>  int(4300808)}";?>
up
-3
salsi at icosaedro dot it
9 years ago
This function fails and returns FALSE with files larger than 2 GB on Linux 32-bits (PHP 7.1.0-dev):    $ dd if=/dev/zero of=/tmp/huge bs=1048576 count=2050    $ php -r 'var_dump(lstat("/tmp/huge"));'    --> Warning: lstat(): Lstat failed for /tmp/huge in Command line code on line 1Window not tested. PHP 64-bits not tested.
To Top