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