Jump to content
eduardaarosaa

Mudar o nome das imagens de um array do tipo file

Recommended Posts

Eu estou salvando no banco de dados um array, como nome das imagens que são adicionadas por campos dinâmicos.

E movendo para um pasta as imagens.

Eu queria mudar o nome das imagens colocando na frente de cada nome um número randômico, porém da maneira que estou fazendo só está pegando no primeiro nome no índice [0] as demais não pegam o número.

<?php
include "../telas/sessao.php";
include "conexao.php";
$numero = rand();
$valor_total = $_POST['valor_total'];
$quantidade = implode('-',$_POST['quantidade']);
$carteira = implode(',', $_POST['carteira']);
$tipo = implode(',',$_FILES['file']['type']);
foreach($_FILES['file']['name'] as $nome => $a){
$nome = implode(',', $_FILES['file']['name']);
 
$nome_novo = str_place($nome,$numero, $nome);

echo $nome_novo;

    $tamanho = implode(',',$_FILES['file']['size']);

    $dia = mktime(date('d'), date('m'), date('y'));

    $data1 = gmdate('d/m/Y',$dia);

    //print $data1;

    $time = mktime(date('H')-3, date('i'), date('s'));

    $hora = gmdate("H:i:s", $time);

    foreach( $_FILES['file']['name'] as $key =>$name){

        $nome1 =  $numero . ($_FILES['file']['name'][$key]);

         move_uploaded_file( $_FILES['file']['tmp_name'][$key], "C:\\xampp\\htdocs\\otc\\anexos\\$nome1");    
    }

 

Share this post


Link to post
Share on other sites

Segue exemplo:

 

<?php

$folder_path = "C:\\xampp\\htdocs\\otc\\anexos\\";

foreach ( $_FILES [ 'file' ][ 'tmp_name' ] as $key => $a ) {
	# ARQUIVO CONF
	$f_name = $_FILES [ 'file' ][ 'name' ][ $key ];
	$f_tmp_name = $_FILES [ 'file' ][ 'tmp_name' ][ $key ];
	$f_ext = pathinfo ( $f_name, PATHINFO_EXTENSION );

	# NOVO NOME
	$new_name = uniqid ( time () ) . '.' . $f_ext;

	# CAMINHO + NOME
	$f_p_name = $folder_path . $new_name;

	# MOVE
	if ( @ move_uploaded_file ( $f_tmp_name, $f_p_name ) ) {
		echo "Enviado com sucesso!!!";
	} else {
		echo "Error!!!";
	}
}

 

Share this post


Link to post
Share on other sites
1 hora atrás, ShadowDLL disse:

Segue exemplo:

 


<?php

$folder_path = "C:\\xampp\\htdocs\\otc\\anexos\\";

foreach ( $_FILES [ 'file' ][ 'tmp_name' ] as $key => $a ) {
	# ARQUIVO CONF
	$f_name = $_FILES [ 'file' ][ 'name' ][ $key ];
	$f_tmp_name = $_FILES [ 'file' ][ 'tmp_name' ][ $key ];
	$f_ext = pathinfo ( $f_name, PATHINFO_EXTENSION );

	# NOVO NOME
	$new_name = uniqid ( time () ) . '.' . $f_ext;

	# CAMINHO + NOME
	$f_p_name = $folder_path . $new_name;

	# MOVE
	if ( @ move_uploaded_file ( $f_tmp_name, $f_p_name ) ) {
		echo "Enviado com sucesso!!!";
	} else {
		echo "Error!!!";
	}
}

 

Desta forma só add uma imagem, eu quero adicionar várias imagens ao mesmo tempo .... Mas obrigada por tentar ajudar (:

Share this post


Link to post
Share on other sites

Ja tentou assim:

Obs: faço a mínima ideia se vai funcionar! só um palpite.


foreach( $_FILES['file']['name'] as $key =>$name){ 
  $rand[$key] = rand();
  $nome1[$key] = $rand[$key] . ($_FILES['file']['name'][$key]); 
  move_uploaded_file( $_FILES['file']['tmp_name'][$key], "C:\\xampp\\htdocs\\otc\\anexos\\".$nome1[$key]); 
}

 

Share this post


Link to post
Share on other sites
11 horas atrás, luannsr12 disse:

Ja tentou assim:

Obs: faço a mínima ideia se vai funcionar! só um palpite.



foreach( $_FILES['file']['name'] as $key =>$name){ 
  $rand[$key] = rand();
  $nome1[$key] = $rand[$key] . ($_FILES['file']['name'][$key]); 
  move_uploaded_file( $_FILES['file']['tmp_name'][$key], "C:\\xampp\\htdocs\\otc\\anexos\\".$nome1[$key]); 
}

 

 Obrigada por tentar me ajudar ... Mas meu problema não está em mover o arquivo ele move normal 

Meu insert está inserindo assim: 

insert into ordens(valor_total,quantidade,carteira,tipo,nome,tamanho,email,data,hora,status)values( '1','1','3asahushahu','image/png,image/jpeg','560156050barco.png','143810,6264','paulo@gmail.com','31/05/2019','16:50:57','0')

 

E eu queria que ele inseri-se assim: 

insert into ordens(valor_total,quantidade,carteira,tipo,nome,tamanho,email,data,hora,status)values( '1','1','3asahushahu','image/png,image/jpeg','560156050barco.png,560156050duda.jpg','143810,6264','paulo@gmail.com','31/05/2019','16:50:57','0')

 

No mesmo campo: '560156050barco.png,560156050duda.jpg' duas fotos

 

Eu até tentei fazer assim: 

$nome = $numero . ($_FILES['file']['name']);

Ai ele fica assim: 

insert into ordens(valor_total,quantidade,carteira,tipo,nome,tamanho,email,data,hora,status)values( '1','1','3asahushahu','image/png,image/jpeg','560156050barco.png,duda.jpg','143810,6264','paulo@gmail.com','31/05/2019','16:50:57','0')

Ele pega as duas fotos, porém só a primeira com o $numero. 

Se tiver alguma sugestão, ou outra forma de fazer estou aberta 

Muito Obrigada

Share this post


Link to post
Share on other sites

Oi, fiz um exemplo para renomear todas a imagens do array $_FILES, só não fiz a parte de mover as imagens, só você complementar, segue:

 

<?php

if (isset($_POST['sendImagens'])) {
	foreach($_FILES as $imagem){
		$novas_imagens = [];
		foreach ($imagem['name'] as $key => $img){
			$md5 = md5(uniqid($key[$img]));
			$novas_imagens[] =  $md5.'_'.$img;
		}
	}
  	// imprime o array com os novos nomes
	echo "<pre>";
	var_dump($novas_imagens);
}

?>

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Exemplo Upload</title>
</head>

<body>
	<form method="POST" action="#" enctype="multipart/form-data">
		<input type='file' multiple name='imagens[]' />
		<input type='submit' value='Enviar' name='sendImagens' />
	</form>
</body>

</html>

 

Share this post


Link to post
Share on other sites
Em 31/05/2019 at 11:28, eduardaarosaa disse:

 Obrigada por tentar me ajudar ... Mas meu problema não está em mover o arquivo ele move normal 

Meu insert está inserindo assim: 

insert into ordens(valor_total,quantidade,carteira,tipo,nome,tamanho,email,data,hora,status)values( '1','1','3asahushahu','image/png,image/jpeg','560156050barco.png','143810,6264','paulo@gmail.com','31/05/2019','16:50:57','0')

 

E eu queria que ele inseri-se assim: 

insert into ordens(valor_total,quantidade,carteira,tipo,nome,tamanho,email,data,hora,status)values( '1','1','3asahushahu','image/png,image/jpeg','560156050barco.png,560156050duda.jpg','143810,6264','paulo@gmail.com','31/05/2019','16:50:57','0')

 

No mesmo campo: '560156050barco.png,560156050duda.jpg' duas fotos

 

Eu até tentei fazer assim: 

$nome = $numero . ($_FILES['file']['name']);

Ai ele fica assim: 

insert into ordens(valor_total,quantidade,carteira,tipo,nome,tamanho,email,data,hora,status)values( '1','1','3asahushahu','image/png,image/jpeg','560156050barco.png,duda.jpg','143810,6264','paulo@gmail.com','31/05/2019','16:50:57','0')

Ele pega as duas fotos, porém só a primeira com o $numero. 

Se tiver alguma sugestão, ou outra forma de fazer estou aberta 

Muito Obrigada

 

Segue exemplo de possível solução:

 

SQL A SER UTILIZADA

CREATE TABLE ordens (
	idOrdem INT NOT NULL AUTO_INCREMENT,
	tipo TEXT NOT NULL,
	nome TEXT NOT NULL,
	PRIMARY KEY (idOrdem)
);

 

CÓDIGO PHP

<?php

if ( $_FILES ) {
	# ARMAZENA OS ARQUIVOS
	$st_files = "";
	$st_mimes = "";

	# PATH
	$folder_path = "C://....";

	foreach ( $_FILES [ 'file' ][ 'tmp_name' ] as $key => $a ) {
		# ARQUIVO CONF
		$f_name = $_FILES [ 'file' ][ 'name' ][ $key ];
		$f_tmp_name = $_FILES [ 'file' ][ 'tmp_name' ][ $key ];
		$f_ext = pathinfo ( $f_name, PATHINFO_EXTENSION );

		# NOVO NOME
		$new_name = uniqid ( time () ) . '.' . $f_ext;

		# CAMINHO + NOME
		$f_p_name = $folder_path . $new_name;

		# ARMAZENA O MIME DOS ARQUIVO
		$st_mimes .= mime_content_type ( $f_tmp_name ) . ',';

		# ARMAZENA O NOME DO ARQUIVO
		$st_files .= $new_name . ',';

		# CÓDIGO DO UPLOAD
		# ...
	}

	# INSERE NO BANCO
	# SIMPLE CONN
	$conn = new PDO ( 'mysql:host=localhost;dbname=sua_tabela', 'root', '' );

	# INSERE
	$inserir = $conn->prepare ( 'INSERT INTO ordens (tipo, nome) VALUES (?, ?)' );
	$inserir->bindValue (1, rtrim ( $st_mimes, ',' ) );
	$inserir->bindValue (2, rtrim ( $st_files, ',' ) );
	$inserir->execute ();

	if ( $inserir->rowCount () > 0 ) {
		echo "Sucesso!!!";
	}
}

?>

<!DOCTYPE HTML>
<html>
	<head>
		<title> EXAMPLE </title>
	</head>

	<body>
		<form action="#" method="post" enctype="multipart/form-data">
			<label for="file">Selecione as Imagens</label>
			<input type="file" id="file" name="file[]" multiple />
			<br />
			<input type="submit" value="Enviar" />
		</form>
	</body>
</html>

 

RESULTADO

image.png.c58099cb3c24ab9b0ac2c1604a78de84.png

Share this post


Link to post
Share on other sites

Solução que consegui fazer ... 

 

<?php
include "../telas/sessao.php";
include "conexao.php";
$numero = rand();
$valor_total = $_POST['valor_total'];
$quantidade = implode('-', $_POST['quantidade']);
$carteira = implode(',', $_POST['carteira']);
$tipo = implode(',', $_FILES['file']['type']);
$nome = $_FILES['file']['name'];

$result = count($nome);
// echo $result;

$novo = [];
for ($i = 0; $i < $result; $i++) {

  $hehe = $numero . $nome[$i];
  array_push($novo, $hehe);

  //print_r($novo);

}
$arra = implode(',', $novo);
//print_r($arra);



//var_dump($nome);
$tamanho = implode(',', $_FILES['file']['size']);





$dia = mktime(date('d'), date('m'), date('y'));

$data1 = gmdate('d/m/Y', $dia);


//print $data1;

$time = mktime(date('H') - 3, date('i'), date('s'));

$hora = gmdate("H:i:s", $time);




foreach ($_FILES['file']['name'] as $key => $name) {

  $nome1 =  $numero . ($_FILES['file']['name'][$key]);

  move_uploaded_file($_FILES['file']['tmp_name'][$key], "C:\\xampp\\htdocs\\otc\\anexos\\$nome1");
}


$logado = $_SESSION['email'];

$inserir = "insert into ordens(valor_total,quantidade,carteira,tipo,nome,tamanho,email,data,hora,status)values(
  '$valor_total','$quantidade','$carteira','$tipo','$arra','$tamanho','$logado','$data1','$hora','0')";


$resposta = mysqli_query($link, $inserir);
//echo "Error: " . $inserir . "<br>" . mysqli_error($link);

 
    
//     }

if($resposta == true){
    echo ("<script>
    window.alert('Ordem criada com sucesso!')
    window.location.href='../telas/minhas_ordens.php';
    </script>");
}else{
    echo ("<script>
    window.alert('Erro entre em contato com a Bloco1!')
    window.location.href='../telas/criar_ordem.php';
    </script>");
}

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 proflupin
      criei uma página que busca alguns dados no BD e retornar em forma de collapse. Como existe um WHILE executando o collapse, ele sempre o executa com o mesmo ID, ou seja, se eu tiver 20 collapse, todos vão ser abertos ao clicar no primeiro.
      A dúvida é, como eu posso criar um novo ID para o collapse a cada loop do While?
      Código:
       
      <?php while($result_inners = mysqli_fetch_object($result_inner)){ ?> <div class="card-footer "> <a class="text-muted" data-toggle="collapse" href="#collapse1" role="button" aria-expanded="false" aria-controls="collapseExample"> <i class="fas fa-comment-alt"></i> <?php if(!empty($result_inners->nome_completo)) echo $result_inners->nome_completo . " respondeu..."; else echo "Aguardando resposta do técnico." ?> </a> <div class="collapse " id="collapse1"> <div class="bg-white mt-2 p-2"> <?php echo nl2br($result_inners->mensagem) ?> </div> <span style="color: #6c757d; float: right;"><?php echo date('d/m/Y H:i', strtotime($result_inners->data_hora)) ?></span> </div> </div> <?php } ?>  
    • By elielton
      Preciso usar um regex 
      qual expressão reconhece: 03-190325
       
       
      Alguém pode me ajudar?
       
       
    • By Guilherme Scarpatto
      <p>Escolha a categoria: <select name="categoria"> <option></option> <option value="v1">Conhecimentos gerais</option> <option value="v2">Português</option> <option value="v3">Matemática</option> <option value="v4">História</option> <option value="v5">Geografia</option> <option value="v6">Sociologia</option> <option value="v7">Tecnologia</option> <option value="v8">Biologia</option> <option value="v9">Programação</option> <option value="v10">Banco de dados</option> </select>  
    • By jeandelima
      Olá pessoal, estava querendo saber se podem me ajudar com uma pequena dúvida que surgiu há poucos dias.
       
      Estou com problemas pra importar um banco de dados pra o usar no meu servidor local (xampp). O banco de dados foi exportado do site de um cliente, e lá no server eles usam o mysql. Instalei a versão mais recente do xampp no meu pc, e quando fui importar o banco pra poder começar os trabalhos, deu vários erros de sintaxe. Daí fiz umas pesquisas e encontrei alguns materiais que mencionavam que o xampp agora usa o mariadb, e ele não é 100% compatível com mysql.
       
      Estou há um bom tempo sem mexer com programação e também sem me atualizar das coisas, e gostaria de saber se alguém sabe a partir de qual versão do xampp eles passaram a usar o mariadb. Eu já pesquisei mas não obtiver sucesso. E instalar e desinstalar inúmeras versões é algo trabalhoso e cansativo demais. Alguém poderia me ajudar?
       
      Desde já, muito obrigado.
       
      PS.: Por ser novo aqui no forum, e por não frequentar forum há muito tempo, acho que acabei postando no lugar errado. Peço perdão aos adms.
    • By Ygor Silva
      Boa tarde gente. Tenho meu site em Mobirise, pra pegar leads. 
      Ao cliente clicar em enviar ele só mostra a mensagem de "obrigado, aguarde nosso contato". 
      Eu gostaria que em vez disto, ele encaminhasse ele pra página de obrigado.
      Já tentei um mente de coisas mas não funcionou.
       
      Segue abaixo o código. Este meu formulário é formoid.
      <div data-form-type="formoid">                     <!---Formbuilder Form--->                     <form action="https://mobirise.com/" method="POST" class="mbr-form form-with-styler" data-form-title="Mobirise Form"><input type="hidden" name="email" data-form-email="true" value="A6LDZwZh8SsHY2SXE5G0uDeobTt+vGAPyztLTpaFnJ3YS523L+3ekb+dfC0ljSO2ENKcG2x7MzCrFsvX6BsE84UN+iQwUvASww4aTuqS7DVv4QO8axCqYvnhYxsAOEpX">                         <div class="row">                             <div hidden="hidden" data-form-alert="" class="alert alert-success col-12">Obrigado por deixar seu contato. Em breve ligaremos pra você.</div>                             <div hidden="hidden" data-form-alert-danger="" class="alert alert-danger col-12">                             </div>                         </div>                         <div class="dragArea">                             <div class="col-md-6  form-group" data-for="name">                                 <input type="text" name="name" placeholder="Seu nome" data-form-field="Name" required="required" class="form-control input display-7" id="name-form4-d">                             </div>                             <div class="col-md-6  form-group" data-for="phone">                                 <input type="text" name="phone" placeholder="Telefone" data-form-field="Phone" required="required" class="form-control input display-7" id="phone-form4-d">                             </div>                             <div data-for="email" class="col-md-12  form-group">                                 <input type="text" name="email" placeholder="E-mail" data-form-field="Email" class="form-control input display-7" required="required" id="email-form4-d">                             </div>                                                          <div class="col-md-12 input-group-btn  mt-2 align-center"><button type="submit" class="btn btn-primary btn-form display-4" href="obrigado.html#header3-2j">ENVIAR</button></div>                         </div>                     </form><!---Formbuilder Form--->                 </div>  
×

Important Information

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