为什么在调用isValid时Zend Framework Validate对于MimeType失败?

问题描述

| 在最近的几个小时里,这让我感到困惑。
            // Using just straight up FINFO detects the mime type
            $oFileInfo = new finfo( FILEINFO_MIME_TYPE );
            $sMimeType = $oFileInfo -> file($_FILES[\'myfile\'][\'tmp_name\'] );
            // $sMimeType == \'application/pdf\';

            // Using Zend File Transfer... detects the mime type
            $upload         = new Zend_File_Transfer_Adapter_Http();                
            $upload->addValidator(\'MimeType\',true,array(\'application/pdf\'));
            // $upload->getMimetype(\'myfile\') == \'application/pdf\'

            // But when I try to validate it throws an exception
            $upload->isValid(\'myfile\');
            // Throws 
            // [fileMimeTypeFalse] => File \'myawesomefile.pdf\' has a false mimetype of \'application/octet-stream\'
代码在Apache,PHP 5.2(Zend Server)下运行良好,但现在在NginxPHP-FPM,PHP 5.3下运行良好。我很想使用isValid()方法来验证上传文件,但是mime类型无法正常工作。有什么建议么?     

解决方法

上载的文件mimetypes永远不会太可靠... 我通常会检查文件扩展名,这是一次令人沮丧的尝试,如果可能的话,请尝试实际检查文件的内容。 如果它是图像,则可以运行getimagesize(),如果它是PDF,则可以创建一个验证器来调用Zend_Pdf :: load($ filename)并检查错误。可悲的是,即使是\'Image \'验证器也对我来说遇到了同样的问题。     ,上载或验证文件时,文件扩展名可能不正确,因为当您使用。*作为扩展名时,会出现application / octet-stream。 检查finfo类中的文件功能。
//$oFileInfo -> file($_FILES[\'myfile\'][\'tmp_name\'] );