以图片 $imgurl = "http://www.php10086.com/wp-content/themes/inove/img/readers.gif"; 为例;
思路1. 把图片名当做字符串来处理,那么判断图片格式的也就是变成了查找“.”号的字符串。
方法一:strrchr() 函数查找字符串在另一个字符串中最后一次出现的位置,并返回从该位置到字符串结尾的所有字符。
echo $ext = strrchr($imgurl,'.');
输出:
.gif
方法二:strrpos() 函数查找字符串在另一个字符串中最后一次出现的位置。
注释:该函数对大小写敏感。如需进行大小写不敏感的查找,请使用 strripos()。
过程是这样的:先计算.号的位置,在使用substr截取字符串
echo $ext1 = substr($imgurl,strrpos($imgurl, '.'));
输出:
.gif
方法三:explode()把字符串分割成数组,取数组最后一个键值
echo (@end(explode(".",$imgurl)));
输出:
gif
思路2:把图片路径当作文件路径,那么这里就需要gd类库函数或者php文件函数
方法四:pathinfo(path,options)函数以数组的形式返回文件路径的信息
包括以下的数组元素:
[dirname]
[basename]
[extension]
options参数: 可选。规定要返回的数组元素。默认是 all。
可能的值:
PATHINFO_DIRNAME – 只返回 dirname
PATHINFO_BASENAME – 只返回 basename
PATHINFO_EXTENSION – 只返回 extension
echo pathinfo($imgurl,PATHINFO_EXTENSION);
输出:
gif
使用 print_r(pathinfo($imgurl)) 打印返回的整个数组:
Array ( [dirname] => http://www.jb51.net/images [basename] => logo.gif [extension] => gif [filename] => logo )
方法五:getimagesize获取图片大小,格式的方式
$imginfo= getimagesize($imgurl); echo end($imginfo);
输出:
image/gif
使用 print_r($imginfo) 打印返回的整个数组:
Array ( [0] => 215 [1] => 78 [2] => 1 [3] => width="215" height="78" [bits] => 8 [channels] => 3 [mime] => image/gif )
方法六:get_headers获取http报头信息,如果图片路径是一个标准的url路径,那么可以使用get_header函数,这个函数可以返回http报头;
$imghttp = get_headers($imgurl,true); print_r($imghttp);
输出:其中“Content-Type”保存的就是格式。
Array ( [0] => HTTP/1.1 200 OK [Date] => Wed, 10 Jun 2015 12:01:35 GMT [Content-Length] => 4481 [Content-Type] => image/gif [Last-Modified] => Sat, 17 Dec 2011 15:54:02 GMT [Accept-Ranges] => bytes [ETag] => "b0cc3219d4bccc1:1896" [Server] => Microsoft-IIS/6.0 [X-Powered-By] => ASP.NET [X-Via] => 1.1 lp87:1 (Cdn Cache Server V2.0) [Via] => 1.1 swiftcache2-pgp.network.nus.edu.sg [Connection] => close )
方法七:使用gd类库函数exif_imagetype()读取一个图像的第一个字节并检查其签名。如果发现了恰当的签名则返回一个对应的常量,否则返回 FALSE。返回值和 getimagesize() 返回的数组中的索引 2 的值是一样的,但本函数快得多。
echo exif_imagetype($imgurl);
输出:
1
1对应的就是gif格式的图像,其他数值的含义如下表所示:
完整代码:
1 <?php 2 $imgurl = "http://www.php10086.com/wp-content/themes/inove/img/readers.gif"; 3 //方法1 4 echo $ext = strrchr($imgurl,'.'); 5 echo '<hr>'; 6 //方法2 7 echo $ext1 = substr($imgurl,strrpos($imgurl, '.')); 8 echo '<hr>'; 9 //方法3 10 echo(@end(explode(".",$imgurl))); 11 echo '<hr>'; 12 //方法4 13 echo pathinfo($imgurl,PATHINFO_EXTENSION); 14 print_r(pathinfo($imgurl)); 15 echo '<hr>'; 16 //方法5 17 $imginfo= getimagesize($imgurl); 18 print_r($imginfo); 19 echo end($imginfo); 20 echo '<hr>'; 21 //方法6 22 $imghttp = get_headers($imgurl,true); 23 print_r($imghttp); 24 echo '<hr>'; 25 //方法7 26 echo exif_imagetype($imgurl);
总结:
比较主流使用的方法是方法1;
如果考虑安全问题的话可以使用方法5,因为方法5可以判断这个文件是否为图像文件(可以避免有人把非法程序伪造成图片文件);