Formulário de envio de arquivos
A primeira coisa a fazer é criar um formulário HTML que, ao abrir uma janela, permitará a escolha do arquivo a enviar:
FORM method="POST" action="[seu arquivo PHP para fazer upload.php]" ENCTYPE="multipart/form-data"> <INPUT type=hidden name=MAX_FILE_SIZE VALUE=2048> <INPUT type=file name="nome do arquivo"> <INPUT type=submit value="enviar"> </FORM>
É fundamental não esquecer a ENCTYPE=”multipart/form-data” ! Caso contrário, o formulário não terá nenhum efeito.
Além disso, o campo MAX_FILE_SIZE indica o tamanho máximo do arquivo a ser enviado pelo navegador mas, isto não é o bastante para garantir que os arquivos enviados não ultrapassarão um determinado tamanho na medida em que nem todos os navegadores levam em conta este tamanho. O valor do tamanho máximo do arquivo enviado é ajustável no disco rígido dentro a pasta de configuração “php.ini”.
Configuração do PHP para fazer upload
O arquivo de configuração « php.ini » contém diretivas que ajustam e que autorizam ou não o envio de arquivos através de um formulário:
file_uploads= On/Off autoriza ou não o envio de arquivos.
upload_tmp_dir = diretório define temporáriamente o diretório, possibilitando a recepção do arquivo enviado.
upload_max_filesize = 2M define o tamanho máximo permitido do arquivo. Se este limite for ultrapassado, o servidor enviará um alerta de erro.
post_max_size indica o tamanho máximo de dados enviados por formulário. Esta diretiva tem primazia sobre o upload_max_filesize ; assim, certifique-se que você tem post_max_size superior a upload_max_filesize
Se você não tiver acesso à configuração (no caso de um site hospedado em um servidor do provedor de acesso ou de uma hospedagem compartilhada), pode-se verificar a configuração graças à função phpinfo() :
<? phpinfo(); ?>
Recuperação do arquivo com PHP
O arquivo e suas informações podem ser encontrados através da variável superglobal $_FILES[].
Para afixar o seu conteúdo, utilize o seguinte script:
<pre><? print_r($_FILES); ?></pre>
A saída deste código será da seguinte forma :
Array ( [nome_do_arquivo] => Array ( [name] => MaBelleImage.jpg [type] => image/jpg [tmp_name] => chemin_complet_du_fichier_uploadé [error] => 0 [size] => 1000 ) )
No caso acima, trata-se de uma imagem JPEG pesando 1 Mo.
Os campos $_FILES[name], $_FILES[type], $_FILES|error], $_FILES[size] permitem testar o tipo de arquivo, seu tamanho , seu nome e verificar se houve erros.
Assim, você pode corrigir os erros da seguinte maneira:
<? if ($_FILES['nome do arquivo']['error']) { switch ($_FILES['nome_do_arquivo']['error']){ caso 1: // UPLOAD_ERR_INI_SIZE echo"O arquivo ultrapassa o limite autorizado pelo servidor(arquivo php.ini) !"; break; caso 2: // UPLOAD_ERR_FORM_SIZE echo " O arquivo ultrapassa o limite autorizado no formulário HTML !"); break; caso 3: // UPLOAD_ERR_PARTIAL echo "O envio do arquivo foi interrompido durante a transferência!"; break; caso 4: // UPLOAD_ERR_NO_FILE echo "O arquivo que você enviou tem um tamanho zero !"); break; } } else { // $_FILES['nome_do arquivo']['error'] vale 0 ou seja UPLOAD_ERR_OK // o que significa que não houve erro } ?>
Com o move_uploaded_files() é possível transferir uma imagem do diretório temporário a um diretório de destino :
<? if ((isset($_FILES['nom_du_fichier']['arquivo'])&&($_FILES['nome_do arquivo']['error'] == UPLOAD_ERR_OK)) { $caminho_destino = '/var/www/arquivos/'; move_uploaded_file($_FILES['nome_do_arquivo']['tmp_name'], $caminho_destino.$_FILES['nome_do_arquivo']['name']); } ?> Fonte: http://pt.kioskea.net/faq/111-php-atualizar-arquivos