PHP
downloads | documentation | faq | getting help | mailing lists | wiki | reporting bugs | php.net sites | links | conferences | my php.net

search for in the

exif_read_data> <Funções da Exif
Last updated: Fri, 14 Nov 2008

view this page in

exif_imagetype

(PHP 4 >= 4.3.0, PHP 5)

exif_imagetypeVerifica o tipo de uma imagem

Descrição

int exif_imagetype ( string $filename )

exif_imagetype() lê os primeiros bytes de uma imagem e verifica sua assinatura.

exif_imagetype() pode ser usada para evitar chamadas para outra função exif que não tem suporte a tipos de arquivos ou um conjunção cin $_SERVER['HTTP_ACCEPT'] para verificar se pode ou não visualizar uma específica imagem no browser.

Parâmetros

filename
A imagem a ser verificada.

Valor Retornado

Quando uma correta assinatura é encontrada, o valor da constante apropriada será retornado caso contrário é retornado FALSE. O valor retornado é o mesmo valor que getimagesize() retorna no índice 2, mas exif_imagetype() é mais rápida.

Histórico

Versão Descrição
4.3.2 Suporte para JPC, JP2, JPX, JB2, XBM, e WBMP
4.3.0 Suporte para SWC

Constantes pré-definidas

As seguintes constantes são definidas, e representam um possível valor retornado pela exif_imagetype():

Constantes Imagetype
Valor Constante
1 IMAGETYPE_GIF
2 IMAGETYPE_JPEG
3 IMAGETYPE_PNG
4 IMAGETYPE_SWF
5 IMAGETYPE_PSD
6 IMAGETYPE_BMP
7 IMAGETYPE_TIFF_II (intel byte order)
8 IMAGETYPE_TIFF_MM (motorola byte order)
9 IMAGETYPE_JPC
10 IMAGETYPE_JP2
11 IMAGETYPE_JPX
12 IMAGETYPE_JB2
13 IMAGETYPE_SWC
14 IMAGETYPE_IFF
15 IMAGETYPE_WBMP
16 IMAGETYPE_XBM

Exemplos

Exemplo #1 Exemplo da exif_imagetype()

<?php
if (exif_imagetype('image.gif') != IMAGETYPE_GIF) {
    echo 
'The picture is not a gif';
}
?>

Veja Também



exif_read_data> <Funções da Exif
Last updated: Fri, 14 Nov 2008
 
add a note add a note User Contributed Notes
exif_imagetype
tom dot ghyselinck at telenet dot be
13-Jan-2008 01:36
If the function exif_imagetype() is not available,
you can try the following workaround:

if ( ! function_exists( 'exif_imagetype' ) ) {
    function exif_imagetype ( $filename ) {
        if ( ( list($width, $height, $type, $attr) = getimagesize( $filename ) ) !== false ) {
            return $type;
        }
    return false;
    }
}
Tim
19-Nov-2007 08:40
By trial and error, it seems that a file has to be 12 bytes or larger in order to avoid a "Read error!".  Here's a work-around to avoid an error being thrown:

// exif_imagetype throws "Read error!" if file is too small
if (filesize($uploadfile) > 11)
    $mimetype = exif_imagetype($uploadfile);
else
    $mimetype = false;
09-Nov-2006 04:43
Seems to give a 'Read error' warning if the size of the file is very small (2 bytes). I think this is because it needs a min 3 bytes to determine the file type
tom at tomvergote dot be
07-Feb-2004 02:11
libexif can also be used to parse image info out of id3 tags:

exif_read_data("mp3_with_2.4ID3TAGS, '', true, false);
tilmauder at yahoo dot com
05-Jul-2003 04:57
After looking for hours, I found a very good source for exif related programs here: http://drewnoakes.com/code/exif/index.html
It lists exif specifications (pdf), a few good links to exif related stuff. The best source I have found in my quest to understand exif better for use in php based exif tools.

exif_read_data> <Funções da Exif
Last updated: Fri, 14 Nov 2008
 
 
show source | credits | stats | sitemap | contact | advertising | mirror sites