sql >> Databáze >  >> RDS >> Mysql

Určete typ mime ze sloupce MySQL

POKUD váš hostitel stále používá php 5.2 a nemáte přístup k funkcím fileinfo, můžete otestovat podpis záhlaví souborů (magická čísla) a určit typ mime

function mimetype($data)
{
    //File signatures with their associated mime type
    $Types = array(
    "474946383761"=>"image/gif",                        //GIF87a type gif
    "474946383961"=>"image/gif",                        //GIF89a type gif
    "89504E470D0A1A0A"=>"image/png",
    "FFD8FFE0"=>"image/jpeg",                           //JFIF jpeg
    "FFD8FFE1"=>"image/jpeg",                           //EXIF jpeg
    "FFD8FFE8"=>"image/jpeg",                           //SPIFF jpeg
    "25504446"=>"application/pdf",
    "377ABCAF271C"=>"application/zip",                  //7-Zip zip file
    "504B0304"=>"application/zip",                      //PK Zip file ( could also match other file types like docx, jar, etc )
    );

    $Signature = substr($data,0,60); //get first 60 bytes shouldnt need more then that to determine signature
    $Signature = array_shift(unpack("H*",$Signature)); //String representation of the hex values

    foreach($Types as $MagicNumber => $Mime)
    {
        if( stripos($Signature,$MagicNumber) === 0 )
            return $Mime;  
    }

    //Return octet-stream (binary content type) if no signature is found
    return "application/octet-stream"; 
}

POZNÁMKA: Některé podpisy se mohou shodovat s částmi jiných, například podpis souboru PK Zip se shoduje s prvními 4 bajty podpisu souboru java archivu (.jar), ve smyčce foreach by bylo potřeba dalších příkazů, aby se určil správný podpis pro mime typu , ale pro vaši situaci by to mělo stačit.

Aktualizovaný seznam podpisů souborů lze nalézt na adrese http://www.garykessler.net/library /file_sigs.html pokud někdo potřebuje více typů podpisů souborů.



  1. jak globálně nastavit autocommit false

  2. Jaký je nejlepší datový typ pro měny v MySQL?

  3. MySQL:Proč 5. ID v klauzuli IN drasticky mění plán dotazů?

  4. Smazat pomocí Join v MySQL