您的位置:

详解PHP函数getimagesize()

一、简介

1.1 概述

在PHP中,getimagesize()是一个用于获取图像信息的函数,它能返回一张图像的基本信息,例如图像的类型、宽度、高度以及是否为一张CMYK类型的图片等等。该函数能够读取本地文件,远程文件,以及任意支持流输入输出的文件。具有广泛的应用场景,常常应用于图片上传、处理和展示等领域。

1.2 语法

getimagesize ( string $filename , array &$imageinfo ) : array|false

1.3 参数说明

参数1:$filename,要获取信息的图像文件名或图像流。

参数2:$imageinfo,一个可选的包含图像相关信息的数组,用于接收返回值。

1.4 返回值

如果获取成功,getimagesize()函数将会返回一个包含图片信息的数组,否则将会返回false。

二、获取图像基本信息

2.1 获取图像类型

在获取图像基本信息的时候,最常见的就是想要了解图像的类型。getimagesize()函数返回的数组中,下标2存储的就是图像的类型。

//这里用的是一张JPEG格式的图片
$file = "test.jpg";
$size = getimagesize($file);
$type = $size[2];  //获取图像类型
if($type == IMAGETYPE_JPEG){
    echo "这是一张JPEG格式的图片";
}else{
    echo "这不是一张JPEG格式的图片";
}

2.2 获取图像宽高

除了图像类型以外,图像的宽度和高度也是获取图像基本信息时非常常见的需求。getimagesize()函数返回的数组中,下标0和1分别存储的是图像的宽度和高度。

$file = "test.jpg";
$size = getimagesize($file);
$width = $size[0];  //获取图像宽度
$height = $size[1]; //获取图像高度
echo "这张图片的宽度为{$width}px,高度为{$height}px";

三、获取更多图像信息

3.1 获取DPI

针对一些印刷品或打印输出需求,需要知道图像的像素密度信息(即DPI),这也可以通过getimagesize()函数获得。这需要将$size数组的第三个值和第四个值作为分母计算得到。

$file = "test.jpg";
$size = getimagesize($file);
list($dpi_x, $dpi_y) = array($size[3]/$size[0] * 2.54, $size[4]/$size[1] * 2.54);
echo "这张图片的横向DPI为{$dpi_x},纵向DPI为{$dpi_y}";

3.2 获取颜色模式

图像的颜色模式一般分为RGB模式和CMYK模式两种,可以通过getimagesize()函数返回的数组中的第二个值来判断。

$file = "test.jpg";
$size = getimagesize($file);
$color_mode = $size['channels'] == 3 ? "RGB模式":"CMYK模式";
echo "这张图片颜色为{$color_mode}";

3.3 获取图像大小

除了获取图像的宽高,有时候我们还需要获取图像在硬盘中的实际大小,这个也可以通过getimagesize()函数返回的数组中的filesize属性获取。

$file = "test.jpg";
$size = getimagesize($file);
$filesize = $size['filesize']/1024;
echo "这张图片大小为{$filesize}KB";

3.4 获取图像方向

对于一些拍摄角度比较特殊的图片,我们可能需要知道它的方向信息,这也可以通过getimagesize()函数进行获取。

$file = "test.jpg";
$size = getimagesize($file);
if($size['height'] > $size['width']){
    echo "这张图片是竖直方向";
}else{
    echo "这张图片是水平方向";
}

四、异常处理

4.1 处理文件不存在异常

当我们需要获取一张不存在或者非法的图片文件信息时,getimagesize()函数会报错。为了避免程序因为错误而中断,我们可以在调用该函数之前先检测文件是否存在。

$file = "not_exist.jpg";
if(file_exists($file)){
    $size = getimagesize($file);
    //其他操作
}else{
    echo "文件不存在";
}

4.2 处理非图片文件异常

当我们用getimagesize()函数获取非图片类型的文件信息时,也会报错。为了避免程序因为错误而中断,我们可以使用try-catch机制进行异常处理。

try{
    $size = getimagesize("test.txt");
}catch(Exception $e){
    echo "文件不是图片类型";
}

总结

通过本篇文章的介绍,我们可以看到getimagesize()函数在获取图像信息方面非常实用,能够满足我们日常开发中绝大部分对于图像信息的需求。同时,在使用该函数时,我们也需要注意异常处理,以保证程序的稳定性。