PHP5 gravando, recuperando e deletando imagens no banco de dados MYSQL
Publicado por vitor nascimento (última atualização em 04/07/2010)
[ Hits: 14.840 ]
Download ScriptPHP.zip (versão 2)
Neste script você vai ver uma das milhares maneiras de manipular arquivos binários no banco de dados MySQL.
Versão 2 - Enviado por vitor nascimento em 25/06/2010
Changelog: Mudança na captura do tipo de arquivo e uma pequena validação.
<?php
/**
* Description of up
*
* @author Vitor Nascimento Araújo
* @see e-mail nascimentvitor@yahoo.com
*/
if(isset ($_FILES["file"])) {
if($_FILES["file"]["tmp_name"]!= NULL) {
$conteudo = file_get_contents($_FILES["file"]["tmp_name"]); /*pegando conteudo do arquivo que foi enviado para upload
se estiver no linux preste atenção se você tem permissão ao diretorio e ao arquivo do upload
http://php.net/manual/pt_BR/reserved.variables.files.php*/
$tipo = trim(str_replace("image/", "",$_FILES["file"]["type"])); /*pega o tipo do arquivo não vo fazer validação porque o foco não é esse =)
tirando a informação /image
http://php.net/manual/en/function.ltrim.php
http://php.net/manual/en/function.str-ireplace.php*/
if($conteudo != NULL && $tipo != NULL) {
require_once "ConnectionFactory.php";//requisitando a classe de conexão
$c = new ConnectionFactory();
if($c->getConnection()) {
$c->execute("insert images values (null,'".$tipo."','".bin2hex($conteudo)."')"); /*passando o conteudo binario da imagem
* representação no formato hexadecimal
e inserindo na tabela com isso possibilita tambem fazer a restrição de imaggens iquais
http://php.net/manual/en/function.bin2hex.php*/
if(mysql_affected_rows($c->getLink()) > 0)
echo "O arquivo foi gravado!!<br/>
<a href=\"show.php\">Ver images</a>";
else
echo "Erro ao gravar o arquivo!!!";
$c->closeConnection();
}else
echo "Erro ao se conectar na base de dados";
}else
echo "Erro ao pegar conteudo da imagem";
}else
header("Location:index.php");
}else
header("Location:index.php");
exit;
Gravando conteudo de uma caixa de texto no banco de dados
protegendo suas páginas de maneira eficiente
Faça suas próprias atualizações de pacotes/programas no Void Linux e torne-se um Contribuidor
Como rodar o Folding@home no Linux
Criando um painel de controle (Dashboard) para seu servidor com o Homepage
O Abismo entre o Código e o Chão: Saltos Tecnológicos e a Exclusão Estrutural no Brasil
Instalar e Configurar a santíssima trindade (PAP) no Void Linux
Pisando no acelerador do Linux Mint: Kernel XanMod, zRAM e Ajustes de Swap
Como compilar kernel no Linux Mint
Lançamento do Brutal DOOM test 6
Consertando o erro no Brave de webgl
Solução para ter de volta as bordas e barra de títulos das janelas em zenity no Debian 13.x
Qual melhor distro para esse notebook? (3)
O que você está ouvindo agora? [2] (244)









