Jump to content
Camilavip

Redimensionar foto no upload

Recommended Posts

Oi, já coloquei aqui esse código, ele faz o upload da imagem, grava a foto na pasta e o caminho no banco de dados, porém eu queria ver se alguém consegue ver para mim se antes de fazer isso ele consiga redimensionar a imagem.Vi algumas soluções de GD, mas não sei como integrar.

<?php
// Conexão com o banco de dados
include "conexao.php";

// pegar a id do cliente na url (se existir)
$id_cliente = isset($_GET['id']) ? $_GET['id'] : null;
$fotoNova = null;

// se algo for postado, e existir a id do cliente
if (sizeof($_POST) && $id_cliente) {

   $foto = $_FILES['foto'];
   // Se a foto estiver sido selecionada
   if (!empty($foto['name'])) {

      // Largura máxima em pixels
      $largura = 700;
      // Altura máxima em pixels
      $altura = 1000;
      // Tamanho máximo do arquivo em bytes
      $tamanho = 1000;

      // Verifica se o arquivo é uma imagem
      if (preg_match("/^image\/(pjpeg|jpeg|png|gif|bmp)$/", $foto['type'])) {
         $error[1] = "Isso não é uma imagem.";
      }

      // Pega as dimensões da imagem
      $dimensoes = getimagesize($foto['tmp_name']);

      // Verifica se a largura da imagem é maior que a largura permitida
      if ($dimensoes[0] > $largura) {
         $error[2] = "A largura da imagem não deve ultrapassar " . $largura . " pixels";
      }

      // Verifica se a altura da imagem é maior que a altura permitida
      if ($dimensoes[1] > $altura) {
         $error[3] = "Altura da imagem não deve ultrapassar " . $altura . " pixels";
      } {

         // Pega extensão da imagem
         preg_match("/\.(gif|bmp|png|jpg|jpeg){1}$/i", $foto['name'], $ext);

         // Gera um nome único para a imagem
         $nome_imagem = md5(uniqid(time())) . "." . $ext[1];

         // Caminho de onde ficará a imagem
         $caminho_imagem = "fotos/" . $nome_imagem;
		 
		 // Tentando apagar a foto anterior da pasta
		 unlink("fotos/".$nome_imagem->foto."");

         // Faz o upload da imagem para seu respectivo caminho
         move_uploaded_file($foto['tmp_name'], $caminho_imagem);
      }
   }
     
$result = $sqli->query("SELECT foto FROM clientes WHERE id_cliente =". intval($id_cliente));
$obj = $result->fetch_object();
$path =  'fotos/'. $obj->foto;
   
// atualiza os dados no banco
$sql = $sqli->query("UPDATE clientes SET foto = '{$nome_imagem}' WHERE id_cliente =". intval($id_cliente));
// Se os dados forem inseridos com sucesso

 
   if ($sqli->error) {
      echo "<p>Erro ao atualizar.</p>" . $sqli->error;
   } else {
	   
	  if (file_exists($path)) {
		unlink($path);
	} 
	   
	   
      // vai forçar o recarregamento da imagem nova
      $fotoNova = '?' . microtime(true);
   }
}
?>

Abaixo apenas o restando do código que faz o upload, então é acima que preciso isso.

<!doctype html>
<html>
   <head>
      <meta charset='utf-8'>
      <title>CLIENTES</title>
      <link href="css/estilo.css" rel="stylesheet" type="text/css">
   </head>
   <body>
      <form id="atualizar" method="post" enctype="multipart/form-data" onsubmit="return validaCampo(); return false;" >
         <?php
         // Seleciona apenas a foto do cliente id = $id_cliente
         $result = $sqli->query("SELECT foto FROM clientes WHERE id_cliente=$id_cliente");
         if ($sqli->error) {
            die($sqli->error);
         } else {
            // Exibe as informações de cada usuário
            while ($nome = $result->fetch_assoc()) {
               // Exibimos a foto
               if (empty($nome['foto'])) {
                  echo "<img src='fotos/sem_foto.jpg' width='135' height='180'>";
               } else {
                  echo "<img src='fotos/" . $nome['foto'] . "$fotoNova' alt='Foto de exibição' width='145' height='180'><br>";
               }
               // Exibimos o nome e email..continua o resto do codigo aqui
            }
         }
         ?>    
         <input type="file" name="foto" accept="image/*"><br><br>
         <input type="hidden" name="enviar" value="1">
         <input type="submit" name="atualizar" value="Enviar" />
      </form>
   </body>
</html>

 

Achei esse código abaixo, mas nem faço ideia de como integrar a primeira parte do código que postei

 

