一般我们都是按照文件扩展名来判断文件类型,但其实不太靠谱,因为可以通过修改扩展名来伪装文件类型。
其实我们可以通过读取文件信息来识别,
比如 PHP扩展中提供了类似 exif_imagetype 这样的函数读取图片类的文件类型,但是很多时候扩展不一定安装了这样的扩展。
下面这个函数就展示了自己通过读取文件头信息来识别文件的真实类型:
- function file_type($file) {
- $filepath = realpath($file);
- $filetype = array(
- 7790=>'exe', 7784=>'midi',
- 8075=>'zip', 8297=>'rar',
- 7173=>'gif', 6677=>'bmp', 13780=>'png', 255216=>'jpg'
- );
- if (!($fp = @fopen($filepath, 'rb'))) return false;
- $bin = fread($fp, 2);
- fclose($fp);
- $str_info = @unpack('C2chars', $bin);
- $str_code = intval($str_info['chars1'].$str_info['chars2']);
- return isset($filetype[$str_code]) ? $filetype[$str_code] : 'unknown';
- }
复制代码