PHP | disk_free_space 函数

Lasted 2020-12-30 19:28:16

disk_free_space 返回给定目录的可用空间。

disk_free_space() 函数将根据相应的文件系统或磁盘分区返回可用的字节数。如果函数处理错误返回 false。

如果传入的不是文件目录,会因操作系统不同返回值不一样。

函数定义

disk_free_space(string $directory):float
// 源文件位于:ext/standard/filestat.c
# 函数定义

static int php_disk_free_space(char *path, double *space) /* {{{ */
#if defined(WINDOWS) /* {{{ */
{
  ...
  if (GetDiskFreeSpaceExW(pathw, &FreeBytesAvailableToCaller, &TotalNumberOfBytes, &TotalNumberOfFreeBytes) == 0) {
    char *err = php_win_err();
    php_error_docref(NULL, E_WARNING, "%s", err);
    php_win_err_free(err);
    PHP_WIN32_IOUTIL_CLEANUP_W()
    return FAILURE;
  }

  *space = FreeBytesAvailableToCaller.HighPart * (double) (1ULL << 32)  + FreeBytesAvailableToCaller.LowPart;

  PHP_WIN32_IOUTIL_CLEANUP_W()

  return SUCCESS;
}
/* }}} */
#elif defined(OS2) /* {{{ */
{
  ...
  if (DosQueryFSInfo( drive ? drive - 64 : 0, FSIL_ALLOC, &fsinfo, sizeof( fsinfo ) ) == 0) {
    bytesfree = (double)fsinfo.cbSector * fsinfo.cSectorUnit * fsinfo.cUnitAvail;
    *space = bytesfree;
    return SUCCESS;
  }
  return FAILURE;
}
/* }}} */
#else /* {{{ if !defined(OS2) && !defined(WINDOWS) */
{
... 
#if defined(HAVE_SYS_STATVFS_H) && defined(HAVE_STATVFS)
  if (statvfs(path, &buf)) {
    php_error_docref(NULL, E_WARNING, "%s", strerror(errno));
    return FAILURE;
  }
  if (buf.f_frsize) {
    bytesfree = (((double)buf.f_bavail) * ((double)buf.f_frsize));
  } else {
    bytesfree = (((double)buf.f_bavail) * ((double)buf.f_bsize));
  }
#elif (defined(HAVE_SYS_STATFS_H) || defined(HAVE_SYS_MOUNT_H)) && defined(HAVE_STATFS)
  if (statfs(path, &buf)) {
    php_error_docref(NULL, E_WARNING, "%s", strerror(errno));
    return FAILURE;
  }
  bytesfree = (((double)buf.f_bsize) * ((double)buf.f_bavail));
#endif

  *space = bytesfree;
  return SUCCESS;
}
#endif

参数

  • checkdirectory - 文件系统目录或者磁盘分区。不能作用于远程文件,被检查的文件必须是可通过服务器的文件系统访问的。

返回值

  • checkfloat - 返回目录可用的字节数。失败时返回 false。

示例1: - 使用 disk_free_space() 函数获取给定目录的可用空间。

<?php
/**
 * PHP 使用 disk_free_space() 函数获取给定目录的可用空间。
 *
 * @since Version 1.0.0
 * @filesource
 */

// 获取目录的字节数
$bytes = disk_free_space("/data");

echo 'Available:: '.$bytes.PHP_EOL;
echo 'Available:: '.humanReadable($bytes).PHP_EOL;

// 友好显示字节数
function humanReadable($bytes) {
  $prefix = array('B', 'KB', 'MB', 'GB', 'TB', 'PB', 'EB', 'ZB', 'YB');
  $base = 1024;
  $class = min((int)log($bytes , $base) , count($prefix) - 1);

  return sprintf('%1.2f' , $bytes / pow($base, $class)) . $prefix[$class];
}
Available:: 3378401280
Available:: 3.15GB