function image_resize($file_name, $width, $height, $crop=FALSE) {
   list($wid, $ht) = getimagesize($file_name);
   $r = $wid / $ht;
   if ($crop) {
      if ($wid > $ht) {
         $wid = ceil($wid-($width*abs($r-$width/$height)));
      } else {
         $ht = ceil($ht-($ht*abs($r-$w/$h)));
      }
      $new_width = $width;
      $new_height = $height;
   } else {
      if ($width/$height > $r) {
         $new_width = $height*$r;
         $new_height = $height;
      } else {
         $new_height = $width/$r;
         $new_width = $width;
      }
   }
   $source = imagecreatefromjpeg($file_name);
   $dst = imagecreatetruecolor($new_width, $new_height);
   image_copy_resampled($dst, $source, 0, 0, 0, 0, $new_width, $new_height, $wid, $ht);
   return $dst;
}
$img_to_resize = image_resize(‘path-to-jpg-image’, 250, 250);

 

Share this post


Link to post
Share on other sites

Achei esse código, faz tudo direitinho, mas não sei como integrar no meu.

<form method="POST" action="redimensionar.php" enctype="multipart/form-data">
	<label>Imagem: </label>
	<input type="file" name="arquivo"><br><br>
	<input type="submit" value="Cadastrar">
</form>

E o arquivo redimensionar.php

<?php
	$altura = "200";
	$largura = "200";
	echo "Altura pretendida: $altura - largura pretendida: $largura <br>";
	
	switch($_FILES['arquivo']['type']):
		case 'image/jpeg';
		case 'image/pjpeg';
			$imagem_temporaria = imagecreatefromjpeg($_FILES['arquivo']['tmp_name']);
			
			$largura_original = imagesx($imagem_temporaria);
			
			$altura_original = imagesy($imagem_temporaria);
			
			echo "largura original: $largura_original - Altura original: $altura_original <br>";

			/* Configura a nova largura */
			$nova_largura = $largura ? $largura : floor (($largura_original / $altura_original) * $altura);

			/* Configura a nova altura */
			$nova_altura = $altura ? $altura : floor (($altura_original / $largura_original) * $largura);

			/* Retorna a nova imagem criada */
			$imagem_redimensionada = imagecreatetruecolor($nova_largura, $nova_altura);
         
            /* Copia a nova imagem da imagem antiga com o tamanho correto */
			//imagealphablending($imagem_redimensionada, false);
			//imagesavealpha($imagem_redimensionada, true);
			imagecopyresampled($imagem_redimensionada, $imagem_temporaria, 0, 0, 0, 0, $nova_largura, $nova_altura,              $largura_original, $altura_original);

	        //função imagejpeg que envia para o browser a imagem armazenada no parâmetro passado		
			imagejpeg($imagem_redimensionada, 'arquivo/' . $_FILES['arquivo']['name']);
			
			echo "<img src='arquivo/".$_FILES['arquivo']['name']."'>";
			
		break;
	endswitch;
?>

 

