以圖片 $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可以判斷這個文件是否為圖像文件(可以避免有人把非法程序偽造成圖片文件);