Share this post


Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now

  • Similar Content

    • By anabeatrizzz
      2. Por que PHP é a mais utilizada em projetos? Explique.
       
      3. São 24 anos de desenvolvimento em PHP, o que faz ele durar tanto na área da programação? Explique.
       
      4. Você acredita que o PHP vai morrer ou não? Explique.
       
      5. Explique o que seria esta HHVM que as empresas utilizam.
       
      6. PHP tem a facilidade de criar APIs, quais seriam as vantagens na hora de desenvolver aplicativos para celular? Explique.
       
      7. Explique um pouco sobre o Laravel, Zend Framework, Sympony, lumen, codelgniter que foram surgindo ao decorrer dos anos.
       
      8. “O PHP veio da WEB e da WEB ele permanecerá”. O que essa frase significaria para você? Explique.
       
      9. Como funcionariam as comunidades em PHP? Por que existem tantas pessoas ainda usando a linguagem? Explique.
       
      10. O PHP vem se modernizando durante anos, quais seriam estas evoluções dele? Explique.
    • By fideles
      Mais uma vez venho aqui pedir ajuda a vocês.
       
      Tenho um formulario que criei aqui na empresa algo bem simples, somente para sair das planilhas de excel, que seria cadastro de funcionarios.
       
      Tem os campos, matricula, nome completo, unidade de trabalho, endereço e telefone de emergencia.
       
      A parte do formulario funciona, a gravação no BD tbm, listar as informações também, ai me perguntaram se era possível um auto preenchimento dos campos colocando somente a matricula do funcionario e respondi que eu não sei porque realmente não sei.
       
      A ajuda que eu preciso de vocês seria, é possível fazer isso ? Colocar a matricula e vir do banco e preencher os outros inputs? Se sim, é possível me derem um exemplo de como funciona e eu estudar o codigo e colocar nos outros inputs.
       
      Obrigado antecipadamente. 
       
    • By tetsuo
      Boas galera?
      Às vezes subo um projeto que, despercebidamente passa um arquivo com letra maiúscula/minúscula
      E dá trabalho pra descobrir que era somente e apenas isso.
       
      Como posso resolver isso?
      Uso rWindows 10.
      Mas a hospedagem é em linux.
       
      O Docker serviria pra me ajudar com essa questão?
       
    • By lUANZIKA3
      minha pagina contém uma table que
      exibe a ultima id da minha DB porém ela não fica ativa.
      a ultima id só é exibida se o form tiver sido enviado.
      ↓table aonde é exibida a Insert_id
      <table class="table table-dark" method="POST" action="processa.php"> <thead> <tr> <th scope="col">#</th> <th scope="col">Ultimo ID</th> </tr> </thead> <tbody> <tr> <th scope="row">1</th> <td> <?php if(isset($_SESSION['id'])){ echo $_SESSION['id']; } ?></td> </tr> </tbody> </table> Agora a conexao.php
      <?php session_start(); $servidor = "localhost"; $usuario = "root"; $senha = ""; $dbname = "contas"; //Criar a conexao $conn = mysqli_connect($servidor, $usuario, $senha, $dbname); $nome = filter_input(INPUT_POST, 'nome', FILTER_SANITIZE_STRING); $face = filter_input(INPUT_POST, 'face', FILTER_SANITIZE_STRING); $numeros = filter_input(INPUT_POST, 'numeros', FILTER_SANITIZE_STRING); //echo "Nome: $nome <br>"; //echo "E-mail: $email <br>"; $result_usuario = "INSERT INTO usuarios (nome, face, numeros, created) VALUES ('$nome', '$face', '$numeros', NOW())"; if ($conn->query($result_usuario) === TRUE) { $id = $conn->insert_id; $_SESSION['id'] = "" . $id; } else { echo "Error: " . $result_usuario . "<br>" . $conn->error; } $resultado_usuario = mysqli_query($conn, $result_usuario); if(mysqli_insert_id($conn)){ $_SESSION['msg'] = "<div class='alert alert-success' role='alert'> Parabéns agora você está participando! </div>"; header("Location: index.php"); }else{ $_SESSION['msg'] = "<div class='alert alert-danger' role='alert'> OPS! Parece que você já está participando, espere por outro sorteio e volte! </div>"; header("Location: index.php"); }  
    • By lUANZIKA3
      minha pagina contém uma table que
      exibe a ultima id da minha DB porém ela não fica ativa.
      a ultima id só é exibida se o form tiver sido enviado.
      ↓table aonde é exibida a Insert_id
      <table class="table table-dark" method="POST" action="processa.php"> <thead> <tr> <th scope="col">#</th> <th scope="col">Ultimo ID</th> </tr> </thead> <tbody> <tr> <th scope="row">1</th> <td> <?php if(isset($_SESSION['id'])){ echo $_SESSION['id']; } ?></td> </tr> </tbody> </table> Agora a conexao.php
      <?php session_start(); $servidor = "localhost"; $usuario = "root"; $senha = ""; $dbname = "contas"; //Criar a conexao $conn = mysqli_connect($servidor, $usuario, $senha, $dbname); $nome = filter_input(INPUT_POST, 'nome', FILTER_SANITIZE_STRING); $face = filter_input(INPUT_POST, 'face', FILTER_SANITIZE_STRING); $numeros = filter_input(INPUT_POST, 'numeros', FILTER_SANITIZE_STRING); //echo "Nome: $nome <br>"; //echo "E-mail: $email <br>"; $result_usuario = "INSERT INTO usuarios (nome, face, numeros, created) VALUES ('$nome', '$face', '$numeros', NOW())"; if ($conn->query($result_usuario) === TRUE) { $id = $conn->insert_id; $_SESSION['id'] = "" . $id; } else { echo "Error: " . $result_usuario . "<br>" . $conn->error; } $resultado_usuario = mysqli_query($conn, $result_usuario); if(mysqli_insert_id($conn)){ $_SESSION['msg'] = "<div class='alert alert-success' role='alert'> Parabéns agora você está participando! </div>"; header("Location: index.php"); }else{ $_SESSION['msg'] = "<div class='alert alert-danger' role='alert'> OPS! Parece que você já está participando, espere por outro sorteio e volte! </div>"; header("Location: index.php"); }  
×

Important Information

Ao usar o fórum, você concorda com nossos Terms of Use.